设为首页 收藏本站
查看: 802|回复: 0

[经验分享] Android学习笔记(四一):SQLite的使用

[复制链接]

尚未签到

发表于 2016-12-1 07:57:05 | 显示全部楼层 |阅读模式
SQLite是非常流行的嵌入式关系型数据库,轻载,速度快,而且是开源。在Android中,runtime提供SQLite,所以我们可以使用SQLite,而且是全集的SQLite。SQLite提供SQL接口,和一般的数据库一样。但是Android的API不采用JDBC,JDBC消耗太多的资源。

SQLite支持绝大部分SQL-92标准,不支持:FOREIGN KEY constraints, nested transactions, RIGHT OUTER JOIN, FULL OUTER JOIN, and some flavors of ALTER TABLE.而我们在手持终端上使用SQLite,一般并不涉及太复杂的数据库处理,除了上诉,其他的SQL,包括tirger、transaction等都是支持,应该说SQLite提供的功能是足够。
和一般的SQL数据库比较,最大的差异是数据类型,例如我们定义一个表的某个column的数据类型为INTEGET,如果在插入时这个数值采用String,在SQLite中是包会产生错误,我们可以将定义表格的数据类型作为一个提示,用于说明期待的数据类型,但是并不真实起到检测作用。如果真的需要限制,要以来程序的其他部分进行判断。
1、建立我们的数据库
在MySQL等数据库中,第一步是创建数据库,第二步是创建表,如需要,还加上我们的初始预制的数据。在Android的SQLite的使用是一样的。稍微特别一点是,我们需要通过继承SQLiteOpenHelper这个类来达到目的。对于抽象类SQLiteOpenHelper的继承,需要重写:1)constructor,2)onCreate()和onUpgrade(),下面举例介绍。
这个例子,我们创建一个称为bebook_db的数据库,里面有一个叫mytable的表格,有三列:_id,Name,Weight。下面我们将演示如何创建数据库,如何在数据库中创建表,如何删除表,如何更新数据库。
/* 对于抽象类SQLiteOpenHelper的继承,需要重写:1)constructor,2)onCreate()和onUpgrade() * */
public class Chapter22Db extends SQLiteOpenHelper{
public static final String DATABASE_BAME ="bebook_db";

/* step 1 :重写构造函数中,继承super的构造函数,创建database */
public Chapter22Db(Context context){
  /* 第一个参数 为当前环境
* 第二个参数 String name为数据库文件,如果数据存放在内存 ,则为null,
* 第三个参数 为SQLiteDatabase.CursorFactory factory,存放cursor,缺省设置为null
* 第四个参数 为int version数据库的版本,从1开始,如果版本旧,则通过onUpgrade()进行更新,如果版本新则通过onDowngrade()进行发布。例如,我要更改mytable表格,增加一列,或者修改初始化的数据,或者程序变得复杂,我需要增加一个表,这时我需要在版本的数字增加,在加载时,才会对SQLite中的数据库个更新,这点非常重要,同时参见onUpgrade()的说明 */

super(context,DATABASE_BAME,null,1);
}

/*step 2 :重写onCreate(),如果Android系统中第一次创建我们的数据库时(即后面介绍调用getWritableDatabase()或者getReadbleDatabase()时),将调用onCreate(),这这里创建数据库(虽然在构造函数中填入数据库名,但数据库的创建实在onCreate()中自动进行。在这里一般进行创建table和写入初始数据*/
public void onCreate(SQLiteDatabase db) {
  //创建table:SQL的语句是“CREATE TABLE constants(_id INTEGER PRIMARY KEY AUTOINCREMENT,title TEXT, value REAL);”,我们可以直接通过db.execSQL(SQLCommand)来执行没有返回值的SQL语言,例如CREATE,DELETE,UPDATE,INSERT,DROP。
db.execSQL("CREATE TABLE mytable(_id INTEGER PRIMARY KEY AUTOINCREMENT, Name TEXT,Weight REAL); ");

//下面是加入三个原始数据,如果对表格进行增、删、改、查,后面会详细介绍。下面的几个数据来自Android自带的重力表,据说是为了传感器管理用,Android已经考虑到我们在月球和火星上使用Android手机的情况^_^,程序员有时真的很无聊……
ContentValues cv = new ContentValues();

cv.put("Name", "Gravity, Earth");
cv.put("Weight", SensorManager.GRAVITY_EARTH);
db.insert("mytable", "Name", cv);

cv.put("Name", "Gravity, Mars");
cv.put("Weight", SensorManager.GRAVITY_MARS);
db.insert("mytable", "Name", cv);

cv.put("Name", "Gravity, Moon");
cv.put("Weight", SensorManager.GRAVITY_MOON);
db.insert("mytable", "Name", cv);
}

/* step 3:重写onUpgrade(),如果版本比原来的高,将调用onUpgrade(),在这个例子中,我们删除原来的表格,根据新需求创建*/
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//这次同样通过db.execSQL(SQLCommand)来执行没有返回值的SQL语言,将表格删除
db.execSQL("DROP TABLE IF EXISTS mytable");
onCreate(db);
}

}

2、和数据库进行关联
就如同在MYSQL中进行来数据库的创建,表格创建和初始数据的填写,其他的操作一般在Activity中和用户互动产生。回忆一下我们在Linux环境中如何处理,首先是要创建和数据库的连接,Android也一样,另外在Activity结束时,我们需要将连接断开,以释放有关资源。
public class Chapter22Test1 extends ListActivity{
private SQLiteDatabase db = null;
private Cursor cursor = null; //在后面与ListView互动中使用

protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
  // 获取处理SQLiteOpenHelper的子类的SQLite的实例,如果只读,可以采用getReadableDatabase(),这个例子我们奖通过SQLiteDatabase实例的操作,来进行对数据进行增删改查询,采用可写的方式。
db= (new Chapter22Db (getApplicationContext())).getWritableDatabase();
}

protected void onDestroy() {
  super.onDestroy();
//释放和数据库的连接
db.close();
}
}

3、对表格进行操作
对表格的操作有两种方式,一种是RAW方式,即直接给出SQL语句,另一种是采用SQLiteDatabase中给出的方法来进行,姑且称为API方式。下面就这两种方式的增、删、改、查进行实验。
3.1增加一行数据

在设置创建表格时,使用了db.execSQL(SQLCommand)来执行没有返回值的SQL语言,这个是RAW方式。另一种方式在之前加入原始数据时给出,通过db.insert("mytable","Name",<ContentValues values>);来实现。其中第二个参数比较特别。SQL是不运行加入一个空的行。如果第二个参数不设置为null,则对这种情空行情况进行处理,将对应列的值设置为“NULL”。
//RAW方式。
db.execSQL("INSERT INTO mytable(Name,Weight) VALUES ('Test1',1.0);");
//API方式,通过db.insert("mytable","Name",<ContentValues values>);来处理,其中ContentValues是用于存储名称和数值,对应为表格的列的名词和其在行中的数据。
ContentValues values =new ContentValues(2);//ContentValues有两个数值
values.put("Name", "Test2"); //一个列名为Name,数据为Test2
values.put("Weight", 2.0); //一个列名为Weight,数据为2.0
db.insert("mytable","Name",values);

3.2删除一行数据

//RAW方式
db.execSQL("DELETE FROM mytable WHERE Name='Test1';");
//API方式,方法是:delete (String table, String whereClause, String[] whereArgs)
db.delete("mytable", "Name=?", {"Test1"});

3.3更新一行数据

//RAW方式
db.execSQL("UPDATE mytable SET Weight=5.0 WHERE Name='Test1';");
//API方式,方法是:update (String table, ContentValuesvalues, StringwhereClause, String[]whereArgs)
String[] name = {"Test1"};
ContentValues values =new ContentValues(2);

values.put("Name", "Test1");
values.put("Weight", 5.0);

db.update("mytable",values,"Name=?",name);

3.4查询和游标Cursor
上面的三个操作都是无返回值的,而查询SELECT则不然,将返回游标Cursor。下面是两种方式的查询
//RAW方式,带返回值,采用db.rawQuery(SQL语句)方式
Cursor result1 =db.rawQuery("SELECT _id,Name,Weight from mytable ORDER BY Name", null);

/API方式,带返回值,采用public Cursor query (String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy)
String[] columns ={"Name","Weight"};
String[] name ={"Name"};

Cursor result2 = db.query("mytable", columns, "Name=?", name, null, null, null);

游标和Iterator接口有些相似,对于Cursor result我们可以通过下面的方式来读取数据:
result.moveToFirst();
while(!result.isAfterLast()){
int id = result.getInt(0);
String name = result.getString(1);
double weight = result.getDouble(2);
System.out.println("\t "+id + "\t["+ name + "]\t" +weight);
result.moveToNext();
}  
result.close();

通过Cursor我们可以读取数据库的详细信息,结合到Android学习笔记(二十):回归简单的ListView,我们可以数据用ArrayList<HashMap<>>来存放,由于real非对象,简单地用ArrayList<HashMap<String,String>>来存储。我们已经有能力对SQLite数据进行处理,并也有能力处理ListView,这样可以编写我们的Activity。
然而Cursor中其实已存有信息,我们也可以使用CursorAdapter来处理,在下一次我们将在这个例子的基础上,经CursorAdapter和ListView结合给出例子。
“现在郭德纲在网上闹那么多事情,在道德在伦理上,出现这么多问题,我搞不懂为什么那么多人喜欢他?”9月28日下午,姜昆在广州讲演,两个小时的时间内,他说学逗唱,紧紧地把观众的耳朵拽到自己嘴边上。他还特别对郭德纲相声的流行表示了强烈质疑。见http://ent.qq.com/a/20111002/000037.htm。这怎么说呢,这是中国式的恶毒和无耻的戏子的言语。1、无法在艺术上对人进行指责,就在道德上,甚至拔高到伦理上,骂人;2、并无法在道德上,指出例证,反正直接一个帽子盖过来,这种思维和做事方式,至今依然流毒,令人恐惧和不安。比泼妇有教养,比泼妇更小人和恶毒,用泼妇与之相比,是侮辱了泼妇。

相关链接:我的Andriod开发相关文章

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-307854-1-1.html 上篇帖子: SQlite数据库的C编程接口(四) 绑定参数(Bound Parameters) ——《Using SQlite》读书笔记 下篇帖子: Android+Jquery Mobile学习系列(5)-SQLite数据库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表