一、添加数据
- SQLiteDatabase中提供了insert方法,内含有三个参数,一个是表名,第二个是在未指定添加数据的情况下给某些可为空的列自动赋值NULL,第三个参数是一个CotentValues对象,它提供了一系列put方法重载,用于向ContentValues中添加数据。
- 修改activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
..............省略部分重复的代码............
<Button
android:id="@+id/add_data"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Add data"/>
</LinearLayout>
- 我们添加了一个按钮,然后为这个按钮绑定事件,修改MainActivity.java
..........省略上面的代码...........
Button addData = (Button)findViewById(R.id.add_data);
addData.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
//开始组装第一条数据
values.put("name", "The Da Vinci Code");
values.put("author", "Dan Brown");
values.put("pages", 454);
values.put("price", 16.96);
db.insert("Book",null,values);//插入第一条数据
values.clear();
//开始组装第二条数据
values.put("name", "The Lost Symbol");
values.put("author", "Dan Brown");
values.put("pages", 510);
values.put("price", 19.95);
db.insert("Book", null, values);//插入第二条数据
}
});
- 我们生成这个app,进行点击“Add data"按钮,然后利用dos窗口工具查看数据库内含有的Book表
二、更新数据
- SQLiteDatabase中提供了update方法,内含有四个参数,一个是表名,第二个参数是一个CotentValues对象,它提供了一系列put方法重载,用于向ContentValues中添加数据。第三个或者第四个参数用于去约束更新某一行或者几行的数据。不指定的话就会默认更新所有行。
- 修改activity_main.xml
<Button
android:id="@+id/update_data"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Update data"
/>
- 在添加一个按钮,然后来绑定点击事件
Button updateData = (Button)findViewById(R.id.update_data);
updateData.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("price", 10.99);
db.update("Book",values,"name=?",new String[] {
"The Da Vinci Code"
});
}
});
- 可以看到其实三四个参数类似于SQL语句的where部分和PreparedStatement用法有异曲同工之妙。
三、删除数据
- SQLiteDatabase中提供了delete方法,内含有三个参数,一个是表名,第二个和第三个参数用于去约束删除某一行或者几行的数据。不指定的话就会默认删除所有行。
- 修改activity_main.xml
<Button
android:id="@+id/delete_data"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Delete data"
/>
Button deleteButton = (Button)findViewById(R.id.delete_data);
deleteButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
SQLiteDatabase db = dbHelper.getWritableDatabase();
db.delete("Book", "pages > ?", new String[] {
"500"
});
}
});
四、源码:
- DatabaseTest
- 地址:https://github.com/ruigege66/Android/tree/master/DatabaseTest
- CSDN:https://blog.csdn.net/weixin_44630050
- 博客园:https://www.cnblogs.com/ruigege0000/
- 欢迎关注微信公众号:傅里叶变换,个人账号,仅用于技术交流