android连接SQLite数据库源代码



一.创建一个DataBaseHelper DataBaseHelper是一个访问SQLite的助类,提供两个方面的功能 1.getReadableDatebase(),getWriteableDatabase()可以获取SQLiteDatabase对象,通过 2.提供了onCreate()和onUpdate()两个回调函数,允许我们常见和升级数据库是进行使用 A、 在SQLiteOpenHelper的子类当中,必须要有的构造函数 B、该函数是在第一次创建数据库的时候执行,实际上是在第一次得到SQLiteDataBase对象的时候onCreate 二、创建一个实体person类并且给字段和封装 三、创建一个业务类对SQL的CRUD操作 1.getWritableDatabase()和getReadableDatabase()的区别 ,两个方法都可以获取一个用于操作数据库的SQLiteDatabase实例 2.execSQL(增,删,改都是这个方法)和close();android内部有缓存可关闭也不关闭也行,查询rawQuery是方法 3.在分页有到Cursor(游标)取游标下一个值cursor.moveToNext(),用游标对象接数据 "select * from person limit ?,?" person不能加上where 关键字 4.在删除注意:sb.deleteCharAt(sb.length() - 1); 四、AndroidCRUD业务对SQLite的CRUD操作 1.ContentValues对象的使用 2.android内部insert添加数据的方法,而且values这个不给值也必须要执行,而主键是不是null的其他字段的值是为null 3.insert update query delete 五、单元测试类要注意的 AndroidCRUDService curdService = new AndroidCRUDService(this.getContext()); /* * 注意:getContext必须在我们使用前已经注解进去的,在使用前要实力化,而且是使用后才有上下文 *一般设置为局部对象 */ 六、AndroidManifest.xml的配置 <!-- 配置用户类库android.test.runner测试 --> <uses-library android:name="android.test.runner" /> <instrumentation android:name="android.test.InstrumentationTestRunner" android:targetPackage="jll.sqlite" android:label="Tests for My App" /> package jll.sqlitedb; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteOpenHelper; import android.database.sqlite.SQLiteDatabase.CursorFactory; /** * *@author Administrator DataBaseHelper是一个访问SQLite的助类,提供两个方面的功能 * 1.getReadableDatebase(),getWriteableDatabase()可以获取SQLiteDatabase对象,通过 * 2.提供了onCreate()和onUpdate()两个回调函数,允许我们常见和升级数据库是进行使用 */ public class DataBaseHelper extends SQLiteOpenHelper { // 给一个默认的SQLite的数据库名 private static final String DataBaseName = "SQLite_DB"; private static final int VERSION = 2; // 在SQLiteOpenHelper的子类当中,必须要有的构造函数 public DataBaseHelper(Context context, String name, CursorFactory factory, int version) { // 必须通过super调用父类当中的构造函数 super(context, DataBaseName, factory, version); } public DataBaseHelper(Context context) { super(context, DataBaseName, null, VERSION); } // 其实是调用四个构造的函数的方法 public DataBaseHelper(Context context, String name, int version) { this(context, name, null, version); } // 该函数是在第一次创建数据库的时候执行,实际上是在第一次得到SQLiteDataBase对象的时候 @Override public void onCreate(SQLiteDatabase db) { System.out.println("create a DataBase"); // execSQL函数用于执行sql语句 db.execSQL("create table person(personid integer primary key autoincrement, name varchar(20),age integer,tel varchar(20))"); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // 存在这个表的话就把它删除, db.execSQL("DROP TABLE IF EXISTS person"); System.out.println("update a Database"); } }






























































































- 1

- 粉丝: 52
我的内容管理 展开
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助


最新资源
- 信息化教学设计方案评价量规.doc
- 基于互联网+的党校档案管理问题分析.docx
- Delphi短信视频点播前台管理子.doc
- 一种基于图像处理的芯片自动开封算法设计.docx
- 基于Java开发平台的安全性措施.docx
- SolidWorks工程图转换成AutoCADDWG文件后字体不变的方法.doc
- 基于计算机技术的科技管理模式的现代化应用研究.docx
- 实验离散信号的DTFT和DFT及其FFT算法的应用.doc
- 新零售背景下网络零售平台创新模式探索.docx
- 什么是人工智能人工智能知识详解.docx
- C++课程设计方案系统和论文设计方案.docx
- 条高AutoCAD工程项目师绘图技巧.doc
- 基于FTTC的桃源步行街无线网络规划与设计.doc
- 通信工程实习总结.docx
- 某教学楼计算机网络系统集成设计方案.doc
- 基于单片机的十字路口交通灯方案设计书大学大学本科方案设计书(方案设计书).doc



- 1
- 2
- 3
- 4
- 5
- 6
前往页