Android数据储存之SQLiteDatabase SQLiteOpenHelper类的简单使用
2024-09-02 23:21:44
SQLiteOpenHelper 简介:
SQLiteOpenHelper是一个借口!所以不能直接实例化!那我们想要得到SQLiteOpenHelper对象就需要实现该接口!创建该接口的实现类对象!
该对象中有如下常用方法:
getReadableDatabase() 打开或创建数据库,返回一个SQLiteDatabase对象;
getWritableDatabase() 打开或创建数据库,返回一个SQLiteDatabase对象;
getReadableDatabase() 与 getWritableDatabase() 它的区别:
使用getReadableDatabase() 获取SQLiteDatabase对象时如果该数据库不可以写入时(如磁盘空间已满)getReadableDatabase()方法返回的SQLiteDatabase对象时只可以读取该数据库中的数据
而方法getReadableDatabase()则会出现异常
abstract void
onCreate(SQLiteDatabase db) |
该方法是第一次创建数据库的时候才会调用!如果程序中已经有该数据库,该方法则不会被再次调用!通常表的初始化会写在该方法中!
abstract void
onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) |
该方法是当数据库版本更新的时候会被调用!在创建数据库的时候我们会设置一个数据库的版本!如果该数据库的版本有改动则就会调用该方法!
synchronized void
close() |
该方法关闭数据库!
String | getDatabaseName() |
获取数据库名称!
自定义我们自己的SQLiteOpenHelper
public class MySqliteHelper extends SQLiteOpenHelper {
private static String My_sql;
private Context context;
public MySqliteHelper(Context context, String name, CursorFactory factory,
int version) {
super(context, name, null, version);
this.context = context;
} @Override
public void onCreate(SQLiteDatabase db) {
My_sql = "CREATE TABLE MYTABLE (_ID INTEGER PRIMARY KEY,_NAME,_AGE,_ADDRESS)";
db.execSQL(My_sql);
} @Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
Toast.makeText(context, "旧版本:"+oldVersion+",新版本"+newVersion, 0).show();
} }
使用MySqliteHelper 操作数据库:
public class MainActivity extends Activity implements OnClickListener{
private Button btnQuery,btnUpdate,btnAdd,btnDelete;
private MySqliteHelper mySqliteHelper;
private int version = 2;
private SQLiteDatabase database;
private ContentValues contentValues;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
setEvent();
} private void setEvent() {
btnQuery.setOnClickListener(this);
btnUpdate.setOnClickListener(this);
btnAdd.setOnClickListener(this);
btnDelete.setOnClickListener(this);
} private void initView() {
btnAdd = (Button) this.findViewById(R.id.id_databaseButtonAdd);
btnDelete = (Button) this.findViewById(R.id.id_databaseButtonDelete);
btnQuery = (Button) this.findViewById(R.id.id_databaseButtonQuery);
btnUpdate = (Button) this.findViewById(R.id.id_databaseButtonUpdate);
mySqliteHelper = new MySqliteHelper(this, "MySqlite.db", null, version);//创建数据库
database = mySqliteHelper.getReadableDatabase();//打开数据库返回SQLiteDatabase对象
contentValues = new ContentValues();
} @Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.id_databaseButtonAdd:
contentValues.clear();
contentValues.put("_NAME","QQ");
contentValues.put("_AGE","15");
contentValues.put("_ADDRESS","NO");
database.insert("MYTABLE", null, contentValues);
break;
case R.id.id_databaseButtonQuery:
Cursor cursor = database.query("MYTABLE", null, null, null, null, null, null);
while (cursor.moveToNext()) {
String name =cursor.getString(cursor.getColumnIndex("_NAME"));
String id =cursor.getString(cursor.getColumnIndex("_ID"));
String age =cursor.getString(cursor.getColumnIndex("_AGE"));
String address =cursor.getString(cursor.getColumnIndex("_ADDRESS"));
Toast.makeText(this,id+"|"+name+"|"+age+"|"+address, 0).show();
}
break;
case R.id.id_databaseButtonDelete:
//与上一篇同样的操作
break;
case R.id.id_databaseButtonUpdate:
//与上一篇同样的操作
break; default:
break;
}
} }
XML文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" > <Button
android:id="@+id/id_databaseButtonAdd"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="添加数据" /> <Button
android:id="@+id/id_databaseButtonUpdate"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="修改数据" /> <Button
android:id="@+id/id_databaseButtonDelete"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="删除数据" /> <Button
android:id="@+id/id_databaseButtonQuery"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="查询数据" />
</LinearLayout>
最新文章
- 【转】Oracle执行计划解释
- 相机位姿估计1_1:OpenCV:solvePnP二次封装与性能测试
- C# winform 模拟键盘鼠标操作
- Mysql跨表更新 多表update sql语句总结
- 使用ClipboardUtils兼容API LEVEL 11以下实现复杂粘贴
- Android开发笔记:打包数据库
- cocos2d-x知识巩固-基础篇(2)
- F题 - A+B for Input-Output Practice (V)
- 迁移到MSYS2 与 Qt 工具链注意的几个事情(注意链接顺序,并且人造mingw工具链所没有的局部midl.exe命令)
- pe and elf
- swift 之 函数
- BZOJ 3786: 星系探索 [伪ETT]
- Python内置函数(21)——tuple
- 可能是最简单的把C++Lib包装成C#可用dll的方法
- linux服务器ssh免密登录
- [BZOJ 4031][LOJ 2122][HEOI 2015] 小Z的房间
- unity动态加载(翻译) .
- 对Java中的异常的理解
- Bootstrap01
- 使用Idea搭建Spring Boot环境
热门文章
- 【server 安全】更改本地安全策略及禁用部分服务以进一步增强windows server的安全性
- 免费的freedns实现动态域名和url转发
- String basePath = request.getScheme()+";://";+request.getServerName()+";:";+request.getSer
- 【转】操作系统Unix、Windows、Mac OS、Linux的故事
- .net网站的下载地址
- python_14_sys_mod
- PAT (Advanced Level) Practise - 1094. The Largest Generation (25)
- HP刀片服务器安装系统步骤
- WPF中对XML的读写
- 2017年9月22日作业 c++算术运算符 自增 自减 逻辑运算符 位运算符 条件运算符(三元运算符)