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

[经验分享] Android 之 SQLite数据库的使用

[复制链接]

尚未签到

发表于 2016-11-30 09:07:11 | 显示全部楼层 |阅读模式

Android 集成了SQLite数据库
Android在运行时集成了SQLite , 所以每个Android应用程序都可以使用SQLite数据库。
数据库存放的位置:data/<项目文件夹>/databases/
第一步:创建数据库
Android 中提供SQLiteOpenHelper类帮助创建一个数据库,继承该类可以轻松的创建SQLite数据库;
注意:SQLiteOpenHelper的子类至少要实现三个方法:
* 带参的构造方法;
* onCreate();
* onUpgrag();
java代码如下:

package com.example.sqlite;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
/* SQLiteOpenHelper的子类, 用于操作数据库  
*
* SQLiteOpenHelper 是一个辅助类,用来管理数据库的创建和版本,提供两方面的功能;
*
* 第一:getReadableDatabase() 、 getWriteableDatabase() 可以获得SQLiteDatabase对象,通过该对象可以对数据库进行操作;
*
* 第二:提供onCreate() ; onUpgrade() 两个回调函数,允许我们再创建和删除数据库时,进行自己的操作;
*
* */
public class MySQLiteOpenHelper extends SQLiteOpenHelper {
/* 构造方法,调用父类SQLiteOpenHelper的构造函数 */
/* 参1:上下文环境;参2:数据库名称(以.db结尾) ; 参3:游标工厂(默认为null) ; 参4:代表使用数据库模型版本的证书*/
public MySQLiteOpenHelper(Context context, String name,CursorFactory factory, int version) {
super(context, name, factory, version);
}

/* 根据需要对SQLiteDatabase 的对象填充表和数据初始化 */
/* 该方法时在第一次创建的时候执行,实际上时第一次得到SQLiteDatabase对象的时侯才会调用这个方法 */
public void onCreate(SQLiteDatabase db) {
// TODO 创建数据库后,对数据库的操作
}

/* 将数据库从旧的模型转换为新的模型 *//* 参1:对象   ; 参2:旧版本号 ; 参3:新版本号 */
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO 更改数据库版本的操作
}
/* 打开数据库执行的函数 */
public void onOpen(SQLiteDatabase db) {
// TODO 每次成功打开数据库后首先被执行
super.onOpen(db);
}
}
案例代码如下:
package com.example.sqlite;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;


public class MainActivity extends Activity {
/* 设置表相关信息的常量 */
final String MYTAB = "t_score";
final String MYNAME ="name";
final String MYSCORE = "score";
MySQLiteOpenHelper helper;
private Button selectData,createDatabase,createTable,insertData,updateData,deleteData;
/* 获取组建对象 */
public void init(){
selectData = (Button) findViewById(R.id.selectData);
createDatabase = (Button) findViewById(R.id.createDatabase);
createTable = (Button) findViewById(R.id.createTable);
insertData = (Button) findViewById(R.id.insertData);
updateData = (Button) findViewById(R.id.updateData);
deleteData  = (Button) findViewById(R.id.deleteData);
}
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
/* 初始化组件对象 */
init();
/* 创建数据库 */
createDatabase.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 创建一个MySQLiteOpenHelper,该语句执行是不会创建或打开连接的 */
helper = new MySQLiteOpenHelper(MainActivity.this, "mydb.db", null, 1);
/* 调用MySQLiteOpenHelper的getWriteableDatabase()方法,创建或者打开一个连接 */
SQLiteDatabase sqlitedatabase = helper.getWritableDatabase();
Toast.makeText(MainActivity.this, "数据库创建成功", 1000).show();
}
});

/* 创建表 */
createTable.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 创建一个MySQLiteOpenHelper,该语句执行是不会创建或打开连接的 */
helper = new MySQLiteOpenHelper(MainActivity.this, "mydb.db", null, 1);
/* 获取一个可写的SQLiteDatabase对象,创建或打开连接 */
SQLiteDatabase sqliteDatabase = helper.getWritableDatabase();
/* 创建两张表 */
sqliteDatabase.execSQL("create table student(id INTEGER PRIMARY KEY autoincrement,name text);");
sqliteDatabase.execSQL("create table "+MYTAB+"("+MYNAME+" text,"+MYSCORE+" integer);");
/* 小贴士 */
Toast.makeText(MainActivity.this, "数据表创建成功", 1000).show();
}
});

/* 插入数据 */
insertData.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 连接数据库 *//* 数据库中有表 , 对表进行操作 */
SQLiteDatabase sqliteDatabase = helper.getWritableDatabase();
/* 给表添加数据: *//* 方式1: *//* 增加一条数据 */
sqliteDatabase.execSQL("insert into student(name) values('mike')");
/* 方式2: *//* 使用SQLiteDatabase 对象的insert()方法 */
/* 创建ContentValues对象 *//* 每次插入的时一条数据  */
ContentValues cv = new ContentValues();
cv.put("name", "mary");/* key==列    value==值 */
sqliteDatabase.insert("student", null, cv);
cv.clear();
/* 对MYTAB进行数据添加  */
sqliteDatabase.execSQL("insert into "+MYTAB+" values('ray',95)");
sqliteDatabase.execSQL("insert into "+MYTAB+" values('tom',85)");
sqliteDatabase.execSQL("insert into "+MYTAB+" values('jone',90)");
cv.put(MYNAME, "jack");
cv.put(MYSCORE, 78);
sqliteDatabase.insert(MYTAB, null, cv);
cv.clear();
Toast.makeText(MainActivity.this, "数据插入成功", 1000).show();
}
});

/* 修改数据 *//* updateData点击事件监听器 */
updateData.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 建立和数据库的连接,获取SQLiteDatabase对象 */
SQLiteDatabase sqliteDatabase = helper.getWritableDatabase();
/* 方式1:直接使用语句 */
//sqliteDatabase.execSQL("update student set name='mary key' where id=1");
/* 方式2:使用sqliteDatabase.update();方法 */
ContentValues cv = new ContentValues();
cv.put("name", "mary key");/* 确定需要修改对应列的值 */
/* 参1:表名  ; 参2:ContentValues对象; 参3:where字句,相当于sql中where后面的语句,?是占位符 */
/* 参4:占位符的值; */
sqliteDatabase.update("student", cv, "id=?", new String[]{"1"});
Toast.makeText(MainActivity.this, "数据修改成功", 1000).show();
}
});

/* 删除数据 ; 设置deleteData点击事件监听器 */
deleteData.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 与数据库建立联系,获得SQLiteDatabase的对象 */
SQLiteDatabase sqliteDatabase = helper.getWritableDatabase();
/* 使用sql语句直接进行删除 */
//sqliteDatabase.execSQL("");
/* 调用:SQLiteDatabase对象的delete()的方法删除数据 */
/* 参1:表名; 参2:条件语句; 参3:条件语句中对应占位符的值 */
sqliteDatabase.delete("student", "id=?", new String[]{"1"});
Toast.makeText(MainActivity.this, "数据删除成功", 1000).show();
}
});

/* 查看数据 *//* selectData点击事件监听器 */
selectData.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/* 获取SQLiteDatabase的对象 */
SQLiteDatabase sqliteDatabase = helper.getReadableDatabase();
/* 调用SQLiteDatabase的query()方法进行查询,返回一个Cursor对象:由数据库查询返回的结果集对象 */
/*参1 String:表名
* 参2 String[]:需要查询的列;
* 参3 String :查询条件;
* 参4 String[]:查询条件的参数;
*  参5 String:对查询的结果进行分组;
*  参6 String:对分组结果进行限制;
*  参7 String: 对查询结果进行排序;
*
* */
Cursor cursor = sqliteDatabase.query("student", new String[]{"id","name"}, "id=?", new String[]{"1"}, null, null, null);
/* 保存结果集中对应字段的数据 */
String id = null;
String name = null;
/* 从结果集中读取数据 */
while(cursor.moveToNext()){
id = cursor.getString(cursor.getColumnIndex("id"));
name = cursor.getString(cursor.getColumnIndex("name"));
}
Toast.makeText(MainActivity.this, "查询数据为:id="+id+" \n name="+name, 1000).show();
}
});
}

}

运维网声明 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-307478-1-1.html 上篇帖子: C# SQLite实用帮助类:SQLiteHelper 下篇帖子: SQlite数据库的C编程接口(二) 数据库连接 ——《Using SQlite》读书笔记
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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