第六周随笔--SQLite

特点:
  • 轻量级
  • 独立
  • 隔离
  • 跨平台
  • 多语言接口
  • 安全性
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: 包含了 小时、分钟、秒。

创建组合主键:

创建组合主键

事例
  1. 创建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) {    
       }
    }
    
  2. 创建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());
    }

  3. 增删改查:
    @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

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容