
在前文中总结了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数据库所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)