SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源的世界著名数据库管理系统来讲,它的处理速度比他们都快。SQLite第一个Alpha版本诞生于2000年5月。 至2015年已经有15个年头,SQLite也迎来了一个版本 SQLite 3已经发布。
下面简单介绍其在安卓中的应用:
1.首先自己写一个类MyOpenHelper继承SQLiteOpenHelper,SQLiteOpenHelper是抽象类,需要重写构造方法和实现两个方法。如下:
package com.example.sqlite; import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper; public class MyOpenHelper extends SQLiteOpenHelper { /**
* 重写构造方法,因为父类没有无参构造方法
* @param context
* @param name
* @param factory
* @param version
*/
public MyOpenHelper(Context context, String name, CursorFactory factory,
int version) {
super(context, name, factory, version);
} /**
* 数据库创建时,此方法会调用
*/
@Override
public void onCreate(SQLiteDatabase db) {
System.out.println("数据库被创建了");
db.execSQL("create table person(_id integer primary key autoincrement," +
" name varchar(10), salary varchar(20), phone integer(20))");
} /**
* 数据库升级时,此方法被调用
*/
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
System.out.println("数据库升级了");
} }
2.在测试类中进行测试,增删改查,下面演示第一种,自己写SQL语句:
package com.example.sqlite.test; import com.example.sqlite.MyOpenHelper; import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.test.AndroidTestCase; public class TestCase extends AndroidTestCase { private MyOpenHelper oh;
private SQLiteDatabase db; /**
* 测试创建数据库
* 即使运行两遍,也只会创建一次数据库
*/
public void test1(){
MyOpenHelper oh = new MyOpenHelper(getContext(), "people.db", null, 1);
//如果数据库不存在,先创建数据库,再获取可读可写的数据库对象,如果数据库存在,就直接打开
SQLiteDatabase db = oh.getWritableDatabase();
//返回的和上面的没区别,除非内部存储空间满了,返回只读数据库
//SQLiteDatabase db = oh.getReadableDatabase();
} /**
* 测试框架初始完毕之后,在测试方法执行之前,此方法调用
*/
@Override
protected void setUp() throws Exception {
super.setUp();
oh = new MyOpenHelper(getContext(), "people.db", null, 1);
db = oh.getWritableDatabase();
}
/**
* 测试方法执行之后,此方法调用
*/
@Override
protected void tearDown() throws Exception {
super.tearDown();
db.close();
} /**
* 测试插入
*/
public void test2(){
db.execSQL("insert into person(name, salary, phone) values(?,?,?)",
new Object[]{"陈驰","15000",151762});
} /**
* 测试删除
*/
public void test3(){
db.execSQL("delete from person where name=?", new Object[]{"陈驰"});
} /**
* 测试更新
*/
public void test4(){
db.execSQL("update person set phone=? where name=?",new Object[]{123456, "陈驰"});
} /**
* 测试查询
*/
public void test5(){
//注意,API变了,第二个参数是sql语句中?的填充
Cursor cursor = db.rawQuery("select name, salary from person", null);
while(cursor.moveToNext()){
//通过列索引获取列的值
String name = cursor.getString(cursor.getColumnIndex("name"));
String salary = cursor.getString(cursor.getColumnIndex("salary"));
System.out.println(name+",,,"+salary);
}
} }
3.在测试类中进行测试,增删改查,下面演示第二种,调用API:
public void insertApi(){
//把要插入的数据全部封装至ContentValues对象
ContentValues values = new ContentValues();
values.put("name", "陈掣");
values.put("salary", "16000");
values.put("phone", 15176290645L);
//返回的是最新插入的主键值(表名,填写null就行<只有在values为空才有用>,插入的内容)
long id = db.insert("person", null, values);
System.out.println(id);
} public void deleteApi(){
//返回的是删除的行数(表名,条件,条件中?的填充)
int rows = db.delete("person", "name=? and _id=?", new String[]{"陈驰", "10"});
System.out.println(rows);
} public void updateApi(){
ContentValues values = new ContentValues();
values.put("salary", "777777");
//返回的是受影响的行数(表名,更改的内容,条件,条件中?的填充)
int rows = db.update("person", values, "_id=?", new String[]{"7"});
System.out.println(rows);
} public void selectApi(){
//(表名,查询字段<null为所有字段>,查询条件,查询条件中?的填充,groupby,having,orderby,limit)
Cursor cursor = db.query("person", null, "name=?", new String[]{"陈掣"},
null, null, null, null);
while(cursor.moveToNext()){
String name = cursor.getString(cursor.getColumnIndex("name"));
String salary = cursor.getString(cursor.getColumnIndex("salary"));
String phone = cursor.getString(cursor.getColumnIndex("phone"));
System.out.println(name+","+salary+","+phone);
}
}
以上就是简单的增删改查操作,可以下载一个SQLite Expert可视化工具进行查看。
4.事务管理,模拟一个转账的例子
public void transaction(){
try {
//开启事务
db.beginTransaction(); ContentValues values = new ContentValues();
values.put("salary", "19000");
db.update("person", values, "_id=?", new String[]{"11"}); values.clear();
values.put("salary", "13000");
db.update("person", values, "_id=?", new String[]{"12"}); //int i = 2/0; //如果在这里抛异常,则设置事务执行成功的代码不会执行,sql语句回滚,update不生效
//设置事务执行成功
db.setTransactionSuccessful();
} catch (Exception e) {
e.printStackTrace();
} finally {
//关闭事务,同时提交,如果已经设置事务执行成功,那么sql语句就生效了,反之,sql语句回滚
db.endTransaction();
}
}
SQLite数据库的基本操作的更多相关文章
-
iOS: sqlite数据库的基本操作
介绍: sqlite3(3是版本)是本地系统中的一个小型数据库,因为它没有在数据维护和安全上做过多的操作,所以它存储处理数据时,非常简单方便,但是它是不安全和不可靠的,如果一旦误操作删除了数据,是没有 ...
-
android SQLite数据库的基本操作
SQLite是Android使用的轻量级的数据库,开发Android应用是对数据库的操作自然是必不可少. Android提供了一个SQLiteOpenHelper类来可以很方便的操作数据库, 继承和扩 ...
-
windows phone 8.1开发SQlite数据库操作详解
原文出自:http://www.bcmeng.com/windows-phone-sqlite1/ 本文小梦将和大家分享WP8.1中SQlite数据库的基本操作:(最后有整个示例的源码)(希望能通过本 ...
-
android 一个SQLite数据库多个数据表的基本使用框架 (带demo)
android 一个SQLite数据库多个数据表(带demo) 前言 demo演示 一.搭建 二.建立实体类 三.建立数据库操作类 ...
-
SQLite数据库基本操作
SQLite 是一个开源的嵌入式关系数据库,实现自包容.零配置.支持事务的SQL数据库引擎. 其特点是高度便携.使用方便.结构紧凑.高效.可靠. 与其他数据库管理系统不同,SQLite 的安装和运行非 ...
-
基于.NET C#的 sqlite 数据库 ORM 【Easyliter】
因为工作原因经常用到SQLITE数据库,但又找不到好用的ORM所以自个整理了一个简单好用的轻量极ORM框架:Easyliter 功能介绍: 1.支持SQL语句操作 2.支持 List<T> ...
-
2014-08-01 ASP.NET中对SQLite数据库的操作——ADO.NET
今天是在吾索实习的第18天.我主要学习了如何在ASP.NET中对SQLite数据库的操作,其基本操作如下: 添加引用System.Data.SQLite.dll(PS:在网页里面任意找到适合的.NET ...
-
IOS开发-UI学习-sqlite数据库的操作
IOS开发-UI学习-sqlite数据库的操作 sqlite是一个轻量级的数据库,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了,而且它的处理速度比Mysql.PostgreSQL这 ...
-
Android数据存储引擎---SQLite数据库
目标:是否可以在PC端桌面上使用SQLite数据库制作一个财务文件? 目录: 来源: 实践: 总结和比较: SQLite数据简介 是什么,内部结构是怎样的,数据库和表的关系是什么 有什么用 常用的操作 ...
随机推荐
-
UITabBarButton 点击失效问题
开发过程: 在创建一个UIWindow时,直接在window上添加手势动作. 开发代码: UITapGestureRecognizer *tapRecognizer=[[UITapGestureRec ...
-
cygwin远程操作linux
远程登录 1.ssh <username>@<IP> eg:ssh root@10.20.30.255 2.输入密码就OK 远程拷贝 1.scp -r <username ...
-
T-SQL中的透视和逆透视
透视 今天抽一点时间来看看透视和逆透视语句,简单的说就是行列转换.假设一个销售表中存放着产品号,产品折扣,产品价格三个列,每一种产品号可能有多种折扣,每一种折扣只对应一个产品价格.下面贴出建表语句和插 ...
-
POJ 3076 Sudoku (dancing links)
题目大意: 16*16的数独. 思路分析: 多说无益. 想说的就是dancing links 的行是依照 第一行第一列填 1 第一行第二列填 2 -- 第一行第十五列填15 第一行第二列填 1 -- ...
-
java通用抹去魔,在边界行动,擦除补偿
java通用抹去魔 package org.rui.generics.erasure; public class HasF { public void f(){ System.out.println( ...
-
linux的运行级别
一.linux共有七种运行级别,内容如下: 级别0:停机状态,系统默认运行级别如果设为0,将不能正常启动: 级别1:单用户模式,只允许root用户对系统进行维护: 级别2:多用户模式,但没有NFS(h ...
-
Ubuntu彻底删除mysql
删除 mysql sudo apt-get autoremove --purge mysql-server-5.0sudo apt-get remove mysql-serversudo apt-ge ...
-
如何在 FineUIMvc 中引用第三方 JavaScript 库
声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. 引入第三方颜色选择器 在 FineUIMvc 中使用第三方 JavaScript 遵循一定的约定,也非常简单. 下面以官网示例为 ...
-
解决打开png图片黑屏问题(批量还原Xcode优化后的png)
window 打开Xcode 里面的png图片会黑屏,但是在mac 打开就显示正常, 这是因为Xocde里面的png图片被 pngcrush 优化过了,需要还原它的优化,window 平台才可以打开. ...
-
XSS攻击(出现的原因、预防措施......)
验证XSS攻击重点不是去查找可输入哪些内容会出现什么样的bug就是测试XSS攻击,重点是了解它出现的原理,为什么会出现XSS攻击,导致一些问题出现?如何防御与解决XSS攻击?以下我将简单介绍以上提出的 ...