zoukankan      html  css  js  c++  java
  • Android之SQLite

    一、SQLite:

        1、SQLite特点:

                                  1、轻量级:使用 SQLite 只需要带一个动态库,就可以享受它的全部功能,而且那个动态库的尺寸想当小。

                  2、独立性:SQLite 数据库的核心引擎不需要依赖第三方软件,也不需要所谓的“安装”。
                       3、隔离性:SQLite 数据库中所有的信息(比如表、视图、触发器等)都包含在一个文件夹内,方便管理和维护。
                   4、跨平台:SQLite 目前支持大部分操作系统,不至电脑操作系统更在众多的手机系统也是能够运行,比如:Android。
                   5、多语言接口:SQLite 数据库支持多语言编程接口。
                   6、安全性:SQLite 数据库通过数据库级上的独占性和共享锁来实现独立事务处理。
               这意味着多个进程可以在同一时间从同一数据库读取数据,
    但只能有一个可以写入数据。

       2、创建数据库类:

    public class DatabaseHelper extends SQLiteOpenHelper {
     
        private static final String DB_NAME = "mydata.db"; //数据库名称
        private static final int version = 1; //数据库版本
         
        public DatabaseHelper(Context context) {
            super(context, DB_NAME, null, version);
            // TODO Auto-generated constructor stub
        }
     
        @Override
        public void onCreate(SQLiteDatabase db) {
            String sql = "create table user(username varchar(20) not null , password varchar(60) not null );";          
            db.execSQL(sql);
        }
     
        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            // TODO Auto-generated method stub
     
        }
     
    }

     3、SQLiteOpenHelper类:

                                    ① SQLiteOpenHelper是SQLiteDatabase的一个帮助类, 用来管理数据库的创建和版本的更新。一般是建立一个类继承它,并实现它的onCreate和onUpgrade方法。

                                ②onCreate(SQLiteDatabase db)创建数据库时调用

                                ③onUpgrade(SQLiteDatabase db,int oldVersion , int newVersion) 版本更新时调用

                                ④getReadableDatabase()创建或打开一个只读数据库

                                ⑤getWritableDatabase()创建或打开一个读写数据库

     4、创建数据库:

           这里特别的地方是通过调用了SQLiteOpenHelper类的getReadableDatabase()方法来实现创建一个数据库的

                                                       DatabaseHelper helper = new DatabaseHelper(this);

                                                       SQLiteDatabase db = helper.getReadalbeDatabase();

    5、SQLiteDatabase类:

         SQLiteDatabase类为我们提供了很多种方法,而较常用的方法如下:

                                         (int) delete(String table,String whereClause,String[] whereArgs)删除数据行的便捷方法

                                         (long) insert(String table,String nullColumnHack,ContentValues values)添加数据行的便捷方法

                                         (int) update(String table, ContentValues values, String whereClause, String[] whereArgs)更新数据行的便捷方法

                                         (void) execSQL(String sql)执行一个SQL语句,可以是一个select或其他的sql语句

                                         (void) close()关闭数据库

      (Cursor) query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit)查询指定的数据表返回一个带游标的数据集

                                       (Cursor) rawQuery(String sql, String[] selectionArgs)运行一个预置的SQL语句,返回带游标的数据集(与上面的语句最大的区别就是防止SQL注入)

    6、数据修改:

    数据修改
    ContentValues cv = new ContentValues();//实例化ContentValues
    cv.put("password","iHatePopMusic");//添加要更改的字段及内容
    String whereClause = "username=?";//修改条件
    String[] whereArgs = {"Jack Johnson"};//修改条件的参数
    db.update("user",cv,whereClause,whereArgs);//执行修改
    
    String sql = "update [user] set password = 'iHatePopMusic' where username='Jack Johnson'";//修改的SQL语句
    db.execSQL(sql);//执行修改

    7、数据查询(通过query实现查询的):

    public Cursor query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit)
    
    table:表名称 
    colums:列名称数组 
    selection:条件子句,相当于where 
    selectionArgs:条件语句的参数数组 
    groupBy:分组 
    having:分组条件 
    orderBy:排序类 
    limit:分页查询的限制 
    Cursor:返回值,相当于结果集ResultSet 

    8、游标(Cursor)属性:

    
    getCount()总记录条数
    isFirst()判断是否第一条记录
    isLast()判断是否最后一条记录
    moveToFirst()移动到第一条记录
    moveToLast()移动到最后一条记录
    move(int offset)移动[是指偏移量而不是指移到指定位置]
    moveToNext()移动到吓一条记录
    moveToPrevious()移动到上一条记录
    getColumnIndex(String columnName)获得指定列索引的int类型值

    9、游标(Cursor)使用:

    
    Cursor c = db.query("user",null,null,null,null,null,null);//查询并获得游标
    if(c.moveToFirst()){//判断游标是否为空
        for(int i=0;i<c.getCount();i++){
            c.moveToNext();
            String username = c.getString(c.getColumnIndex("username");
            String password = c.getString(c.getColumnIndex("password"));
        }

    10、rawQuery实现的带参数查询:

    Cursor c = db.rawQuery("select * from user where username=?",new Stirng[]{"Jack Johnson"});
    if(cursor.moveToFirst()) {
        String password = c.getString(c.getColumnIndex("password"));
    }
  • 相关阅读:
    filter的用法
    刚下载好的 vscode 不能运行,一片黑 以及终端不能输入 解决办法
    JS获取光标在input 或 texterea 中下标位置
    JS 数组去重
    字符串操作函数:JSON.parse()、JSON.stringify()、toString 的区别,字符串转数组 str.split(','),数组转字符串String(),以及对象拼接合并Object.assign(),数组拼接合并concat()
    创建标准化工程目录脚本
    configParse模块
    json与api- 天气api 博客词频分析
    文件读写
    os模块、文件压缩 、匹配文件后缀名:fnmatch glob
  • 原文地址:https://www.cnblogs.com/wdht/p/6123525.html
Copyright © 2011-2022 走看看