首先创建数据库类

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    }}

SQLiteOpenHelper类介绍

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

方法名 方法描述
SQLiteOpenHelper(Context context,String name,SQLiteDatabase.CursorFactory factory,int version) 构造方法,一般是传递一个要创建的数据库名称那么参数
onCreate(SQLiteDatabase db) 创建数据库时调用
onUpgrade(SQLiteDatabase db,int oldVersion , int newVersion) 版本更新时调用
getReadableDatabase() 创建或打开一个只读数据库
getWritableDatabase()() 创建或打开一个读写数据库

下面来介绍调用的方法

  1. 创建数据库
    这里特别的地方是通过调用了SQLiteOpenHelper类的getReadableDatabase()方法来实现创建一个数据库的
DatabaseHelper database = new DatabaseHelper(this);//这段代码放到Activity类中才用thisSQLiteDatabase db = null;db = database.getReadalbeDatabase();
(返回值)方法名 方法描述
(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注入)

2. 数据的添加
使用insert方法

ContentValues cv = new ContentValues();//实例化一个ContentValues用来装载待插入的数据cv.put("username","Jack Johnson");//添加用户名cv.put("password","iLovePopMusic"); //添加密码db.insert("user",null,cv);//执行插入操作
使用execSQL方式来实现
String sql = "insert into user(username,password) values ('Jack Johnson','iLovePopMuisc');//插入操作的SQL语句db.execSQL(sql);//执行SQL语句String s="INSERT INTO ID_LIST VALUES (NULL,?,?,?,?,?)"; db.execSQL(s, new Object[]{id, townEng, townChin, area, provice});//执行SQL语句
  1. 数据的删除
    同样有2种方式可以实现
String whereClause = "username=?";//删除的条件String[] whereArgs = {"Jack Johnson"};//删除的条件参数db.delete("user",whereClause,whereArgs);//执行删除

使用execSQL方式的实现

String sql = "delete from user where username='Jack Johnson'";//删除操作的SQL语句 db.execSQL(sql);//执行删除操作
  1. 数据修改
    同上,仍是2种方式
ContentValues cv = new ContentValues();//实例化ContentValuescv.put("password","iHatePopMusic");//添加要更改的字段及内容String whereClause = "username=?";//修改条件String[] whereArgs = {"Jack Johnson"};//修改条件的参数db.update("user",cv,whereClause,whereArgs);//执行修改

使用execSQL方式的实现

String sql = "update [user] set password = 'iHatePopMusic' where username='Jack Johnson'";//修改的SQL语句 db.execSQL(sql);//执行修改
  1. 数据查询
    数据查询相对前面几种方法就复杂一些了,因为查询会带有很多条件

通过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
    针对游标(Cursor)也提供了不少方法
方法名称 方法描述
getCount() 总记录条数
isFirst() 判断是否第一条记录
isLast() 判断是否最后一条记录
moveToFirst() 移动到第一条记录
moveToLast() 移动到最后一条记录
move(int offset) 移动到指定的记录
moveToNext() 移动到下一条记录
moveToPrevious() 移动到上一条记录
getColumnIndex(String columnName) 获得指定列索引的int类型值

实现代码

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

通过rawQuery实现的带参数查询

Cursor c = db.rawQuery("select * from user where username=?",new Stirng[]{"Jack Johnson"});if(cursor.moveToFirst()) {    String password = c.getString(c.getColumnIndex("password"));}

转载自

ANDROID开发之SQLite详解

更多相关文章

  1. 关于Android中的SQLite使用
  2. Android(安卓)Google地图那些事
  3. Android创建快捷方式图标
  4. 手动修改Android数据库数据
  5. Android批量插入数据
  6. Android(安卓)中使用 ComponentName 类
  7. [Android设计模式]Android退出应用程序终极方法
  8. 浅谈Java中Collections.sort对List排序的两种方法
  9. Python list sort方法的具体使用

随机推荐

  1. android 按钮倒计时读秒
  2. 软键盘默认不弹出,点击别的控件让EditText
  3. Android(安卓)SQLite数据库升级的问题
  4. Android: Android(安卓)Bluetooth
  5. android Linkify的用法
  6. Android(安卓)网络请求加密
  7. Android下USB Accessory的实现分析 (四)---
  8. android服务和进程详解
  9. Android一键锁屏代码
  10. Android(安卓)使用jdk1.8新特性之lambda