一、SQLiteOpenHelper类

  android 提供类SQLiteOpenHelper帮助用户简化对SQLite数据库的操作。该类是一个抽象类,必须用户自己实现并重写oncreate()和onUpGrade()方法;此外,还必须重写构造方法。构造方法包括上下文,数据库名称,版本等形参。

  SQLiteOpenHelper提供两个方法获取数据库:getWriteableDatabase()方法,和getReadableDatabase(),这两个方法都返回一个SQliteDatabase对象,如果该对象不存在就调用onCreate方法创建一个。

二、SQLiteDatabase

  获取到SQLiteDatabase后可以任意操纵数据库了,

  2.1 调用execSQL("xxx")直接执行SQL命令,例如:

    execSQL(“create table book(id integer primary key autouincrement, author text, price real,pages integer)”)创建一张名为book的表格。

    execSQL(" drop table if exists book")如果book表存在就删除它。

    insert(“book”,null ,contentValue),向book表中添加数据,数据由contentValue描述。contentValue 有很多put方法,接收一个键与对应的值,其中键为表中的列。

  2.2 向表中添加数据

    insert(“book”,null ,contentValue),向book表中添加数据,数据由contentValue描述。contentValue 有很多put方法,接收一个键与对应的值,其中键为表中的列。

  2.3 更新表中的数据

    updata("book","data","name = ?",new String(“the lost symbol”)),第一个参数指定要更新数据的表,第二个参数指定要更新的参数,对应列,第三个参数和第四个参数描述要删除的行。其中?是占位符,可以用地四个参数的内容指定其值。第三个参数相当于where。

  2.4 删除表中的数据

    delete("book","pages>?","500"),第一个参数对应操作的表,第二个和第三个参数描述要删除数据的行。

  2.5 查询数据

    SQLiteDatabase  提供一个query()方法对数据进行查询,不过query方法比较复杂。query主要包含以下参数:

      参数      对应SQL部分        描述

      table      from table_name     指定查询的表名

      columns       select column1 columns    指定查询的列名

      selection      where column=value         指定where的约束条件

      selection Args  -------------------    为where中的占位符提供具体的值

      groupBy    group by column     指定需要group by 的列

      having     having column=value   对group by 的结果进一步的约束

      orderBy    order by column1,column2指定查询结果的排序方式

    调用query()方法后将返回一个Cursor对象,查询到的所有数据都将从这个对象中取出。

    例如:

    Cursor cursor = db.query("book",null,null,null,null,null,null);
    if (cursor.moveToFirst()){
     do {
      String name = cursor.getString(cursor.getColumnIndex("name"));
      String author = cursor.getString(cursor.getColumnIndex("author"));
     int pages = cursor.getInt(cursor.getColumnIndex("pages"));
     float price = cursor.getFloat(cursor.getColumnIndex("price"));
      Log.d("MainActivity","书名" +name);
     Log.d("MainActivity","作者" +author);
     Log.d("MainActivity","页数" +pages);
     Log.d("MainActivity","价格" +price);
    }while (cursor.moveToNext());
     cursor.close();
    }
三、使用SQL操作数据库
  直接使用SQL操作数据库,示例:
  3.1 添加数据
    db.execSQL("insert into book (name ,author,pages,price) values(?,?,?,?)",new String[]{"The Da vinci Code","Dan Brown","520","19.9"});
  3.2 更新数据
    db.execSQL("updata book set price = ?where name = ?",new String[]{"9.9","The Da vinci Code"});

    3.3 删除数据

      db.execSQL(“delete from book where pages>? where name = ?”,new String[]{"500","The Da vinci Code"});

   3.4 查询数据

    db.rawQuery("select * from book",null);

SQLiteDatabase 基本操作的更多相关文章

  1. Android Sqlite 工具类封装

    鉴于经常使用 Sqlite 数据库做数据持久化处理,进行了一点封装,方便使用. 该封装类主要支持一下功能 支持多用户数据储存 支持 Sqlite数据库升级 支持传入 Sql 语句建表 支持 SQLit ...

  2. android SQLite数据库的基本操作

    SQLite是Android使用的轻量级的数据库,开发Android应用是对数据库的操作自然是必不可少. Android提供了一个SQLiteOpenHelper类来可以很方便的操作数据库, 继承和扩 ...

  3. android 使用SQLite的基本操作

    Android操作数据库SQLite使用sql语句基本操作 1:自定义自己的SQLiteOpenHelper public class DBHelper extends SQLiteOpenHelpe ...

  4. Key/Value之王Memcached初探:二、Memcached在.Net中的基本操作

    一.Memcached ClientLib For .Net 首先,不得不说,许多语言都实现了连接Memcached的客户端,其中以Perl.PHP为主. 仅仅memcached网站上列出的语言就有: ...

  5. Android Notification 详解(一)——基本操作

    Android Notification 详解(一)--基本操作 版权声明:本文为博主原创文章,未经博主允许不得转载. 微博:厉圣杰 源码:AndroidDemo/Notification 文中如有纰 ...

  6. Android Notification 详解——基本操作

    Android Notification 详解 版权声明:本文为博主原创文章,未经博主允许不得转载. 前几天项目中有用到 Android 通知相关的内容,索性把 Android Notificatio ...

  7. 三、Redis基本操作——List

    小喵的唠叨话:前面我们介绍了Redis的string的数据结构的原理和操作.当时我们提到Redis的键值对不仅仅是字符串.而这次我们就要介绍Redis的第二个数据结构了,List(链表).由于List ...

  8. 二、Redis基本操作——String(实战篇)

    小喵万万没想到,上一篇博客,居然已经被阅读600次了!!!让小喵感觉压力颇大.万一有写错的地方,岂不是会误导很多筒子们.所以,恳请大家,如果看到小喵的博客有什么不对的地方,请尽快指正!谢谢! 小喵的唠 ...

  9. 一、Redis基本操作——String(原理篇)

    小喵的唠叨话:最近京东图书大减价,小喵手痒了就买了本<Redis设计与实现>[1]来看看.这里权当小喵看书的笔记啦.这一系列的模式,主要是先介绍Redis的实现原理(可能很大一部分会直接照 ...

随机推荐

  1. Android 自定义ListView

    本文讲实现一个自定义列表的Android程序,程序将实现一个使用自定义的适配器(Adapter)绑定 数据,通过contextView.setTag绑定数据有按钮的ListView. 系统显示列表(L ...

  2. jquery jQuery-File-Upload 例子

    网上jquery-file-upload的例子 都过于简单,在项目中这个插件经常使用,写个例子供参考. 下面介绍 用插件实现图片异步上传的代码. 1   比要的js一个都不能少,他们之间是有依赖关系的 ...

  3. Cassandra 键空间(keyspace),表(table)

    查看用户下信息: describe cluster; desc cluster;   查看所有keyspace: describe keyspaces; desc keyspaces;   查看key ...

  4. webstorm修改文件,webpack-dev-server不会自动编译刷新

    重装了 webstorm ,从10升级到了2016 一升不要紧,打开老项目,开启webpakc-dev-server,然后改代码,发现浏览器不会自动刷新了!!! 这可急死我了,各种卸载webpack. ...

  5. 渗透日记-POST注入

    今晚给一个网站做了一次入侵检测,首先进行信息刺探后,发现这个站有注入策略,所有页面都没法通过常规的注入,利用wvs扫描网站发现一个页面. 这个页面直接暴露出了错误信息,看了一下url没有参数却爆出了错 ...

  6. iOS简单动画

    知识架构 CALayer 图层类 CABasicAnimation 基础动画 CAKeyFrameAnimation 帧动画 CATransition 转场动画 CAAnimationGroup 动画 ...

  7. PHP开发环境配置~Windows 7 IIS

    1.配置IIS添加角色服务:CGI.ISAPI扩展.ISAPI筛选器 2.下载PHP安装包 http://windows.php.net/download/ 3.添加模块映射 4.配置php.ini ...

  8. NCreport报表控件教程:设计页眉和页脚

    一.设计页眉 一般来说页眉部分一般是用于包含标题的内容, 首先我们会添加列标签到页眉部分,标签都是简单的文本,标签项一般是用于在报表上显示一些描述信息,标签都是静态项,所以它们的值不会有变化. 添加标 ...

  9. CentOS 6.5 安装HDFS集群(Hadoop-2.7.3)

    安装真实集群,而不是但节点或者伪分布式,以3个节点为例,node1为NameNode和SecondNameNode,node2和node3为DataNode. 1.3台机器的配置必须要一模一样,只需要 ...

  10. Don't make a promise when you are in Joy. Don't reply when you are Sad.Don't take decisions when you are Angry.Think Twice.Act Wise.

    Don't make a promise when you are in Joy. Don't reply when you are Sad.Don't take decisions when you ...