已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Android中Sqlite使用初步 1、使用Sqlite的关键是创建一类,这个类继承SQLiteOpenHelper,继承的类必须重写三个方法:构造方法,onCreate方法,onUpgrate方法 2、SQLiteDatabase是直接操作数据库的对象,可以使用SQLiteOpenHelper的 getReadableDatabase或getWritableDatabase方法得到SQLiteDatabase对象。具体使用这两个方法得到的 SQLiteDatabase对象的不用点,根据方法名就可以看出。一个是得到可读的,一个是得到可写的。 实例代码: 1、布局文件 2、自定义继承SQLiteOpenHelper的类,重写三个方法 package yyl.db;import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteDatabase.CursorFactory;import android.database.sqlite.SQLiteOpenHelper;public class DatabaseHelper extends SQLiteOpenHelper /构造函数 public DatabaseHelper(Context context,String name,CursorFactory factory, int version) super(context,name,factory,version); /该函数在第一次创建数据库的时候执行 Override public void onCreate(SQLiteDatabase db) System.out.println(Creaet a database test_user and table user); db.execSQL(create table user (id int,name varchar(20); Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) System.out.println(upgrate a database); 3、数据库操作代码 package yyl.sqlite;import yyl.db.DatabaseHelper;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.widget.Button;public class SqliteActivity extends Activity / 定义变量 private Button createDatabase = null; private Button upgrateDatabase = null; private Button insert = null; private Button update = null; private Button query = null; private Button delete = null; Override public void onCreate(Bundle savedInstanceState) super.onCreate(savedInstanceState); setContentView(R.layout.main); / 根据ID得到控件对象 createDatabase = (Button) findViewById(R.id.createDatabase); upgrateDatabase = (Button) findViewById(R.id.upgrateDatabase); insert = (Button) findViewById(R.id.insert); update = (Button) findViewById(R.id.update); query = (Button) findViewById(R.id.query); delete = (Button) findViewById(R.id.delete); / 给按钮绑定单击事件监听器 createDatabase.setOnClickListener(new View.OnClickListener() Override public void onClick(View v) /生成DatabaseHelper对象 DatabaseHelper databaseHelper = new DatabaseHelper(SqliteActivity.this,sqlite_user,null,1); /只有调用了getReadableDatabase方法,或者getWritableDatabase方法,才会创建数据库 databaseHelper.getReadableDatabase(); ); upgrateDatabase.setOnClickListener(new View.OnClickListener() Override public void onClick(View v) /生成DatabaseHelper对象 DatabaseHelper databaseHelper = new DatabaseHelper(SqliteActivity.this,sqlite_user,null,2); /只有调用了getReadableDatabase方法,或者getWritableDatabase方法,才会更新数据库 databaseHelper.getReadableDatabase(); ); insert.setOnClickListener(new View.OnClickListener() Override public void onClick(View v) /创建ContentValue对象 ContentValues values = new ContentValues(); /插入键值对,注意值的类型必须和数据库表中字段的类型一致 values.put(id, 1); values.put(name, yangyulin); /生成SQLiteDatabase对象 DatabaseHelper dbHelper = new DatabaseHelper(SqliteActivity.this,test_user,null,1); SQLiteDatabase db = dbHelper.getWritableDatabase(); /执行插入 db.insert(user, null, values); ); update.setOnClickListener(new View.OnClickListener() Override public void onClick(View v) /生成DatabaseHelper对象 DatabaseHelper dbHelper = new DatabaseHelper(SqliteActivity.this,test_user,null,1); /调用DatabaseHelper的getWritableDatabase方法,生成SQLiteDatabase对象 SQLiteDatabase db = dbHelper.getWritableDatabase(); /生成ContentValues对象,并设定键值对 ContentValues values = new ContentValues(); values.put(name, newSky); /更新表信息:update user set name = newSky where id =1; db.update(user, values, id=?, new String1); ); query.setOnClickListener(new View.OnClickListener() Override public void onClick(View v) /生成DatabaseHelper对象 DatabaseHelper dbHelper = new DatabaseHelper(SqliteActivity.this,test_user,null,1); /调用DatabaseHelper的getReadableDatabase方法,生成SQLiteDatabase对象 SQLiteDatabase db = dbHelper.getReadableDatabase(); /执行查询,将查询结果放入到Cursor中 Cursor cursor = db.query(user, new Stringid,name, id =?, new String1, null, null, null); /打印查询结果 while(cursor.moveToNext() String name = cursor.getString(cursor.getColumnIndex(name); System.out.println(name - + name); ); delete.setOnClickListener(new View.OnClickListener() Override public void onClick(View v) /生成DatabaseHelper对象 DatabaseHelper dbHelper = new DatabaseHelper(SqliteActivity.this,test_user,null,1); /调用DatabaseHelper的getReadableDatabase方法
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年新能源行业氢燃料电池汽车产业发展报告
- 2026广西贺州市直学校赴高校招聘高校毕业生(广西师范大学专场)笔试考试参考题库及答案解析
- 2025年安庆宿松县铁寨村村级后备干部招考1人笔试考试备考试题及答案解析
- 2026云南普洱“才聚普洱•智赢未来”-宁洱县教育体育行业第一批急需紧缺人才招聘9人笔试考试备考试题及答案解析
- 2025贵州机电职业技术学院引进高技能人才2人笔试考试参考试题及答案解析
- 《JBT9918.2-1999 高精度滚刀刃磨床技术条件》(2026年)实施指南
- 《JBT9165.3-1998 管理用工艺文件格式》(2026年)实施指南
- 《JBT9162.25-1999 衬套尺寸》(2026年)实施指南
- 土建造价员顶岗实习报告
- 2025重庆南岸区长生桥镇人民政府招聘13人笔试考试备考试题及答案解析
- 2025年中国农业银行基础运营人员(供柜面经理及大堂经理岗位)考试题库及答案
- 校长岗位竞聘面试技巧与答辩范文
- 大件运输护送协议书
- 制程质量管理培训
- 2025年消防文员理论考试题库(浓缩400题)
- 个人借款合同标准范本合集
- 教师招聘考试教育法律法规试题库及答案
- 敲门礼仪培训课件
- 中职护理老师笔试题库及答案解析
- 成立消化分会的申请课件
- 2020年一级计算机基础及MSOffice应用真题汇编8
评论
0/150
提交评论