记一次对sqlite数据库的学习
来源:互联网 发布:淘宝教育上直通车 编辑:程序博客网 时间:2024/05/23 01:05
1.使用SqliteOpenHelper类
构造方法
public DBOpenHandler(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) { super(context, name, factory, version); // TODO Auto-generated constructor stub}
// SQLiteOpenHelper的构造函数参数: // context:上下文环境 // name:数据库名字 // factory:游标工厂(可选) // version:数据库模型版本号
重写onCreate
使用到新建数据库表。
重写onUpgrade
方法在数据库的版本发生变化时会被调用,一般在软件升级时才需改变版本号,而数据库的版本是由程序员控制的。
假设数据库现在的版本是1,由于业务的变更,修改了数据库表结构,这时候就需要升级软件,升级软件时希望更新用户手机里的数据库表结构,为了实现这一目的,可以把原来的数据库版本设置为2,并且在onUpgrade()方法里面实现表结构的更新。
package com.example.admin.ddplayv11.obj;/* * Created by p4d on 2016/12/13. */import android.content.Context;import android.database.sqlite.SQLiteDatabase;import android.database.sqlite.SQLiteOpenHelper;public class DBOpenHandler extends SQLiteOpenHelper{ public DBOpenHandler(Context context, String name, SQLiteDatabase.CursorFactory factory, int version) { super(context, name, factory, version); // TODO Auto-generated constructor stub } @Override public void onCreate(SQLiteDatabase db) { // TODO Auto-generated method stub db.execSQL("CREATE TABLE t_users1 ( id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, " + "username TEXT UNIQUE NOT NULL," + " password TEXT NOT NULL, " + "phone TEXT, " + "email TEXT," + " money INTEGER NOT NULL," + " time INTEGER NOT NULL)"); db.execSQL("CREATE TABLE t_order ( id INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,"+ "content TEXT NOT NULL,"+ "senderid TEXT NOT NULL," + "receiverid TEXT,"+ "money INTEGER NOT NULL,"+ "time INTEGER NOT NULL)"); } @Override public void onUpgrade(SQLiteDatabase db, int arg1, int arg2) { // TODO Auto-generated method stub }}2.SqliteDatabase类
SQLiteOpenHelper
类中的 getWritableDatabase()
和getReadableDatabase()
方法返回这个类的对象
SQLiteDatabase的学习,应该重点掌握execSQL()和rawQuery()方法。
execSQL()方法可以执行insert、delete、update和CREATE TABLE之类有更改行为的SQL语句;
rawQuery()方法用于执行select语句。
0 0
- 记一次对sqlite数据库的学习
- Python学习之对SQLite数据库详解
- 对sqlite的微型数据库的认知
- sqlite数据库的学习笔记
- QT实现对sqlite数据库的操作
- 对SQLite数据库应用的代码解析
- 对Android sqlite数据库的简单熟悉
- arcgis对sqlite数据库的支持情况
- xUtils3中对Sqlite数据库的操作
- xUtils3中对Sqlite数据库的操作
- xUtils3中对Sqlite数据库的操作
- C#对Sqlite数据库的操作类
- 对JAVA学习的一次小小总结
- Qt 的sqlite数据库的学习
- Qt 的sqlite数据库的学习
- android学习笔记---SQLite数据库的使用
- Android的数据库(SQLite)学习
- 学习笔记:SQLite数据库索引的使用
- 2016年的平安夜,我依旧在优化网站
- cpluscplus在线库参考
- 重置样式 reset.css
- MVP简单入门(附视频资料)
- STM32F系列ARM Cortex-M3核微控制器基础之系统时钟一
- 记一次对sqlite数据库的学习
- 没有一个“差生”
- java面向对象综合性总结----抽象+封装+继承+多态+接口
- 如何求原码、补码、反码、移码和他们的关系
- 《THING IN JAVA》 9章接口-读书笔记
- Java中堆和栈创建对象的区别
- 机器学习流行算法一览
- iOS使用UICollectionView实现可旋转菜单
- 广东航空大数据创新大赛:机场停机位资源分配优化