sharedPreferences只适合存储比较简单的数据和键值对,支持不同的数据类型

文件存储连键值对都没有,不会进行任何格式化处理,存储简单的二进制或者文本数据

sqlite则能处理一些数据量大,并且结构比较复杂的数据

管理sqlite   SQLiteHelper:抽象类,要使用的话就要创建自己的帮助类去继承它,并且重写oncreate和onupgrade,

还有两个实例方法可以调用:  getreadabledatabase()  getwritabledatabase()  都可以创建或者打开数据库,但是getreadabledatabase可以再数据库不可写入的的时候继续以只读方式打开,但是另一个方法  将会产生异常

重写构造函数:一般使用简单的参数这个**(context,数据库名字,cursor,版本号)

使用android adb来查看是否创建成功,需要配置adb环境变量 adb的环境变量path D:\andriod\adt-bundle-windows-x86-20140702\adt-bundle-windows-x86-20140702\sdk\platform-tools java的环境变量  %JAVA_HOME%\bin;

创建数据库:

创建数据库
//先定义一个类MyDatabaseHelper
public class MyDatabaseHelper extends SQLiteOpenHelper{
public static final String CREATE_BOOK="create table Book("+"id integer primary key autoincrement,"+"tuthor text,"+"price real,"+"pages integer,"+"name text)";
//创建一个新表升级数据库
public static final String CREATE_CATEGORY="create table Category("+"id integer primary key autoincrement,"+"catagory_name text,"+"categoty_code integer)"; private Context mContext;
public MyDatabaseHelper(Context context,String name,CursorFactory factory,int version){
super(context, name, factory, version);
mContext=context;
}
public void onCreate(SQLiteDatabase db){
db.execSQL(CREATE_BOOK);
db.execSQL(CREATE_CATEGORY);//新增表category的见表语句
Toast.makeText(mContext, "Create secceed", Toast.LENGTH_SHORT).show();
}
public void onUpgrade(SQLiteDatabase db,int oldVersion,int newVersion){
switch(oldVersion) {////升级数据库当老版本是1的时候就只创建在版本2中新加的表,直接安装时就两个表一起创建
case :db.execSQL(CREATE_CATEGORY);//这里没有使用break是为了保证在跨程序升级的时候能够全部创建所有升级的数据库
case :sb.execSQL(CREATE_CATEGORY);
default:
}
} }
//在主函数中进行创建数据库
public class MainActivity extends Activity {
private MyDatabaseHelper dbHelper;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
dbHelper=new MyDatabaseHelper(this,"BoolStore.db",null,);//此处的数字决定了是否执行更新操作
Button createDatabase=(Button) findViewById(R.id.create_database);
createDatabase.setOnClickListener(new OnClickListener(){
public void onClick(View v){
dbHelper.getWritableDatabase();//检查是否有库,没有就创建并且电泳oncreate见表,有就不创建
}
});
Button adddata=(Button)findViewById(R.id.adddata);
adddata.setOnClickListener(new OnClickListener(){
public void onClick(View v){
SQLiteDatabase db=dbHelper.getWritableDatabase();//getWritableDatabase会返回一个可以操作的对象
ContentValues values=new ContentValues();
values.put("name","The Da vinci code");
values.put("author","dan brown");
values.put("pages",);
values.put("price",);
db.insert("Book",null,values);
values.clear();
//开始插入第二条
values.put("name","the lost symbol");
..
..
db.inset("Book",null,values);
//开始给另一个表插入
values.put("categoty_code","");
..
.
db.insert("Category",null,values);
//id我们设为自增长了所以不用单独赋给id
}
});
//更新表中的数据
Button updatedata=(Button)findViewById(R.id.updatedata);
updatedata.setOnClickListener(new OnClickListener{
public void onClick(View v){
SQLiteDatabase db=dbHelper.getWritableDatabase();
ContentValues values=new ContentValues();
values.put("price",);
db.update("Book",values,"name=?",new String[]{"the davinci code"});//这里指定书名为the davinci code 的且在book表中的价格修改为10
}
});
//删除数据
Button deletedata=(Button)findViewById(R.id.deletedata);
deletedata.setOnClickListener(new OnClickListener{
public void onClick(View v){
SQLiteDatabase db=dbHelper.getWritableDatabase();
db.delete("Book","pages>?","new String[]{""}")//这里指定删除book中页数大于500的书籍
}
});
Button queryButton=(Button)findViewById(R.id.queruButton);
queryButton.setOnClickListener(new OnClickListener(){
public void onClick(View v){
SQLiteDatabase db=dbHelper.getWritableDatabase();
Cursor cursor=db.query("Book",null,null,null,null,null,null);//查询完后得到一个Cursor对象,接着调用moveToFirst()遍历
if(cursor.moveToFirst()){
do{
String name=cursor.getString(cursor.getColumnIndex("name"));
String author=cursor.getString(cursor.getColumnIndex("author"));
..
}while(cursor.moveToNext());//取出所有的book中的数据
}
cursor.close();
}
}); }
}

为了连贯的操作一系列的动作,要么全部完成要么全部不能完成
使用事务:

..
public void onClick(View v){
SQLiteDatabase db=dbHelper.getWritableDatabase();
db.beginTransaction();
try{
db.delete("Book",null,null);
if(true){
throw new NullPointException();//手动抛出异常
}
ContentValues values=new ContentValues();
values.put("name","bookname");
values.put("author","bookauthor");
...
db.insert("Book",null,values);
db.setTransactionSuccessful();//事务执行成功
}catch(Exception e){
e.printStackTrace();
}finally{
db.endTransaction();//结束事务
}
}

android SQLITE的基本使用总结(八)的更多相关文章

  1. Android SQLite 通配符查询找不到参数问题

    使用Android SQLite中SQLiteDatabase类的query方法查询时,如果where中包含通配符,则参数会无法设置,如类似下面的方法查询时 SQLiteDatabase db = d ...

  2. Android+Sqlite 实现古诗阅读应用(三)

    往期传送门: Android+Sqlite 实现古诗阅读应用(一) Android+Sqlite 实现古诗阅读应用(二) 加入截图分享的功能. 很多应用都有分享的功能,我也想在我的古诗App里加入这个 ...

  3. Android+Sqlite 实现古诗阅读应用(二)

    传送门:Android+Sqlite 实现古诗阅读应用(一) Hi,又回来了,最近接到很多热情洋溢的小伙伴们的来信,吼开心哈,我会继续努力的=-=! 上回的东西我们做到了有个textview能随机选择 ...

  4. Android Sqlite 数据库版本更新

      Android Sqlite 数据库版本更新 http://87426628.blog.163.com/blog/static/6069361820131069485844/ 1.自己写一个类继承 ...

  5. Android SQLite总结(一) (转)

    Android SQLite总结(一)  郑海波 2012-08-21 转载请声明:http://blog.csdn.net/nuptboyzhb/article/details/7891887 前言 ...

  6. android SQLite使用SQLiteOpenHelper类对数据库进行操作

    android SQLite使用SQLiteOpenHelper类对数据库进行操作 原文: http://byandby.iteye.com/blog/835580

  7. Android sqlite管理数据库基本用法

    Android操作系统中内置了sqlite数据库(有关sqlite数据库详细介绍见:http://zh.wikipedia.org/wiki/SQLite),而sqllite本身是一个很小型的数据库, ...

  8. Android SQLite 数据库详细介绍

    Android SQLite 数据库详细介绍 我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在很多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用 ...

  9. Android Sqlite 导入CSV文件 .

    http://blog.csdn.net/johnnycode/article/details/7413111 今天遇到 Oracle 导出的12万条CSV格式数据导入 Android Sqlite ...

  10. Android sqlite数据库存取图片信息

    Android sqlite数据库存取图片信息 存储图片:bitmap private byte[] getIconData(Bitmap bitmap){ int size = bitmap.get ...

随机推荐

  1. javascript中for in与in的用法

    1.For...In 声明用于对数组或者对象的属性进行循环/迭代操作. 对于数组 ,迭代出来的是数组元 素,对于对象 ,迭代出来的是对象的属性: var x var mycars = new Arra ...

  2. Druid手动创建连接的坑

    环境:druid 1.1.10 今天优化了一天的代码, 老代码手动创建连接,坑 Connection conn = DBUtil.getConnection("d_log_dot_" ...

  3. WPF的依赖项属性

    WPF的依赖项属性 属性与事件是.NET抽象模型的核心部分.WPF使用了更高级的依赖项属性(Dependency Property)功能来替换原来.NET的属性,实现了更高效率的保存机制,还添加了附加 ...

  4. 【学习笔记】Java中生成对象的5中方法

    概述:本文介绍以下java五种创建对象的方式: 1.用new语句创建对象,这是最常用的创建对象的方式. 2.使用Class类的newInstance方法 3.运用反射手段,调用java.lang.re ...

  5. 1729 单词查找树 2000年NOI全国竞赛

    1729 单词查找树 2000年NOI全国竞赛 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 大师 Master         题目描述 Description 在进行文法分析的 ...

  6. javascript统计一个字符在一段字符串出现次数

      <!DOCTYPE html><html lang="en"><head><meta charset="UTF-8" ...

  7. html相对定位绝对定位

    孔子说:“温故而知新,可以为师矣.”这几天参加了一个免费的前端课,每天晚上都有直播,讲解一个独立的案例.在听前端基础的时候,发现自己有不少东西没学会,平时在学校虽说html也写了不少,但有好大一部分都 ...

  8. 【Linux】文本编辑器Vim常用操作入门

    Linux常用文本编辑器:Vi & Eamcs Vim -- Vi的升级版本 Vim 一.3种工作模式 命令行模式 (Command Mode) 插入模式 (Insert Mode) -- 键 ...

  9. Jmeter(一)http接口添加header和cookie --转载

    Jmeter(一)http接口添加header和cookie   HTTP信息头管理器在Jmeter的使用过程中起着很重要的作用,通常我们在通过Jmeter向服务器发送http请求(get或者post ...

  10. Jmeter性能测试 入门--转载

    转载: Jmeter性能测试 入门 Jmeter是一款优秀的开源测试工具, 是每个资深测试工程师,必须掌握的测试工具,熟练使用Jmeter能大大提高工作效率. 熟练使用Jmeter后, 能用Jmete ...