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"));
}
原文地址:https://www.cnblogs.com/wdht/p/6123525.html