美文网首页
第六周随笔--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