本文主要介绍SQLite初步使用步骤、方法(参考郭霖《第二行代码》):
一、SQLiteOpenHelper相关操作
SQLite的使用主要借助SQLiteOpenHelper帮助类,通过调用它的getReadableDatabase()以及getWritableDataBase() 方法可以获得一个数据库对象。SQLiteOpenHelper是一个抽象类,需要对其进行重写。
需要对其进行重写的有它的构造方法,onCreate()方法,以及onUpgrade()方法。
如果数据库文件不存在,在获取数据库对象时会执行onCreate()方法,如果数据库文件已经存在,在构造方法中传入高版本号后会调用onUpgrade()方法。
public class MyDatabaseHelper extends SQLiteOpenHelper {
public static final String CREATE_BOOK="create table Book(id integer primary key autoincrement,author text," +
"price real,pages integer,name text)";
public static final String CREATE_CATEGORY="create table Category(id integer primary key autoincrement, category_name text," +
"category_code integer)";
private Context mContext;
public MyDatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
mContext=context;
}
@Override
public void onCreate(SQLiteDatabase db) {
db.execSQL(CREATE_BOOK);
db.execSQL(CREATE_CATEGORY);
}
//构造方法中传入新版本号时会调用
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
db.execSQL("drop table if exists Book");
db.execSQL("drop table if exists Category");
onCreate(db);
}
}
//最后一个参数是版本号,如果比之前版本号大则执行onUpgrade()
databaseHelper=new MyDatabaseHelper(this,"BookStore.db",null,1);
二、对数据库进行操作
在有了自己的SQLiteOpenHelper之后,就能根据它来获得SQLiteDatabase的对象,进而对数据库进行操作“增删改查”。除了下面的操作,还可以直接执行sql语句来对数据库进行操作。
public class MainActivity extends AppCompatActivity {
private MyDatabaseHelper databaseHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
databaseHelper=new MyDatabaseHelper(this,"BookStore.db",null,1);
}
//向数据库添加数据
private void addData(){
SQLiteDatabase db=databaseHelper.getWritableDatabase();
ContentValues values=new ContentValues();
values.put("name","Vinci");
values.put("author","Dan Brown");
values.put("pages",454);
values.put("price",16.96);
db.insert("Book",null,values);
values.clear();
values.put("name","Vinci");
values.put("author","Dan Brown");
values.put("pages",510);
values.put("price",15.96);
db.insert("Book",null,values);
}
//更新数据
private void updateData(){
SQLiteDatabase db=databaseHelper.getWritableDatabase();
ContentValues values=new ContentValues();
values.put("price",10.99);
db.update("Book",values,"name=?",new String[]{"The Da Vinci Code"});
}
//删除数据
private void delData(){
SQLiteDatabase db=databaseHelper.getWritableDatabase();
db.delete("Book","page>?",new String[]{"500"});
}
//查找数据
private void searchData(){
SQLiteDatabase db=databaseHelper.getWritableDatabase();
Cursor cursor=db.query("Book",null,null,null,null,null,null);
if(cursor.moveToFirst()){
do{
String name=cursor.getString(cursor.getColumnIndex("name"));
String author=cursor.getString(cursor.getColumnIndex("author"));
int pages=cursor.getInt(cursor.getColumnIndex("pages"));
double price=cursor.getDouble(cursor.getColumnIndex("price"));
}while(cursor.moveToNext());
}
cursor.close();
}
//也可以直接使用db.execSQL("");来操作数据库
}