1. package com.shawn.test;
    2. import android.content.ContentValues;
    3. import android.content.Context;
    4. import android.database.Cursor;
    5. import android.database.sqlite.SQLiteDatabase;
    6. import android.database.sqlite.SQLiteOpenHelper;
    7. import android.util.Log;
    8. public class DatabaseAdapter{
    9. private static final String DB_NAME = "Test.db";    //数据库名
    10. private static final int    DB_VERSION = 1;         //数据库版本
    11. private static final String DB_TABLE = "my_order";  //表名
    12. private static final String KEY_ID = "_id";         //id
    13. private static final String KEY_ORDER_ID = "order_id";  //订单号
    14. private static final String KEY_TYPE = "_type";         //订单类型
    15. private static final String KEY_STATE = "_state";       //订单状态
    16. private Context context;
    17. private DatabaseHelper mDatabaseHelper;
    18. private SQLiteDatabase mSQLiteDatabase;
    19. private static class DatabaseHelper extends SQLiteOpenHelper{
    20. //创建数据库语句
    21. private static final String DB_CREAT = "CREATE TABLE "
    22. + DB_TABLE
    23. + " (" + KEY_ID + " INTEGER PRIMARY KEY,"
    24. + KEY_ORDER_ID + " TEXT,"
    25. + KEY_TYPE + " INTEGER,"
    26. + KEY_STATE + " INTEGER)";
    27. public DatabaseHelper(Context context) {
    28. super(context, DB_NAME,  null , DB_VERSION);
    29. }
    30. @Override
    31. public void onCreate(SQLiteDatabase db) {
    32. // TODO Auto-generated method stub
    33. db.execSQL(DB_CREAT);
    34. }
    35. @Override
    36. public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    37. // TODO Auto-generated method stub
    38. db.execSQL("DROP TABLE IF EXISTS "+DB_TABLE);
    39. onCreate(db);
    40. }
    41. }
    42. public DatabaseAdapter(Context context) {
    43. this.context = context;
    44. }
    45. //开启
    46. public void open() {
    47. mDatabaseHelper = new DatabaseHelper(context);
    48. mSQLiteDatabase = mDatabaseHelper.getWritableDatabase();
    49. }
    50. //关闭
    51. public void close() {
    52. mSQLiteDatabase.close();
    53. mDatabaseHelper.close();
    54. }
    55. //增
    56. public long insertData(String orderId, int type) {
    57. ContentValues values = new  ContentValues();
    58. values.put(KEY_ORDER_ID, orderId);
    59. values.put(KEY_TYPE, type);
    60. values.put(KEY_STATE, Config.STATE_APPLY);
    61. long id = mSQLiteDatabase.insert(DB_TABLE, KEY_ID, values);
    62. return id;
    63. }
    64. //删
    65. public boolean deleteData(Context context, long id) {
    66. boolean delete = mSQLiteDatabase.delete(DB_TABLE, KEY_ID + "=" +id, null)>0;
    67. return delete;
    68. }
    69. //改
    70. public boolean updateData(long id, int state) {
    71. ContentValues values = new  ContentValues();
    72. values.put(KEY_STATE, ""+state);
    73. boolean update = mSQLiteDatabase.update(DB_TABLE, values, KEY_ID + "=" +id, null)>0;
    74. return update;
    75. }
    76. //查
    77. public Cursor fetchData(String selection) {
    78. Cursor mCursor = mSQLiteDatabase.query(DB_TABLE, new String[]{KEY_ID, KEY_ORDER_ID, KEY_TYPE, KEY_STATE}, selection, null, null, null, null);
    79. if(mCursor != null)
    80. mCursor.moveToFirst();
    81. return mCursor;
    82. }
    83. }

Android SQLiteDatabase的使用的更多相关文章

  1. Android:Sqlitedatabase学习小结

    今天刚刚学习完Sqlite数据库的基础知识,随即把学到的东西记录下来,以便随后查阅,以下是自己对Sqlite数据库的小结:1.Sqlite简介       Sqlite是一款轻型的数据库,它包含在一个 ...

  2. Android SQLiteDatabase分析

    Android中的数据存储使用的小巧的SQLite数据库. 为了方便java层使用SQLite,android做了大量的封装.提供了一些列的类和API.本文章就揭露这些封装背后的类图关系. 老规矩,首 ...

  3. Android SQLiteDatabase使用总结

    SQLiteDatabase数据库操作 1.创建一个继承了类SQLiteOPenHelper类复写相应的方法,和构造函数 2.然后创建一个类,定义一个私有变量(上述类的实例化对象),在构造函数中进行初 ...

  4. Android sqlitedatabase 事务

    SQLiteDatabase的beginTransaction()方法可以开启一个事务,程序执行到endTransaction() 方法时会检查事务的标志是否为成功,如果为成功则提交事务,否则回滚事务 ...

  5. Android SQLiteDatabase中query、insert、update、delete方法参数说明

    1.SQLiteDataBase对象的query()接口: public Cursor query (String table, String[] columns, String selection, ...

  6. android SQLiteDatabase数据库使用的时候 常见问题

    用数据库的时候有时候一定要用_id否则会报错 对于Contentprovider的查询用contentResolver.insert()      一般的数据库操作用db.insert();

  7. Android Sqlite数据库执行插入查询更新删除的操作对比

    下面是在Android4.0上,利用Sqlite数据库的insert,query,update,delete函数以及execSql,rawQuery函数执行插入,查询,更新,删除操作花费时间的对比结果 ...

  8. 4、Android-数据存储方案(SQLite数据库存储)

    4.4.SQLite数据库存储 这是Android内置的数据库 是一款轻量级的关系型数据库 运算速度非常快.占用资源少.通常只需要几百kb的内存就够了 因而特别适合在移动端设备上使用 SQLite不仅 ...

  9. Android本地数据存储之SQLite关系型数据库 ——SQLiteDatabase

    数据库的创建,获取,执行sql语句: 框架搭建:dao 思考: 1.数据库保存在哪里? 2.如何创建数据库?如何创建表? 3.如何更新数据库?如何更改表的列数据? 4.如何获取数据库? 5.如何修改数 ...

随机推荐

  1. Flask中current_app和g对象

      Flask零基础到项目实战(七)请求方法.g对象和钩子函数 一.get方法 二.post方法 post请求在模板中要注意几点: input标签中,要写name来标识这个value的key,方便后台 ...

  2. 阶段5 3.微服务项目【学成在线】_day04 页面静态化_12-页面静态化-页面静态化流程

    需要知道数据结构,然后去做模板标签.首先需要获取页面的数据模型.下面的每一条记录都代表一个页面. 比如这个轮播图.就需要提前给这个轮播图编写一个模板 有很多的页面如果知道每个页面的dataUrl.例如 ...

  3. vim 全局替换

    :%s/foo/bar/g 把全部foo替换为bar,全局替换

  4. mysql left join对于索引不生效的问题

    SELECT t.val, m.username FROM  test.tmp_table AS t LEFT JOIN cehome.uc_members AS m USE INDEX(`mobil ...

  5. SpringBoot: 14.异常处理方式4(使用SimpleMappingExceptionResolver处理异常)(转)

    修改异常处理方法3中的全局异常处理Controller即可 package bjsxt.exception; import org.springframework.context.annotation ...

  6. 配置zabbix监控windows,cmd运行报错cannot connect to Service Manager: [0x00000005]

    错误原因: cmd运行没有管理员权限 解决: 找到cmd.exe的位置C:\Windows\System32,选中--右键--使用管理员身份运行 再通过cmd进入到zabbix_agentd文件夹进行 ...

  7. 最新 汇通达java校招面经 (含整理过的面试题大全)

    从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿. 汇通达等10家互联网公司的校招Offer,因为某些自身原因最终选择了 汇通达.6.7月主要是做系统复习.项目复盘.Leet ...

  8. qt坐标系统见解

    窗口坐标为逻辑坐标,是基于视口坐标系的. 视口坐标为物理坐标,是基于绘图设备坐标系的 窗口坐标始终以视口坐标为最终目标进行映射: QPainter::setWindow 修改了窗口位置和大小(左上角重 ...

  9. VMware Windows Server 2008 R2 X64 虚拟机安装教程

    首先进入VMware Workstation中,点击创建新的虚拟机 然后按如下步骤操作 然后进去选择拷贝的Windows 2008的映像文件 下面这个网址里面提供了各种映像文件的下载http://is ...

  10. <cctype>的用法

    #include<cctype> 1.isalnum() 检查字符c是十进制数还是大写还是小写字母.如果是,则返回true:如果不是,则返回false. 2.isalpha() 检查字符c ...