SQLite是Android自带的关系型数据库,是一个基于文件的轻量级数据库。Android提供了3种操作数据的方式,SharedPreference(共享首选项)、文件存储以及SQLite数据库。
SQLite数据库文件被保存在/data/data/package_name/databases目录下。
一、创建和删除表
1.创建表
创建表的SQL语句为:
CREATE TABLE userInfo_brief (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT,
password TEXT);
对应的Java代码为:
final static int VERSION=1;
final static String TABLENAME="userInfo_brief";
final static String ID="id";
final static String NAME="name";
final static String PASSWORD="password";
String sql="CREATE TABLE "+TABLENAME+"("+"ID"+" INTEGER PRIMARY KEY AUTOINCREMENT,"
+NAME+" TEXT,"// Attention:注意SQL语法,每个变量后需要有空格,否则不认识。
+PASSWORD+" TEXT,"
+AGE+" TEXT);";
db.execSQL(sql);
2.删除表
SQL语句为:
DROP TABLE userInfo_brief;
对应的java代码为:
String sql="DROP TABLE "+TABLENAME+";";
db.execSQL(sql);
二、操作数据库中的记录
1.插入记录
insert用法:
SQliteDatabase.insert(String table,String nullColumnHack,ContentValues values)
ContentValues values=new ContentValues();//获取ContentValues对象,类似HashMAP
values.put(DatabaseHelper.NAME, name);//键值对形式保存数据
values.put(DatabaseHelper.PASSWORD, pass);
values.put(DatabaseHelper.AGE, age);
db.insert(DatabaseHelper.TABLENAME, null, values);
2.更新记录
update使用方法:
SQliteDatabase.update(String table,ContentValues values,String where-Clause,String[] WhereArgs)
eg:更新表中name为bob的密码
ContentValues values=new ContentValues();
values.put(PASSWORD,"123456");//要更新的数据
db.update(TABLENAME,values,NAME+"=?",new String[]{"bob"});
3.删除记录
delete使用方法:
SQliteDatabase.delete(String table,String where-Clause,String[] WhereArgs)
eg:删除那么为bob的记录
db.delete(TABLENAME,NAME+"=?",new String[]{"bob"});
4.查询记录
1.单表查询
使用SQLiteDatabase.query(7个参数)。
2.多表查询
如果A表中存了用户名和密码,B表中存了用户名和其他具体信息,使用SQLiteQueryBuilder多表查询。
SQL语句:
SELECT A.name,A.password,B.age,B.sex FROM A,B WHERE A.name=B.name AND A.name=“bob”
多表查询步骤:
SQLiteQueryBuilder builder