特点:
- 轻量级
- 独立
- 隔离
- 跨平台
- 多语言接口
- 安全性
SQLite数据类型
一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。
SQLite具有以下五种常用的数据类型:
NULL: 这个值为空值
VARCHAR(n):长度不固定且其最大长度为 n 的字串,n不能超过 4000。
CHAR(n):长度固定为n的字串,n不能超过 254。
INTEGER: 值被标识为整数,依据值的大小可以依次被存储为1,2,3,4,5,6,7,8.
REAL: 所有值都是浮动的数值,被存储为8字节的IEEE浮动标记序号.
TEXT: 值为文本字符串,使用数据库编码存储(TUTF-8, UTF-16BE or UTF-16-LE).
BLOB: 值是BLOB数据块,以输入的数据格式进行存储。如何输入就如何存储,不改 变格式。
DATA :包含了 年份、月份、日期。
TIME: 包含了 小时、分钟、秒。
创建组合主键:
事例
-
创建SQLiteOpenHelper的类
public class DatabaseHelper extends SQLiteOpenHelper { public static final String TABLENAME_USER = "User"; public static final String USER_NAME = "userName"; public static final String AGE = "age"; public DatabaseHelper(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) { super(context, name, factory, version); } @Override public void onCreate(SQLiteDatabase db) { db.execSQL(" create table " + TABLENAME_USER + " ( " + USER_NAME + " varchar(20) not null, " + AGE + " number(9) not null )"); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { } }
创建db数据库
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_database_buton);
Button btnAdd = (Button) findViewById(R.id.btnAdd);
Button btnDelete = (Button) findViewById(R.id.btnDelete);
btnAdd.setOnClickListener(this);
btnDelete.setOnClickListener(this);
//创建名为“test.db”的数据库
DatabaseHelper databaseHelper = new DatabaseHelper(this, "test.db", null, 1);
mSqLiteDatabase = databaseHelper.getReadableDatabase();
Log.i("mmmmm", mSqLiteDatabase.getPath());
}增删改查:
@Override
public void onClick(View v) {
switch (v.getId()){
case R.id.btnAdd:
ContentValues contentValues = new ContentValues();
contentValues.put(DatabaseHelper.USER_NAME, "lin");
contentValues.put(DatabaseHelper.PASS_WORD, "1234567890");
Long isSussce = mSqLiteDatabase.insert(DatabaseHelper.TABLENAME_USER, null, contentValues);
if (isSussce != -1){
Toast.makeText(this, "插入数据成功", Toast.LENGTH_LONG).show();
}
break;
case R.id.btnSelect:
//query 查询
Cursor cursor = mSqLiteDatabase.query(DatabaseHelper.TABLENAME_USER, null, null, null, null, null, null);
if (cursor.moveToFirst()) {
int count = cursor.getCount();
for (int i = 0; i < count; i++) {
String str1 = cursor.getString(cursor.getColumnIndexOrThrow(DatabaseHelper.USER_NAME));
int age = cursor.getInt(cursor.getColumnIndexOrThrow(DatabaseHelper.AGE));
Log.i("ddddd", "i:" + i);
Log.i("ddddd", "name:" + str1 + " || " + age);
cursor.moveToNext(); //下一条
}
Log.i("ddddd", "--------------------");
}
cursor.close();
break;
case R.id.btnDelete:
//删除
String whereClause = DatabaseHelper.USER_NAME + " = ?";
String[] whereArgs = {"lin"};
mSqLiteDatabase.delete(DatabaseHelper.TABLENAME_USER, whereClause, whereArgs);
break;
case R.id.btnUpdate:
//修改
ContentValues contentValues_update = new ContentValues();
contentValues_update.put(DatabaseHelper.AGE, 25);
String whereClause_update = DatabaseHelper.AGE + " = ?";
String[] whereArgs_update = {"1234567890"};
mSqLiteDatabase.update(DatabaseHelper.TABLENAME_USER, contentValues_update, whereClause_update, whereArgs_update);
break;
}
}
优化
- 数据库的执行属于IO操作,而IO操作会损耗性能,有可能导致程序卡顿,所以一般建议执行数据库操作时用线程操作;
- 原始SQL语句执行效率更高,例如rawQuery、execSQL
- 只检索有用的列、有用的行、越少越好
- 排序会影响查找速度(一般数据量比较大的时候)
- 创建索引(数据量大的时候加索引会更快)
- 事务
//开始事务
mSqLiteDatabase.beginTransaction();
try {
for (int i = 0; i < 1000; i++) {
mSqLiteDatabase.execSQL("insert into User (userName, age) values ('zhangsan', 10)");
}
//事务完成
mSqLiteDatabase.setTransactionSuccessful();
} catch (Exception e) {
e.fillInStackTrace();
}
finally {
//结束事务
mSqLiteDatabase.endTransaction();
} - 对象关系映射ORM
推荐下面的链接,写得不错
http://blog.csdn.net/codeeer/article/details/30237597