当前位置: 首页 > 编程日记 > 正文

基础学习总结(四)--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<Person> 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<Person> list=new ArrayList<Person>();
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<Person> 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<Person> personList = new ArrayList<Person>();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

相关文章:

用node实现websocket协议

协议 WebSocket是一种基于TCP之上的客户端与服务器全双工通讯的协议&#xff0c;它在HTML5中被定义&#xff0c;也是新一代webapp的基础规范之一。 它突破了早先的AJAX的限制&#xff0c;关键在于实时性&#xff0c;服务器可以主动推送内容 到客户端&#xff01;可能的应用有&a…

反向春运成为新趋势 客流年增9%

资料图&#xff1a;春运。殷立勤 摄 中新社北京1月18日电 (记者 周音)近年来&#xff0c;反向春运成为新趋势。中国铁路总公司18日披露&#xff0c;反向春运客流以年增9%左右的速度增长。 传统春运是大城市返乡回家过年。反向春运是年轻人选择将老家的父母和孩子接来自己工作的…

把.sql文件上传到服务器上

使用xftp工具&#xff0c;在root文件夹下新建myProject文件夹&#xff0c;然后把.sql文件拖拽过去即可。 进入xshell&#xff0c; 进入到mysql&#xff1a; mysql -u root -p输入密码&#xff1a; create database 数据库名&#xff1b;use 数据库名&#xff1b;source ~/新…

最先进的开源游戏引擎KlayGE 3.12.0发布

转载请注明出处为KlayGE游戏引擎&#xff0c;本文地址为http://www.klayge.org/2011/06/30/%e6%9c%80%e5%85%88%e8%bf%9b%e7%9a%84%e5%bc%80%e6%ba%90%e6%b8%b8%e6%88%8f%e5%bc%95%e6%93%8eklayge-3-12-0%e5%8f%91%e5%b8%83/ KlayGE 3.12.0在上半年的最后一天发布了&#xff01…

如何防止博客文章被窃取

写文章的优点&#xff1a; 1.整理自己的学习过程&#xff0c;思想心得。 2.看到自己的文章被别人转载了&#xff0c;心理愉悦&#xff0c;说明作者写的文章有价值&#xff0c;可以帮助他人。 缺点&#xff1a; 1.花费时间和精力。 2.说是抄袭别人。明明自己是原创&#xff0c;别…

js中的装饰器执行顺序

/*** 执行顺讯* [(property)...]->[(parameter->method)...]->constructor->class* [属性...]->[((方法参数...)->方法)...]->[constructor...]->class* 声明周期 property|parameter|method|constructor|class* 声明周期 [始化完毕]init->[属性添加…

关于springboot vue前后端分离项目部署到阿里云轻量服务器(前后端分开部署)

0.购买阿里云服务器 1.安装jdk 使用yml安装 2.安装mysql 3.安装nginx 4.打包后端项目 后端项目更改&#xff1a; 在pom.xml文件中&#xff0c;增加打包成jar包的配置文件 application.properties配置文件中更改数据库信息&#xff0c;端口号&#xff1a;&#xff08;所使…

.NET泛型解析(下)

上一篇对.NET中的泛型进行了详细的介绍以及使用泛型的好处是什么,这篇将更加深入的去了解泛型的其他的知识点,重头戏. 【1】泛型方法 上一篇我们也说过了,泛型可以是类,结构,接口,在这些泛型类型中定义的方法都可以叫做泛型方法,都可以引用由泛型类型本身指定的一个类型参数例如…

spark集群使用hanlp进行分布式分词操作说明

本篇分享一个使用hanlp分词的操作小案例&#xff0c;即在spark集群中使用hanlp完成分布式分词的操作&#xff0c;文章整理自【qq_33872191】的博客&#xff0c;感谢分享&#xff01;以下为全文&#xff1a;分两步&#xff1a;第一步&#xff1a;实现hankcs.hanlp/corpus.io.IIO…

让VirtualBox的虚拟机器在电脑开机时自动启动

当你安装很多套Virtualbox的虚拟机器系统后&#xff0c;希望能在开机后自动启动虚拟机器的系统。 Linux (Host OS):在你的/etc/rc.local中加入下列几行VBoxVRDP -startvm WinXP & VBoxVRDP -startvm Win2003 & VBoxVRDP -startvm LinuxFC6 & Windows (Host OS): 开…

L1-025 正整数A+B

不确定的点&#xff1a; 1.数据用什么类型输入&#xff0c;如果用字符串类型输入&#xff0c;怎么判断它是不是正整数 2.怎么判断哪部分是A&#xff0c;哪部分是B 解析 c语言’\0’ 意思&#xff1a; 字符常量占一个字节的内存空间。字符串常量占的内存字节数等于字符串中字节…

制作显示欢迎信息的脚本程序

终端程序恐怕是Linux用户使用最为频繁的了。我的Debian系统启动后便是直接进入的终端界面。为了在每次登录时或者是在X视窗环境下打开终端程序时显示一些欢迎信息&#xff0c;比如当前的日期、名人警句等&#xff0c;从而可以增加一些生活情趣&#xff0c;就可以创建一个脚本程…

文章分页浏览(二)

分页的方法: View Code publicstringOutputBySize(stringp_strContent, stringbType) { stringm_strRet ""; intm_intPageSize 500;//文章每页大小 intm_intCurrentPage 1;//设置第一页为初始页 intm_intTotalPage 0; intm_intArticlelengt…

云计算时代,如何选择适合自己的云服务器厂商?

据百科定义&#xff0c;云服务器是一种处理能力可弹性伸缩的计算服务&#xff0c;帮助您快速构建更稳定、安全的应用&#xff0c;降低开发运维的难度和整体IT成本&#xff0c;使您能够更专注于核心业务的创新。云服务器相对传统服务器有些优势&#xff1a;按国内市场上云服务器…

解决mysql建立的数据库名字不能带大写字母

1、在安装目录下&#xff0c;找到 my.ini文件 2、找到 [mysqId]节点 3、在它下面添加 lower_case_table_names2如果设置为0的话&#xff0c;我的Mysql服务不能重启 4、重启Mysql 直接手动重启即可&#xff0c;在服务中&#xff0c;找到Mysql服务&#xff0c;先停止&#xff0c…

CSS position财产

CSS在position位置信息要素用于表示属性。 有三个起飞值&#xff1a;static, absolute, relative。假设元件不显式配置position财产&#xff0c;该元素默认position 值至static。 1、static&#xff1a;这是表示该元素依照排列和嵌套的顺序和规则应该在的位置&#xff0c;此时设…

通过产品ID得到collection!!!

You can do as following for filtering products id 10 and 12$products->addAttributeToFilter(entity_id, array(in>array(10,12)));当然这种方式的上面&#xff0c;必须用 ->addAttributeToSelect();下面这种方式比较实用的&#xff0c;如果想按照名字排序&#…

jupyter notebook出现cannot import name 'create_prompt_application'问题(Died Kernel)

应该是在安装其它python第三方库时更新了prompt-toolkit版本&#xff0c;降级到下面的版本即可&#xff1a; sudo pip install prompt-toolkit1.0.15 转载于:https://www.cnblogs.com/darklights/p/10302706.html

导入sql时出现Invalid default value for ‘create_time‘报错处理方法

&#xff08;上图是初始的sql文件的内容&#xff09; 在开发微信小程序时&#xff0c;需要导入.sql文件&#xff0c;但是最一开始导入的时候没有任何改动进行了导入&#xff0c;报错如下 PS E:\weichatApp\my-project\server> node tools/initdb.js 开始初始化数据库... 准…

Python相关机器学习

Python机器学习库 Python的机器学习库汇总与梳理 机器学习之开源库大总结 转载于:https://www.cnblogs.com/SFMing/p/4590261.html

Django 图片上传upload_to路径指定失效的问题记录

为什么80%的码农都做不了架构师&#xff1f;>>> 初始方法一&#xff1a; 疑虑&#xff1a;model使用upload_to自定义路径方法失效&#xff0c;指定路径也失效。最后以Views中指定MEDIA_URL和MEDIA_ROOT做拼接&#xff0c;并且自行判断并建立文件夹&#xff0c;手动…

javascript tab切换类LixTabs最新版

javascript Tab切换类LixTabs&#xff0c;更新至0.5版: 受snandy的“读jquery”系列的启发&#xff0c;改进了代码&#xff0c;现在调用LixTabs时不用加new了。即可以这样写&#xff1a;var tab Tabs();把原来的参数evt&#xff0c;改成了易理解的event(我的疏忽)总代码量&…

linux虚拟机文件挂载

把U盘中的文件上传到linux虚拟机中&#xff0c;可以采用挂载的方式。 &#xff08;1&#xff09;启动虚拟机 &#xff08;2&#xff09;把U盘插入电脑中 &#xff08;3&#xff09;输入命令 fdisk -l可以查看新的分区 &#xff08;4&#xff09; cd /mnt mkdir usb mount /d…

HDU 1757 A Simple Math Problem

Problem Description Lele now is thinking about a simple function f(x).If x < 10 f(x) x.If x > 10 f(x) a0 * f(x-1) a1 * f(x-2) a2 * f(x-3) …… a9 * f(x-10);And ai(0<i<9) can only be 0 or 1 .Now, I will give a0 ~ a9 and two positive intege…

mariadb 内存占用优化

本文由云社区发表 作者&#xff1a;工程师小熊 摘要&#xff1a;我们在使用mariadb的时候发现有时候不能启动起来&#xff0c;在使用过程中mariadb占用的内存很大&#xff0c;在这里学习下mariadb与内存相关的配置项&#xff0c;对mariadb进行调优。 查询最高内存占用 使用以下…

windows程序设计之对话框简介1

这里先介绍下wParam和lParam&#xff0c;对于鼠标而言&#xff0c;LOWORD(wParam)和HIWORD(wParam)代表鼠标位置x,y坐标&#xff0c;对于菜单和控件而言&#xff0c;两者wParam的低字节都是各自的ID&#xff0c;即LOWORD(wParam)都是ID。两者的高字节对菜单而言是0&#xff0c;…

linux虚拟机下安装Tomcat

&#xff08;1&#xff09;首先通过挂载的方式把 tomcat的安装包从U盘上传到虚拟机中 我上传的路径是 &#xff1a;usr/tomcat &#xff08;2&#xff09; cd /usr/tomcat tar xzvf 压缩包的名字 ##进行解压&#xff08;3&#xff09;进到tomcat安装目录下的bin文件夹 ./…

unity中使用自定义shader进行光照贴图烘培无法出现透明度的坑爹问题

最近开发中在对场景进行光照贴图烘焙时发现一个坑爹问题&#xff0c;在使用自定义shader的时候&#xff0c;shader命名中必须包含Transparent路径&#xff0c;否则烘焙的时候不对alpha通道进行计算&#xff0c;烘焙出来都是狗皮膏药 比如一个shader叫 Shader "xx/UnlitAlp…

动软代码生成器教程——懒人有福了

很多时候项目必须是三层架构模式&#xff0c;但是很多繁琐的代码让多数程序员闹心……那有没有一个省时省力的工具快速的帮我们搞定三层架构呢&#xff1f;回答是肯定的&#xff0c;很早之前技术牛人李天平就开发出了这么一款工具&#xff0c;目前该工具还在不断的更新&#xf…

unity3d做简单小游戏可以吗?

可以吗&#xff1f;当然。如果是独立开发&#xff0c;主要在美工&#xff0c;这类的游戏程序简单&#xff0c;有些基础就行&#xff0c;美工要做得好可不容易&#xff0c;要是效果要求不高&#xff0c;随便在max拉几个模型吧。unity方面&#xff0c;熟悉一下&#xff0c;如果有…