/*

大家都知道写博客会很累的,大热天的。

希望=转载请注明出处:http://blog.csdn.net/ta893115871

请不要可怜你的鼠标,(*^__^*) 嘻嘻……

*/

众所周知,数据库是很重要的。市面上的大大小小的软件差不多都要用到数据库。

在Android中数据库为SQlite,因为小巧便捷,占用的空间少,易于操作。使用很受欢迎。

数据库不外乎查询(query)新增(insert)修改(update)删除(delete)。

本例子

1.使用Menu按键来做数据库的查询(query)新增(insert)修改(update)删除(delete)。

2.搭配ListView Widget来触发单击事件和鼠标滚轮事件。

下面就看一下数据库。

首先建一个辅助类MyDataBase继承SQLiteOpenHelpe,必须实现它的onCreate()和 onUpdate()方法;

数据库创建时,会调用onCreate()方法,所以可将要添加的表(table)写在里面。

创建的方法如下所示:

@Overridepublic void onCreate(SQLiteDatabase db) {// TODO Auto-generated method stub/* 建立表table */Log.i(TAG, " onCreate() ");String sql = "CREATE TABLE " + TABLE_NAME + " (" + FIELD_id+ " INTEGER PRIMARY KEY AUTOINCREMENT," + " " + FIELD_TEXT+ " TEXT)";db.execSQL(sql);}

当更新数据库时会调用onUpdate()方法。

所以要将更新table的SQL写在里面。

//更新数据库@Overridepublic void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {// TODO Auto-generated method stubLog.i(TAG, " onUpgrade() ");//删除表的SQLString sql = "DROP TABLE IF EXITS " + TABLE_NAME;db.execSQL(sql);onCreate(db);}

2.得到SQLiteDatabasedb对象,

通过db=MyOpenHelper.getReadableDatabase();//得到只读的数据存储对象,如果数据库不存在择创建一个数据库

db= MyOpenHelper.getWritableDatabase();//得到可读可写的数据哭对象。

如果数据库不存在择创建一个数据库

数据库的文件会自行产生在/data/data/package名称/database下在Eclipse来查询数据库是否创建成功。

根据自己的需要选择不同的方法;

到此我们的数据库就创建成功了。

(一)查询:

Cursor  cursor=db.query(table,columns,selection,selectionArgs,groupBy,having,orderBy);

返回的是一个游标对象。

游标的作用是指项数据库的表的行我们可以通过 cursor.moveToNext();或者

Cursor.moveToPosition();来控制游标的位置;

字段虽然比较多,但了解数据库的人应该很清楚,

第一个参数是表名table_name

第二个参数是要查询的字段

第三个参数是查询的条件

这里说一下这个查询条件

查询所有的数据:

//asc是升序,desc是降序,默认为asc

mSQLiteDatabase.query(TABLENAME,new String[] {ID,stuName,stuNumber,stuScore },null,null,null,null,ID+" asc");

查询有条件的数据:

Cursor cursor = db.query(TABLENAME,new String[] {ID, stuName, stuNumber,stuScore }," stuName =?",

new String[] {“zhnagsan”},null,null,null)

这样写的话第四个参数就是第三个参数?的替代值。

//Returns A Cursor object, whichis positioned before the first entry

Cursorcur= mSQLiteDatabase.query(TABLENAMEnew String[] {ID,stuName,stuNumber,stuScore }, stuNumber+"="+number,null,null,null,null);

也可以把第四个参数置空,直接在第三个参数完成数据的查询条件。

两种方法都可以。

在完成游标的生成之后。

如果这个cursor不为空,择我们进行查询的时候要让游标移到第一个数据。

Cursor.moveTofirst();

因为游标默认的是指向第一行数据的上一行,如果我们不指向第一行就会报错,越界的异常。

(二)增加

// 增加数据public long addMethod(String str) {/* 将新增的值放入ContentValues */ContentValues cv = new ContentValues();cv.put(FIELD_TEXT, str);//键值对long row = db.insert(TABLE_NAME, null, cv);Log.i(TAG, "addMethod row=" + row);return row;}

第一个参数是你想往哪张表中插入数据的表名。

第二个参数是不允许插入一个完全为空的一条记录。

第二个参数是键值对,封装在一个ContentValues对象中。

(三)修改

// 修改public void modMethod(int id, String str) {ContentValues values = new ContentValues();values.put(FIELD_TEXT, str);String[] whereArgs = { Integer.toString(id) };int rowsaffected = db.update(TABLE_NAME, values, FIELD_id + " = ?",whereArgs);Log.i(TAG, "modMethod() rowsaffected=" + rowsaffected);} 

参数已经很清楚了。

返回的是受影响的行数,是一行还是2行。

(四)删除

// 删除public void deleteMethod(int id) {String[] whereArgs = { Integer.toString(id) };int rowsaffected = db.delete(TABLE_NAME, FIELD_id + "=?", whereArgs);Log.i(TAG, "deleteMethod() rowsaffected=" + rowsaffected);}

参数已经很清楚了。

返回的是受影响的行数,是一行还是2行。

(五)关闭数据库

//关闭数据库@Overridepublic synchronized void close() {// TODO Auto-generated method stubLog.i(TAG, " close() ");db.close();super.close();}

范例的源代码见《二》Android 数据库  SQlite      SQLiteOpenHelper

《一》Android 数据库 SQlite SQLiteOpenHelper相关推荐

  1. 《二》Android 数据库 SQlite SQLiteOpenHelper

    /**************************************************** 大家都知道写博客会很累的,大热天的. 希望=转载请注明出处:http://blog.csdn ...

  2. Android 数据库(SQLite)【简介、创建、使用(增删改查、事务、实战演练)、数据显示控件(ListView、Adapter、实战演练-绿豆通讯录)】

    目   录 (壹)SQLite数据库简介 (贰)数据库的创建 (叁)数据库的使用 3.1.SQlite的基本操作 3.1.1.添加数据 3.1.2.修改数据 3.1.3.查询数据 3.1.4.删除数据 ...

  3. Android 数据库Sqlite的使用(1)

    在Android中,我们使用的数据库是一个轻量级的数据库 sqlite 下面我们来学习一下它的CURD操作 首先 我们需要创建一个类 继承自android自带的一个数据库帮助类SQLiteOpenHe ...

  4. android绿豆通讯录xml,Android 数据库(SQLite)【简介、创建、使用(增删改查、事务、实战演练)、数据显示控件(ListView、Adapter、实战演练)】...

    目   录 (壹)SQLite数据库简介 (贰)数据库的创建 (叁)数据库的使用 3.1.SQlite的基本操作 3.1.1.添加数据 3.1.2.修改数据 3.1.3.查询数据 3.1.4.删除数据 ...

  5. Android数据库—SQLite

    目录 Android数据库-SQLite 在线查看数据库方法 继承SQLiteOpenHelper的类,加载驱动 在Activity中进行增删改查 增加数据 删除数据 修改数据 查询数据 在界面上进行 ...

  6. android realm 简书,android 数据库SQLite realm

    一.SQLite android内置了数据库SQLite,这是一款轻量级的关系型数据库,通常只需要几百K的内存.数据库文件存放在/data/data//databases/目录下. 为了方便管理数据库 ...

  7. Android 数据库 SQLite

    首先关于SQLite的介绍百度上看看就大致了解的差不多了. Android 操作数据库的关键步骤就在于实现API SQLiteOpenHelper,通常这个库辅助类来创建或打开数据库. 废话不多说直接 ...

  8. android 数据库sqlite的使用

    android开发的过程中,不可避免的有需要存储数据的时候. android的数据存取机制有很多,其中最重要的大概就是sqlite数据库了 sqlite 数据库是android自带的数据库.不需要任何 ...

  9. 一篇好文之Android数据库 SQLite全解析

    项目效果地址: SQlite 1. 创建数据库 Android中使用SQlite,需要自己创建库,建表,添加数据!好在Android中提供了SQLiteOpenHelper类来帮助创建使用数据库,我们 ...

最新文章

  1. LeetCode简单题之检查整数及其两倍数是否存在
  2. [转] C# Winform 拦截关闭按钮触发的事件
  3. css制作漂亮彩带导航条菜单
  4. 数学/找规律/sgu 118 Digital root
  5. 从零开始学习docker(七)docker配置环境变量
  6. 手把手教你用7行代码实现微信聊天机器人 -- Python wxpy
  7. 外网访问FTP服务,解决只能以POST模式访问Filezilla的问题
  8. 软件测试工程师和WGT,软件系统测试(WGT)工程师---ATK
  9. 程序员秒懂的30个段子:看到第几个你笑了?
  10. ajax 刷新 保持原位置_JavaEE之Ajax第一课
  11. #!/usr/bin/env python作用
  12. 几种经典的hash算法
  13. 在线直播系统源码,进入新的界面后自动刷新内容
  14. 计算机专业博士阶段研究方向,国内计算机专业博士研究方向
  15. C#实现Gauss完全主元消去法
  16. 西门菲莎大学计算机专业怎么样,西蒙菲莎大学世界排名2021年
  17. 成都市计算机学校怎么样,成都市计算机学校教学怎么样
  18. RHEL5+postfix+mysql+extmai(源代码)续
  19. SQL0668N Operation not allowed for reason code 3 on table TEST.
  20. 睡眠期间人类海马体中缓慢振荡、纺锤波和波纹的分层嵌套

热门文章

  1. 常见错误:JavaScript 提交form 的时候,Error:对象不支持此属性或方法
  2. php扩展可以通过pecl 或者phpize 安装
  3. 向着DJANGO奔跑!
  4. Learning Data Structure_2_线性表、栈和队列
  5. linux mint 16 安装chrome 浏览器
  6. C/C++语言中Static的作用详述
  7. 【自然框架】 权限 的视频演示(二): 权限到字段、权限到记录
  8. TensorWatch 机器学习调试和可视化工具
  9. 前端开发和设计必备的Chrome插件
  10. 【Word】关于Word文档写作中遇到的一些问题