请大家伙多多指教:
邮箱:weimingweicom@sina.com
最终插入的数据:
除了可以使用文件或SharedPreferences存储数据,还可以选择使用sqlite数据库存储数据。
在Android平台上,集成了一个嵌入式关系型数据库—sqlite,sqlite3支持NULL、INTEGER、REAL(浮点数字)、TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型只有五种,但实际上sqlite3也接受varchar(n)、char(n)、decimal(p,s)等数据类型,只不过在运算或保存时会转成对应的五种数据类型。sqlite最大的特点是你可以保存任何类型的数据到任何字段中,无论这列声明的数据类型是什么。例如:可以在Integer类型的字段中存放字符串,或者在布尔型字段中存放浮点数,或者在字符型字段中存放日期型值。但有一种情况例外:定义为INTEGERPRIMARYKEY的字段只能存储64位整数,当向这种字段中保存除整数以外的数据时,将会产生错误。另外,sqlite在解析CREATETABLE语句时,会忽略CREATETABLE语句中跟在字段名后面的数据类型信息,如下面语句会忽略name字段的类型信息:
CREATETABLEperson(personidintegerprimarykeyautoincrement,namevarchar(20))
查询语句:select*from表名where条件子句groupby分组字句having...orderby排序子句
如:select*fromperson
select*frompersonorderbyiddesc
selectnamefrompersongroupbynamehavingcount(*)>1
分页sql与MysqL类似,下面sql语句获取5条记录,跳过前面3条记录
select*fromAccountlimit5offset3或者select*fromAccountlimit3,5
插入语句:insertinto表名(字段列表)values(值列表)。如:insertintoperson(name,age)values(‘传智’,3)
更新语句:update表名set字段名=值where条件子句。如:updatepersonsetname=‘传智‘whereid=10
删除语句:deletefrom表名where条件子句。如:deletefrompersonwhereid=10;
我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在成百上千个用户的手机上,如果应用使用到了sqlite数据库,我们必须在用户初次使用软件时创建出应用使用到的数据库表结构及添加一些初始化记录,另外在软件升级的时候,也需要对数据表结构进行更新。那么,我们如何才能实现在用户初次使用或升级软件时自动在用户的手机上创建出应用需要的数据库表呢?总不能让我们在每个需要安装此软件的手机上通过手工方式创建数据库表吧?因为这种需求是每个数据库应用都要面临的,所以在Android系统,为我们提供了一个名为sqliteOpenHelper的抽象类,必须继承它才能使用,它是通过对数据库版本进行管理来实现前面提出的需求。
为了实现对数据库版本进行管理,sqliteOpenHelper类提供了两个重要的方法,分别是onCreate(sqliteDatabasedb)和onUpgrade(sqliteDatabasedb,intoldVersion,intnewVersion),前者用于初次使用软件时生成数据库表,后者用于升级软件时更新数据库表结构。当调用sqliteOpenHelper的getWritableDatabase()或者getReadableDatabase()方法获取用于操作数据库的sqliteDatabase实例的时候,如果数据库不存在,Android系统会自动生成一个数据库,接着调用onCreate()方法,onCreate()方法在初次生成数据库时才会被调用,在onCreate()方法里可以生成数据库表结构及添加一些应用使用到的初始化数据。onUpgrade()方法在数据库的版本发生变化时会被调用,一般在软件升级时才需改变版本号,而数据库的版本是由程序员控制的,假设数据库现在的版本是1,由于业务的变更,修改了数据库表结构,这时候就需要升级软件,升级软件时希望更新用户手机里的数据库表结构,为了实现这一目的,可以把原来的数据库版本设置为2(有同学问设置为3行不行?当然可以,如果你愿意,设置为100也行),并且在onUpgrade()方法里面实现表结构的更新。当软件的版本升级次数比较多,这时在onUpgrade()方法里面可以根据原版号和目标版本号进行判断,然后作出相应的表结构及数据更新。
getWritableDatabase()和getReadableDatabase()方法都可以获取一个用于操作数据库的sqliteDatabase实例。但getWritableDatabase()方法以读写方式打开数据库,一旦数据库的磁盘空间满了,数据库就只能读而不能写,倘若使用的是getWritableDatabase()方法就会出错。getReadableDatabase()方法先以读写方式打开数据库,如果数据库的磁盘空间满了,就会打开失败,当打开失败后会继续尝试以只读方式打开数据库。
packagecom.example.lession05_db.db;
importandroid.content.Context;
importandroid.database.sqlite.sqliteDatabase;
importandroid.database.sqlite.sqliteDatabase.CursorFactory;
importandroid.database.sqlite.sqliteOpenHelper;
importandroid.util.Log;
/**
*数据库
*
*@authorchenhj
*
*/
publicclassDBsqliteOpenHelperextendssqliteOpenHelper{
privatestaticfinalStringname="CSDN.db";
//数据库的版本
privatestaticfinalintversion=4;
publicDBsqliteOpenHelper(Contextcontext){
//第三个参数CursorFactory指定在执行查询时获得一个游标实例的工厂类,设置为null,代表使用系统默认的工厂类
super(context,name,null,version);
Log.v("DBsqliteOpenHelper","构造器......");
}
@Override
publicvoidonCreate(sqliteDatabasedb){
db.execsql("createtableperson(personidintegerprimarykeyautoincrement,namevarchar(20),ageinteger)");
Log.v("DBsqliteOpenHelper","onCreate......创建执行一次");
}
@Override
publicvoidonUpgrade(sqliteDatabasedb,intnewVersion){
db.execsql("altertablepersonaddaccountinteger");
Log.v("DBsqliteOpenHelper","当数据库版本更新的时候执行........每次更新都执行");
}
}
CRUD的方法:
packagecom.example.lession05_db.test;
importandroid.database.sqlite.sqliteDatabase;
importandroid.test.AndroidTestCase;
importcom.example.lession05_db.db.DBsqliteOpenHelper;
importcom.example.lession05_db.db.dao.PersonDao;
importcom.example.lession05_db.db.dao.PersonDaoImpl;
importcom.example.lession05_db.domain.Person;
publicclassDBTestextendsAndroidTestCase{
PersonDaopersonDao=newPersonDaoImpl();
/**
*创建数据库
*/
publicvoidcreateDB(){
//创建数据库管理的对象
DBsqliteOpenHelperdb=newDBsqliteOpenHelper(this.getContext());
sqliteDatabasesdb=db.getWritableDatabase();
}
publicvoidinsert(){
//创建数据库管理的对象
DBsqliteOpenHelperdb=newDBsqliteOpenHelper(this.getContext());
for(inti=1;i<10;i++){
sqliteDatabasesdb=db.getWritableDatabase();
Personentity=newPerson(null,"chenhj"+i,28+i,1000+i);
personDao.insert(sdb,entity);
}
}
publicvoidupdate(){
//创建数据库管理的对象
DBsqliteOpenHelperdb=newDBsqliteOpenHelper(this.getContext());
sqliteDatabasesdb=db.getWritableDatabase();
Personentity=newPerson(1,"xinxt",29,10000*2);
personDao.update(sdb,entity);
}
publicvoiddelete(){
//创建数据库管理的对象
DBsqliteOpenHelperdb=newDBsqliteOpenHelper(this.getContext());
sqliteDatabasesdb=db.getWritableDatabase();
personDao.delete(sdb,1);
}
}
注意:每次数据库进行改变后都要把文件重新导出,然后在刷新,才能看到效果。
添加测试的权限: