首页 > 基础学习总结(四)--SQLite

基础学习总结(四)--SQLite

1. SQLiteDatabase
操作SQLite数据库的类。可以执行SQL语句,对数据库进行增、删、查、改的操作。也可以进行transaction的控制。很多类对数据库的操作最终都是通过SQLiteDatabase实例来调用执行的。
需要注意的是,数据库对于一个应用来说是私有的,并且在一个应用当中,数据库的名字也是惟一的。
2. SQLiteOpenHelper
创建数据库和数据库版本管理的辅助类。这是一个抽象类,所以我们一般都有一个SQLiteOpenHelper子类,需要继承实现
· void onCreate(SQLiteDatabase db)
在数据库第一次生成的时候会调用这个方法,一般我们在这个方法里边生成数据库表。
· void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
当数据库需要升级的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据表,并建立新的数据表,当然是否还需要做其他的操作,完全取决于应用的需求。
而void onOpen(SQLiteDatabase db) 则可以选择重写。同时此类还有3个synchronized方法:void close(),SQLiteDatabasegetReadableDatabase(),SQLiteDatabasegetWritableDatabase()。
3. Cursor
游标。要注意这是一个接口。但很多时候我不需要知道它具体是哪个子类,直接按照API Doc里面提供的方法调用就行了。通过Cursor 我们可以对从数据库查询出来的结果集进行随机的读写访问。对于数据库的查询结果,一般是由子类SQLiteCursor返回的。

1. 加载驱动.

2. 连接数据库.

3. 操作数据库.

SQLite:一款轻量级的数据库,除了主键(Primark key)需要设置为Integer类型且填充数据必须是integer类型,其它字段均任意类型填充

字段属性与语法sqlserver类似,但无关键字

在android系统中提供了SQLiteOpenHelper抽象类,用于版本管理与操作:

onCreate:数据库创建时执行

onUpgrade:数据库更新版本时执行

onOpen:数据库打开连接时执行

实现SQLiteOpenHelper抽象类

 1 /*
 2  * 数据库帮助类
 3  * */
 4 public class PersonSQLiteOpenHelper extends SQLiteOpenHelper {
 5 
 6     
 7     public PersonSQLiteOpenHelper(Context context) {
 8         //super(context, name, factory, version);
 9         /*
10          * context 上下文
11          * name    数据库名
12          * factory游标工厂
13          * version 版本,必须大于1*/
14         super(context, "cuiOne.db", null, 1);
15         // TODO Auto-generated constructor stub
16     }
17 
18     //数据库第一次创建时回调此方法
19     //初始化一些表
20     @Override
21     public void onCreate(SQLiteDatabase db) {
22         // TODO Auto-generated method stub
23         String sql="create table Person(_id integer primary key,age integer,name varchar(20));";
24         db.execSQL(sql);
25         
26     }
27 
28     //数据库的版本号更新时回调此 方法,
29     //更新数据库内容
30     @Override
31     public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
32         // TODO Auto-generated method stub
33 
34     }
35 
36 }
View Code

 

使用sql语句实现数据的insert、query

 1 public class Persondao {
 2     PersonSQLiteOpenHelper mOpenHelper;//成员变量
 3     
 4     public Persondao(Context context){
 5         mOpenHelper=new PersonSQLiteOpenHelper(context);
 6     }
 7     
 8     public void insert(Person p){
 9         //赋给db写入权限
10         SQLiteDatabase db= mOpenHelper.getWritableDatabase();
11         //判断数据库状态是否为打开状态
12         if(db.isOpen()){
13             db.execSQL("insert into person(name,age) values(?,?);", new Object[]{p.getName(),p.getAge()});
14             db.close();
15         }
16     }
17     
18     public List queryAll(){
19         SQLiteDatabase db=mOpenHelper.getReadableDatabase();
20         if(db.isOpen()){
21             Cursor rawCur = db.rawQuery("select _id,age,name from Person", null);
22             if(rawCur!=null&&rawCur.getCount()>0){
23                 List list=new ArrayList();
24                 int id;int age;String name;
25                 while(rawCur.moveToNext()){
26                      id=rawCur.getInt(0);
27                      age=rawCur.getInt(1);
28                      name=rawCur.getString(1);
29                      list.add(new Person(id,age,name));
30                 }
31                 db.close();
32                 return list;
33             }
34             db.close();
35         }
36         return null;
37     }
38     
39     public     Person queryItem(int id){
40         SQLiteDatabase db=mOpenHelper.getReadableDatabase();
41         if(db.isOpen()){
42             Cursor cur=db.rawQuery("select _id,age,name from Person where _id=?;", new String[]{String.valueOf(id)});
43             //判断游标在移动到下一个位置时是否有值
44             if(cur!=null&&cur.moveToFirst()){
45                 int _id=cur.getInt(0);
46                 int age=cur.getInt(1);
47                 String name=cur.getString(2);
48                 db.close();
49                 return new Person(_id,age,name);
50             }
51             db.close();
52         }
53         return null;
54         
55     }
56 }
View Code

使用SQLite工具类实现i,d,u,q

public class PersonDao2 {private static final String TAG = "PersonDao2";private PersonSQLiteOpenHelper mOpenHelper;    // 数据库的帮助类对象public PersonDao2(Context context) {mOpenHelper = new PersonSQLiteOpenHelper(context);}/*** 添加到person表一条数据* @param person*/public void insert(Person person) {SQLiteDatabase db = mOpenHelper.getWritableDatabase();if(db.isOpen()) {    // 如果数据库打开, 执行添加的操作
            ContentValues values = new ContentValues();values.put("name", person.getName());        // key作为要存储的列名, value对象列的值values.put("age", person.getAge());long id = db.insert("person", "name", values);Log.i(TAG, "id: " + id);db.close();    // 数据库关闭
        }}/*** 更据id删除记录* @param id*/public void delete(int id) {SQLiteDatabase db = mOpenHelper.getWritableDatabase();    // 获得可写的数据库对象if(db.isOpen()) {    // 如果数据库打开, 执行添加的操作
            String whereClause = "_id = ?";String[] whereArgs = {id + ""};int count = db.delete("person", whereClause, whereArgs);Log.i(TAG, "删除了: " + count + "行");db.close();    // 数据库关闭
        }}/*** 根据id找到记录, 并且修改姓名* @param id* @param name*/public void update(int id, String name) {SQLiteDatabase db = mOpenHelper.getWritableDatabase();if(db.isOpen()) {    // 如果数据库打开, 执行添加的操作ContentValues values = new ContentValues();values.put("name", name);int count  = db.update("person", values, "_id = ?", new String[]{id + ""});Log.i(TAG, "修改了: " + count + "行");db.close();    // 数据库关闭
        }}public List queryAll() {SQLiteDatabase db = mOpenHelper.getReadableDatabase();    // 获得一个只读的数据库对象if(db.isOpen()) {String[] columns = {"_id", "name", "age"};    // 需要的列String selection = null;    // 选择条件, 给null查询所有String[] selectionArgs = null;    // 选择条件的参数, 会把选择条件中的? 替换成数据中的值String groupBy = null;    // 分组语句  group by nameString having = null;    // 过滤语句String orderBy = null;    // 排序
            Cursor cursor = db.query("person", columns, selection, selectionArgs, groupBy, having, orderBy);int id;String name;int age;if(cursor != null && cursor.getCount() > 0) {List personList = new ArrayList();while(cursor.moveToNext()) {    // 向下移一位, 知道最后一位, 不可以往下移动了, 停止.id = cursor.getInt(0);name = cursor.getString(1);age = cursor.getInt(2);personList.add(new Person(id, name, age));}db.close();return personList;}db.close();}return null;}/*** 根据id查询人* @param id* @return*/public Person queryItem(int id) {SQLiteDatabase db = mOpenHelper.getReadableDatabase();    // 获得一个只读的数据库对象if(db.isOpen()) {String[] columns = {"_id", "name", "age"};    // 需要的列String selection = "_id = ?";    // 选择条件, 给null查询所有String[] selectionArgs = {id + ""};    // 选择条件的参数, 会把选择条件中的? 替换成数据中的值String groupBy = null;    // 分组语句  group by nameString having = null;    // 过滤语句String orderBy = null;    // 排序
            Cursor cursor = db.query("person", columns, selection, selectionArgs, groupBy, having, orderBy);if(cursor != null && cursor.moveToFirst()) {        // cursor对象不为null, 并且可以移动到第一行int _id = cursor.getInt(0);String name = cursor.getString(1);int age = cursor.getInt(2);db.close();return new Person(_id, name, age);}db.close();}return null;}
}

事务的使用:

// 开启事务

db.beginTransaction();

// 标记事务成功

db.setTransactionSuccessful();

// 停止事务

db.endTransaction();

转载于:https://www.cnblogs.com/cuijl/p/4582311.html

更多相关:

  •     先吐为敬!   最近心血来潮研究nodejs如何完成微信支付功能,结果网上一搜索,一大堆“代码拷贝党”、“留一手”、“缺斤少两”、“不说人话”、“自己都没跑通还出来发blog”、“各种缺少依赖包”、“各种注释都没有”、“自己都不知道在写什么”的程序大神纷纷为了增加自己博客一个帖子的名额而发布了各种千奇百�...

  • 阅读ceph源码过程中需要明确当前操作是由哪个线程发出,此时需要根据线程id来确认线程名称 C++获取线程id是通过系统调用来直接获取 函数描述 头文件: 函数名称:syscall(SYS_gettid) 该函数直接返回了一个pid_t int类型的数字,即为当前线程id 此外函数pthread_s...

  • 面试题 分库分表之后,id 主键如何处理? 面试官心理分析 其实这是分库分表之后你必然要面对的一个问题,就是 id 咋生成?因为要是分成多个表之后,每个表都是从 1 开始累加,那肯定不对啊,需要一个全局唯一的 id 来支持。所以这都是你实际生产环境中必须考虑的问题。 面试题剖析 基于数据库的实现方案 数据库自增 id 这个就是说你的...

  • ORM操作    单表、一对多表操作 1 from django.db import models 2 3 4 class UserGroup(models.Model): 5 title = models.CharField(max_length=32) 6 7 8 class UserInfo(m...

  • 建立如下表: 建表语句: class表创建语句 create table class(cid int not null auto_increment primary key, caption varchar(32) not null)engine=innodb default charset=utf8;student表创建语句 c...

  • 【知识点梳理】 ________________________ 一、熟练Spring操作数据库 bean → IoC:控制反转 完成实现类的单例生成 property → DI:依赖注入 各种属性(属性类ref) DI 注入方式 → 1、setter注入;2、构造器注入;3、注解注入 _______________________...

  • 安装数据库 安装数据库的时候我们需要安装三个软件,使用下面的命令,可能还会出现一些问题,关于数据库的安装,大家可以上网自行百度 yum install mysql yum install mysql-server yum install mysql-devel 我个人的理解大概是这个样子的,我们首先需要在自己的操作系统里面安装m...

  • 1.SQL的定义 结构化查询语言(Structured Query Language)简称SQL,SQL语句就是对数据库进行操作的一种语言。   2.SQL的作用 通过SQL语句我们可以方便的操作数据库中的数据、表、数据库等。 3.SQL的分类 1. DDL(Data Definition Language)数据定义语言用来定义数据库...

  • 云计算时代的高可用数据库是可扩展、容错且与任何私有云或公共云兼容的数据库实例。它们旨在提供业务连续性,而不会因任何类型的硬件或网络故障而导致用户体验的影响。其核心设计原则是消除任何单点故障,并提供平稳的故障转移体验。 公共云和私有云使企业能够摆脱容易出错的传统架构,并运行具有可靠性为5个9和6个9的应用程序。业务应用程序可以按需、即...

  • java的代码就不说了,毕竟不是我的主业。 1.c#数据库连接池Hikari.    (1)动态加载各类数据库驱动   (2)支持简单配置文件 (3)支持按照名称多数据库调用 (4)使用简洁  单数据库使用: HikariConfig hikariConfig = new HikariConfig(); hikariConfig.L...

  • 引言 在这个-SLAM建图和导航仿真实例-项目中,主要分为三个部分,分别是 (一)模型构建(二)根据已知地图进行定位和导航(三)使用RTAB-MAP进行建图和导航 该项目的slam_bot已经上传我的Github。 这是第三部分,完成效果如下 图1 建图和导航 三、使用RTAB-Map进行建图和导航 1. rtab...

  • 引言 在这个-SLAM建图和导航仿真实例-项目中,主要分为三个部分,分别是 (一)模型构建(二)根据已知地图进行定位和导航(三)使用RTAB-MAP进行建图和导航 该项目的slam_bot已经上传我的Github。 由于之前的虚拟机性能限制,我在这个项目中使用了新的ubantu 16.04环境,虚拟机配置 内存 8GCPU...

  • [{name:1},{name:2}].forEach((v,i,ar) => {console.log(v,i,ar)});//基础遍历[{name:1},{name:2}].map((v) => v.name);//[1,2]返回对象数组中指定字段值的一位数组(不改变原始数组)[{name:1},{name:2},{name:3}...

  • 体验内容 使用gmapping方法利用turtlebot底盘移动信息和激光雷达数据进行建图。 1. 安装一些依赖包 sudo apt-get install ros-melodic-move-base* sudo apt-get install ros-melodic-map-server* sudo apt-get insta...

  • 前言 我们知道Java/Python这种语言能够很好得 支持反射。反射机制 就是一种用户输入的字符串到对应实现方法的映射,比如http接口中 用户传入了url,我们需要调用该url对应的方法/函数对象 从而做出对应的操作。 而C++ 并没有友好得支持这样的操作,而最近工作中需要通过C++实现http接口,这个过程想要代码实现得优雅...