(1)创建一个数据类工具类DBHelper,该类继承SQLiteOpenHelper,重写onCreate()和onUpgrade()方法,并添加insert()、delete()、query()方法,分别实现数据的添加、删除和查询。DBHelper类的代码如下:

package com.example.musiclist;import android.content.ContentValues;import android.content.Context;import android.database.Cursor;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;import android.os.Bundle;import android.view.Menu;import android.view.MenuItem;public class DBHelper extends SQLiteOpenHelper{    private static final String DB_NAME = "music.db";    //数据库名称    private static final String TBL_NAME = "MusicTbl";    //表名    private SQLiteDatabase db;    //声明SQLiteDatabase对象    //构造函数    DBHelper(Context c){        super(c, DB_NAME, null, 2);    }    @Override    public void onCreate(SQLiteDatabase db){        //获取SQLiteDatabase对象        this.db = db;        //创建表        String CREATE_TBL = "create table MusicTbl(_id integer primary key autoincrement, name text, singer text)";        db.execSQL(CREATE_TBL);    }    //插入    public void insert(ContentValues values){        SQLiteDatabase db = getWritableDatabase();        db.insert(TBL_NAME, null, values);        db.close();    }    //查询    public Cursor query(){        SQLiteDatabase db = getWritableDatabase();        Cursor c = db.query(TBL_NAME, null, null, null, null, null, null);        return c;    }    //删除    public void del(int id){        if(db == null){            db = getWritableDatabase();        }        db.delete(TBL_NAME, "_id=?", new String[]{String.valueOf(id)});    }    //关闭数据库    public void close(){        if(db != null){            db.close();        }    }    @Override    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {    }}

(2)创建添加音乐的AddActivity,添加界面提供两个文本框和一个按钮,用于输入音乐名和歌手名,当单击“添加”按钮时,将数据插入到表中,具体代码如下:

package com.example.musiclist;import android.app.Activity;import android.content.ContentValues;import android.content.Intent;import android.os.Bundle;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;import android.widget.EditText;public class AddActivity extends Activity {    private EditText et1, et2;    private Button b1;    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_add);        this.setTitle("添加收藏信息");        et1 = (EditText)findViewById(R.id.EditTextName);        et2 = (EditText)findViewById(R.id.EditTextSinger);        b1 = (Button)findViewById(R.id.ButtonAdd);        b1.setOnClickListener(new OnClickListener() {               public void onClick(View v) {                // 获取用户输入的文本信息                String name = et1.getText().toString();                String singer = et2.getText().toString();                //创建ContentValues对象。封装记录信息    key 和 values 值成对出现                ContentValues values = new ContentValues();                values.put("name", name);                values.put("singer", singer);                //创建数据库工具类DBHelper                DBHelper helper = new DBHelper(getApplicationContext());                //调用insert()方法插入数据                helper.insert(values);                //跳转到QueryActivity,显示音乐列表                Intent intent = new Intent(AddActivity.this, QueryActivity.class);                startActivity(intent);            }        });    }}

  当单击“添加”按钮时,先将用户输入的音乐名和歌手信息封装到ContentValues对象中,再调用DBHelper的insert()方法将记录插入到数据库中,然后跳转到QueryActivity来显示音乐列表。
AddActivity的布局文件内容如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:orientation="vertical"    android:padding="10dp">   <TableLayout       android:id="@+id/TableLayout"       android:layout_width="wrap_content"       android:layout_height="wrap_content"       android:stretchColumns="1">       "       <TableRow         android:id="@+id/TableRow01"        android:layout_width="wrap_content"        android:layout_height="wrap_content">        <TextView             android:id="@+id/TextView01"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text="歌名"/>        <EditText             android:id="@+id/EditTextName"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text=""/>         TableRow>    <TableRow         android:id="@+id/TableRow02"        android:layout_width="wrap_content"        android:layout_height="wrap_content">         <TextView             android:id="@+id/TextView02"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text="歌手"/>        <EditText             android:id="@+id/EditTextSinger"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text=""/>        TableRow>    <Button         android:id="@+id/ButtonAdd"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="添加"/>   TableLayout>LinearLayout>

(3)创建显示音乐列表的QueryActivity,具体代码如下:

package com.example.musiclist;import android.app.AlertDialog;import android.app.ListActivity;import android.content.DialogInterface;import android.database.Cursor;import android.os.Bundle;import android.support.v4.widget.CursorAdapter;import android.text.AlteredCharSequence;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.widget.AdapterView;import android.widget.AdapterView.OnItemClickListener;import android.widget.ListView;import android.widget.SimpleCursorAdapter;public class QueryActivity extends ListActivity {    //列表视图    private ListView listView = null;    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        this.setTitle("浏览音乐列表信息");        final DBHelper helpter = new DBHelper(this);        //获取listview对象,引用变量和实例化对象        listView = getListView();        //查询数据,获取游标        Cursor c = helpter.query();        //列表项数组        String[] from = {"_id", "name", "singer"};        //列表项ID        int[] to = {R.id.text0, R.id.text1, R.id.text2};        //适配器        SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, R.layout.activity_query, c, from, to);   //为列表视图添加适配器        listView.setAdapter(adapter);        //提示对话框        final AlertDialog.Builder builder = new AlertDialog.Builder(this);        //设置ListView单击监听器        listView.setOnItemClickListener(new OnItemClickListener() {            @Override            public void onItemClick(AdapterView<?>arg0, View arg1, int arg2, long arg3){                final long temp = arg3;                builder.setMessage("真的要删除该记录吗?").setPositiveButton("是", new DialogInterface.OnClickListener() {                    public void onClick(DialogInterface dialog, int which) {                        //删除数据                        helpter.del((int)temp);                        //重新查询数据                        Cursor c = helpter.query();                        String[] from = {"_id", "name", "singer"};                        int[] to = {R.id.text0, R.id.text1, R.id.text2};                        SimpleCursorAdapter adapter = new SimpleCursorAdapter(getApplicationContext(), R.layout.activity_query, c, from, to);   //为列表视图添加适配器                        listView.setAdapter(adapter);                    }                }).setNegativeButton("否", null);                AlertDialog ad = builder.create();                ad.show();            }        });        helpter.close();    }}

  上述代码中调用DBHelper的query()方法查询数据库并返回一个Cursor游标,然后使用SimpleCursorAdapter适配器将数据绑定到ListView控件上,并在ListView控件上注册单击监听器,当单击一条记录时,显示一个警告对话框提示是否删除,单击“是”,则调用DBHelper的del()方法删除指定记录。
QueryActivity布局文件内容如下:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent">    <TextView        android:id="@+id/text0"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:textSize="25px"/>    <TextView        android:id="@+id/text1"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:textSize="25px"/>    <TextView        android:id="@+id/text2"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:textSize="25px"/>LinearLayout>

运行程序,添加音乐信息:

在音乐列表中单击一条记录,弹出警告对话框删除一条记录:

更多相关文章

  1. “罗永浩抖音首秀”销售数据的可视化大屏是怎么做出来的呢?
  2. Nginx系列教程(三)| 一文带你读懂Nginx的负载均衡
  3. 不吹不黑!GitHub 上帮助人们学习编码的 12 个资源,错过血亏...
  4. Android获得火车时刻表Web Services的全部始发站名称
  5. android关于获取摄像头帧数据转成图片
  6. Android数据存储(3)SQLite简介和简单的登录与注册源代码
  7. android 第一行代码(第二版)Litepal遇到的问题
  8. Android(安卓)GET,POST向服务器端发送数据(发送)
  9. android 为 ListView Item中的组件添加事件 以及更新数据

随机推荐

  1. TCPIP卷一(9):EIGRP的数据包格式、TLV、 三
  2. 容器?
  3. TCPIP卷一(7):Routing Information Protocol
  4. 9月的风,我们重新认识一下
  5. 如何做好一件事
  6. TCPIP卷一(10):EIGRP的DUAL算法和SIA解决方
  7. TCPIP卷一(2):二层封装之–PPP与FR
  8. TCPIP卷一(6):距离矢量与链路状态 路由选择
  9. docker进程分析
  10. 同城异地灾备