使用SQLiteOpenHelper和单例模式 *** 作SQLite数据库

使用SQLiteOpenHelper和单例模式 *** 作SQLite数据库,第1张

概述在前文中总结了SQLite数据库的基本用法,本文中将使用SQLiteOpenHelper和单例模式 *** 作数据库。SQLiteOpenHelper是Android提供的一个管理数据库的工具类,可以用于管理数据库的创建和版本更新。一般的用法是创建它的子类,并扩展它的onCreate()和onUpgrade方法。 SQLiteOpenHelper包含如下方法: 同上文一样,数据仍是手动写死的,实际情况应

在前文中总结了sqlite数据库的基本用法,本文中将使用sqliteOpenHelper和单例模式来 *** 作数据库。sqliteOpenHelper是AndroID提供的一个管理数据库的工具类,可以用于管理数据库的创建和版本更新。一般的用法是创建它的子类,并扩展它的onCreate()和onUpgrade方法。

sqliteOpenHelper包含如下方法:

同上文一样,数据仍是手动写死的,实际情况应该根据业务需求从界面或其他地方获取,实例代码如下,关键是后面两个类:

Activity:

package com.lovo.activity;import androID.app.Activity;import androID.database.Cursor;import androID.os.Bundle;import androID.vIEw.VIEw;import androID.Widget.TextVIEw;import com.lovo.dao.StuDao;import com.lovo.databasetest.R;public class DatabaseTestActivity extends Activity {	private TextVIEw show;	private StuDao dao;	@OverrIDe	protected voID onCreate(Bundle savedInstanceState) {		super.onCreate(savedInstanceState);		setContentVIEw(R.layout.main);		show = (TextVIEw) findVIEwByID(R.ID.main_tv_show);		dao = new StuDao(this);	}	public voID click(VIEw v) {		switch (v.getID()) {		case R.ID.main_btn_insert:			// 添加数据			dao.insert("张三",24,"男");			break;		case R.ID.main_btn_delete:			// 根据指定ID删除数据			dao.del(2);			break;		case R.ID.main_btn_update:			// 根据指定ID修改数据			dao.update("王斌",34,"男",1);			break;		case R.ID.main_btn_find:			StringBuffer sb = new StringBuffer();			// 查询所有数据			Cursor cursor = dao.findAll();			// 根据指定ID查询数据			// Cursor cursor=dao.findByID(1);			while (cursor.movetoNext()) {				int ID = cursor.getInt(cursor.getColumnIndex("_ID"));				String name = cursor.getString(cursor.getColumnIndex("s_name"));				String sex = cursor.getString(cursor.getColumnIndex("s_sex"));				int age = cursor.getInt(cursor.getColumnIndex("s_age"));				sb.append(ID + " " + name + " " + sex + " " + age + "\n");			}			show.setText(sb.toString());			break;		}	}}

布局XML:

<linearLayout xmlns:androID="http://schemas.androID.com/apk/res/androID"    androID:layout_wIDth="match_parent"    androID:layout_height="match_parent"    androID:orIEntation="vertical" >    <button        androID:ID="@+ID/main_btn_insert"        androID:layout_wIDth="wrap_content"        androID:layout_height="wrap_content"        androID:onClick="click"        androID:text="添加" />    <button        androID:ID="@+ID/main_btn_delete"        androID:layout_wIDth="wrap_content"        androID:layout_height="wrap_content"        androID:onClick="click"        androID:text="删除" />    <button        androID:ID="@+ID/main_btn_update"        androID:layout_wIDth="wrap_content"        androID:layout_height="wrap_content"        androID:onClick="click"        androID:text="修改" />    <button        androID:ID="@+ID/main_btn_find"        androID:layout_wIDth="wrap_content"        androID:layout_height="wrap_content"        androID:onClick="click"        androID:text="查找" />    <TextVIEw        androID:ID="@+ID/main_tv_show"        androID:layout_wIDth="wrap_content"        androID:layout_height="wrap_content" /></linearLayout>

sqliteOpenHelper的子类(DBUtil):

package com.lovo.dao;import androID.content.Context;import androID.database.sqlite.sqliteDatabase;import androID.database.sqlite.sqliteDatabase.CursorFactory;import androID.database.sqlite.sqliteOpenHelper;public class DBUtil extends sqliteOpenHelper {	private static DBUtil dbUtil;	private DBUtil(Context context,String name,CursorFactory factory,int version) {		super(context,name,factory,version);	}	public static sqliteDatabase getInstance(Context context) {		if (dbUtil == null) {			// 指定数据库名为student,需修改时在此修改;此处使用默认工厂;指定版本为1			dbUtil = new DBUtil(context,"student",null,1);		}		return dbUtil.getReadableDatabase();	}	@OverrIDe	public voID onCreate(sqliteDatabase db) {		try {			db.execsql("create table t_stu(_ID integer primary key,s_name text,s_age integer,s_sex text)");		} catch (Exception e) {			e.printstacktrace();		}	}	@OverrIDe	public voID onUpgrade(sqliteDatabase db,int oldVersion,int newVersion) {		System.out.println("-----onUpgrade Called-----" + oldVersion + "--->"				+ newVersion);	}}

StuDao类:封装数据 *** 作的方法

package com.lovo.dao;import androID.content.Context;import androID.database.Cursor;import androID.database.sqlite.sqliteDatabase;public class StuDao {	private sqliteDatabase db;	public StuDao(Context context) {		db = DBUtil.getInstance(context);	}	/**	 * 查询所有数据	 * 	 * @return Cursor	 */	public Cursor findAll() {		Cursor cursor = db.rawquery("select * from t_stu",null);		return cursor;	}	/**	 * 添加数据	 * 	 * @param name  姓名	 * @param age  年龄	 * @param sex  性别	 */	public voID insert(String name,int age,String sex) {		db.execsql("insert into t_stu values(null,?,?)",new String[] { name,age + "",sex });	}	/**	 * 删除数据	 * 	 * @param ID	 */	public voID del(int ID) {		db.execsql("delete from t_stu where _ID=?",new String[] { ID + "" });	}	/**	 * 根据ID查询数据	 * 	 * @param ID	 * @return Cursor	 */	public Cursor findByID(int ID) {		Cursor cursor = db.rawquery("select * from t_stu where _ID=?",new String[] { ID + "" });		return cursor;	}	/**	 * 修改数据	 * 	 * @param name 姓名	 * @param age  年龄	 * @param sex  性别	 * @param ID   ID	 */	public voID update(String name,String sex,int ID) {		db.execsql("update t_stu set s_name=?,s_age=?,s_sex=? where _ID=?",new Object[] { name,age,sex,ID });	}}
总结

以上是内存溢出为你收集整理的使用SQLiteOpenHelper和单例模式 *** 作SQLite数据库全部内容,希望文章能够帮你解决使用SQLiteOpenHelper和单例模式 *** 作SQLite数据库所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/1180874.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-02
下一篇2022-06-02

发表评论

登录后才能评论

评论列表(0条)

    保存