美文网首页
第六周随笔--SQLite

第六周随笔--SQLite

作者: 關kwan | 来源:发表于2016-06-19 23:55 被阅读0次
特点:
  • 轻量级
  • 独立
  • 隔离
  • 跨平台
  • 多语言接口
  • 安全性
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

相关文章

网友评论

      本文标题:第六周随笔--SQLite

      本文链接:https://www.haomeiwen.com/subject/tluddttx.html