记录一下Android数据库的增删查改的简单使用

话不多说,先献上你们最爱的效果图~
这边我用的是一个ListView来展示数据库里的数据

准备工作:
先写一个类继承SQLiteOpenHelper,因为SQLiteOpenHelper.java是一个Android提供的抽象类,我们要使用就写一个类继承它~
OpenHelper.java
public class OpenHelper extends SQLiteOpenHelper {    public OpenHelper(Context context) {        super(context,"sq.db",null,1);    }    @Override    public void onCreate(SQLiteDatabase db) {        //拓展:主键标识  primary key autoincrement        String sql="create table "+"tbname"+"(id text,name text,age text )";        db.execSQL(sql);    }    @Override    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {    }}
然后在Activity中实例化一下OpenHelper和SQLiteDatabase
OpenHelper openHelper= new OpenHelper(SQActivity.this);SQLiteDatabase db = openHelper.getWritableDatabase();

这样子可以说准备工作就做完了,可以开始功能的实现了。

功能实现:增

首先实例化一下ContentValues,然后用put的方式以key-value(键对值)的形式传入数据,最后SQLiteDatabase的insert方法插入数据库。

private void setSQ(String id, String name, String age) {    //增        ContentValues cv=new ContentValues();        cv.put("id", id);        cv.put("name", name);        cv.put("age", age);        //分别插入id name age三个数据,然后调用insert方法进行插入        db.insert("tbname", null, cv);    }
功能实现:删

删除就一行代码~SQLiteDatabase的delete的方法实现,这里只演示根据id来删除对应的数据。

private void getDel(String str_del) {  //删        //这里仅演示根据ID删除某条数据        db.delete("tbname", "id=?", new String[]{str_del});    }
功能实现:查

首先创建一个Cursor 游标,然后遍历所有数据,这里由于我是用的ListView来展示数据,所以在while循环里面直接把数据传入到List中,cursor.getString(0)这个就是获取你每条数据的第一个数据的意思,也就是我传入的id。

 private void getSQ() {    //查        //创建游标 cursor 并用游标遍历所有数据       Cursor cursor = db.query("tbname", null, null, null, null, null, null);        while (cursor.moveToNext()) {            bean = new SQBean(cursor.getString(0), cursor.getString(1), cursor.getString(2));            list.add(bean);        }        cursor.close();//关闭游标(cursor)释放资源    }
功能实现:改

更改数据库中的内容的话,你需要再实例化一个ContentValues,然后添加一个数据到里面,最后利用SQLiteDatabase的update方法实现新旧数据的更新。(我这里是对name来进行更新)

 private void getUpData() {//改        ContentValues cv_Updata=new ContentValues();        cv_Updata.put("name",editUpdatastr.getText().toString());        db.update("tbname", cv_Updata, "name=?", new String[]{editUpdataid.getText().toString()});    }

如果还有什么不懂的可以下方评论区留言讨论!

最后贴上完整的代码:(ListView的Adapter和Bean就不贴了)

SQActivity.java

public class SQActivity extends AppCompatActivity implements View.OnClickListener {    private EditText e1;    private EditText e2;    private EditText e3;    private Button btn;    private ListView lv;    private EditText editDel;    private Button buttonDel;    private EditText editUpdataid;    private EditText editUpdatastr;    private Button buttonUpdata;    private Button buttonRead;    private OpenHelper openHelper;    private SQLiteDatabase db;    private SQBean bean;    private SQAdapter adapter;    private List<SQBean> list = new ArrayList<>();    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_sq);        initView();        openHelper= new OpenHelper(SQActivity.this);        db = openHelper.getWritableDatabase();        adapter = new SQAdapter(SQActivity.this, list);        lv.setAdapter(adapter);    }    private void setSQ(String id, String name, String age) {    //增        ContentValues cv=new ContentValues();        cv.put("id", id);        cv.put("name", name);        cv.put("age", age);        //分别插入id name age三歌数据,然后调用insert方法进行插入        db.insert("tbname", null, cv);    }    private void getDel(String str_del) {  //删        //这里仅演示根据ID删除某条数据        db.delete("tbname", "id=?", new String[]{str_del});    }    private void getSQ() {    //查        //创建游标 cursor 并用游标遍历所有数据       Cursor cursor = db.query("tbname", null, null, null, null, null, null);        while (cursor.moveToNext()) {            bean = new SQBean(cursor.getString(0), cursor.getString(1), cursor.getString(2));            list.add(bean);        }        cursor.close();//关闭游标(cursor)释放资源    }    private void getUpData() {//改        ContentValues cv_Updata=new ContentValues();        cv_Updata.put("name",editUpdatastr.getText().toString());        db.update("tbname", cv_Updata, "name=?", new String[]{editUpdataid.getText().toString()});    }    private void initView() {        e1 = (EditText) findViewById(R.id.e1);        e2 = (EditText) findViewById(R.id.e2);        e3 = (EditText) findViewById(R.id.e3);        btn = (Button) findViewById(R.id.btn);        lv = (ListView) findViewById(R.id.lv);        editDel = (EditText) findViewById(R.id.edit_del);        buttonDel = (Button) findViewById(R.id.button_del);        editUpdataid = (EditText) findViewById(R.id.edit_updataid);        editUpdatastr = (EditText) findViewById(R.id.edit_updatastr);        buttonUpdata = (Button) findViewById(R.id.button_updata);        buttonRead = (Button) findViewById(R.id.button_read);        btn.setOnClickListener(this);        buttonUpdata.setOnClickListener(this);        buttonRead.setOnClickListener(this);        buttonDel.setOnClickListener(this);    }    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.btn:                //增                setSQ(e1.getText().toString(), e2.getText().toString(), e3.getText().toString());                Toast.makeText(this, "插入数据成功", Toast.LENGTH_SHORT).show();                break;            case R.id.button_del:          //删                getDel(editDel.getText().toString());                Toast.makeText(this, "删除成功", Toast.LENGTH_SHORT).show();                break;            case R.id.button_read:        //查                list.clear();//先清空旧数据防止重叠                getSQ();                adapter.notifyDataSetChanged();//更新List列表                Toast.makeText(this, "查询成功", Toast.LENGTH_SHORT).show();                break;            case R.id.button_updata:     //改                getUpData();                Toast.makeText(this, "更改成功", Toast.LENGTH_SHORT).show();                break;        }    }}

activity_sq.xml

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:orientation="vertical"    android:layout_width="match_parent"    android:layout_height="match_parent">    <LinearLayout        android:gravity="center"        android:padding="10dp"        android:layout_width="match_parent"        android:layout_height="wrap_content">        <EditText            android:singleLine="true"            android:maxLines="1"            android:hint="id"            android:id="@+id/e1"            android:layout_weight="1"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />        <EditText            android:singleLine="true"            android:maxLines="1"            android:hint="name"            android:layout_marginLeft="10dp"            android:id="@+id/e2"            android:layout_weight="1"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />        <EditText            android:singleLine="true"            android:maxLines="1"            android:hint="age"            android:layout_marginLeft="10dp"            android:id="@+id/e3"            android:layout_weight="1"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />        <Button            android:layout_weight="1"            android:text="插入"            android:id="@+id/btn"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />    </LinearLayout>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content">        <EditText            android:gravity="center"            android:hint="id"            android:id="@+id/edit_del"            android:layout_weight="1"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />        <Button            android:text="删除"            android:id="@+id/button_del"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />    </LinearLayout>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="wrap_content">        <EditText            android:gravity="center"            android:hint="old"            android:id="@+id/edit_updataid"            android:layout_weight="1"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />        <EditText            android:gravity="center"            android:hint="new"            android:id="@+id/edit_updatastr"            android:layout_weight="1"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />        <Button            android:text="改"            android:id="@+id/button_updata"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />    </LinearLayout>    <Button        android:text="查询数据库"        android:id="@+id/button_read"        android:layout_width="match_parent"        android:layout_height="wrap_content" />    <ListView        android:id="@+id/lv"        android:layout_width="match_parent"        android:layout_height="match_parent">    </ListView></LinearLayout>

更多相关文章

  1. SpringBoot 2.0 中 HikariCP 数据库连接池原理解析
  2. 一句话锁定MySQL数据占用元凶
  3. ListView的Adapter使用(绑定数据) 之 自定义每一项的布局去绑定
  4. Android(安卓)SQLite数据库使用INTO子句创建新表时报错
  5. Android请求服务器的两种方式--post, get的区别
  6. Android使用JSONObject和GSON方法解析JSON格式数据
  7. Android数据库ContentProvider封装原理
  8. 详解 Android(安卓)的 Activity 组件——笔记
  9. Android(安卓)ListView和ListAdapter

随机推荐

  1. iPod Touch也将支持运行Android系统
  2. 设计模式~单例-[Android_YangKe]
  3. Android(安卓)传感器开发 完全解析
  4. 【Android】程序设计 ——记账App项目and
  5. Google Developing for Android(安卓)一
  6. Android(安卓)Drawable及其相关类的使用
  7. Android闹钟 AlarmManager的使用
  8. 【Andorid】短视频拍摄SDK——Vitamio Re
  9. 【Android】Dagger2 + MVVM
  10. 利用Eclipse打包混淆时报:Conversion to D