android开发之路09(浅谈SQLite数据库01)
1.SQLite数据库:
SQLite 是一个开源的嵌入式关系数据库,实现自包容、零配置、支持事务的SQL数据库引擎。 其特点是高度便携、使
用方便、结构紧凑、高效、可靠。 与其他数据库管理系统不同,SQLite 的安装和运行非常简单,在大多数情况下 - 只要确保
SQLite的二进制文件存在即可开始创建、连接和使用数据库。
对于SDK来讲,已经内置了SQLite的程序,因此我们不需要在SQLite官网上下载。一般数据库采用的都是静态的数据类
型,而我们的SQLite数据库采用的是动态数据库,会根据存入值自动判断。SQLite 数据库相对于其他数据库最大的特点是我们
可以把各种类型的数据保存到任何字段中,而不用关心字段声明的类型是什么。有一种特殊的情况是,定义为INTEGER PRIMARY
KEY 的字段只能存储64位整数。SQLite具有以下五种类型:
1.NULL:空值;
2.INTEGER:带符号的整形,具体取决于存入数字的范围大小;
3.REAL:浮点数字;
4.TEXT:字符串文本;
5.BLOB:二进制对象;
2.相关操作
①创建数据库:sqlite3 test.db;
②创建表:create table userInfo(userId integer primary key autoincrement,name varchar(20));
SQLite数据库可以解析大部分标准SQL语句:
①查询语句:select * from 表名 where 条件子句 group by 分组子句 having...order by 排序子句
例如:select * from userInfo order by id desc;
select * from userInfo group by name having count(*)>1
②插入语句:insert into 表名(字段列表) values(值列表)
例如:insert into userInfo(name,age) values('张三',20)
③更新语句:update 表名 set 字段名=值 where 条件子句
例如:update person set name = '张三' where id = 10
④删除语句:delete from 表名 where 条件子句
例如:delete from userInfo where id = 10
实例代码:
1.创建一个JavaBean
public class Student {
private int sid;
private String name;
private short age;
public Student() {
super();
}
public Student(int sid, String name, short age) {
super();
this.sid = sid;
this.name = name;
this.age = age;
}
public int getSid() {
return sid;
}
public void setSid(int sid) {
this.sid = sid;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public short getAge() {
return age;
}
public void setAge(short age) {
this.age = age;
}
@Override
public String toString() {
return "Student [sid=" + sid + ", name=" + name + ", age=" + age + "]";
}
}
2.创建一个用于创建SQLite数据库的类DBOpenHelper .java
public class DBOpenHelper extends SQLiteOpenHelper{
private static final String DBNAME="data.db";
private static CursorFactory factory=null;
private static final int VERSION=1;
public DBOpenHelper(Context context) {
super(context, DBNAME, factory, VERSION);
}
//当数据库第一次被创建的时候,执行该方法
@Override
public void onCreate(SQLiteDatabase db) {
//sql语句中的字段名与Student.java的成员变量对应
String sql="create table t_student (sid integer primary key,"
+ "name varchar(20),age integer)";
db.execSQL(sql);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
3.创建一个操作数据库的类StudentDAO .java
public class StudentDAO {
private DBOpenHelper helper;
private SQLiteDatabase db;
public StudentDAO(Context context) {
// 创建DBOpenHelper的实例
helper = new DBOpenHelper(context);
}
public void add(Student student) {
/**
* Android使用getWritableDatabase()和getReadableDatabase()方法都可以获取一个用于操作数据库的SQLiteDatabase实例。
* (getReadableDatabase()方法中会调用getWritableDatabase()方法)
* 1.getWritableDatabase() 方法以读写方式打开数据库,一旦数据库的磁盘空间满了,数据库就只能读而不能写.
* 2.getReadableDatabase()方法则是先以读写方式打开数据库,如果数据库的磁盘空间满了,就会打开失败,当打
* 开失败后会继续尝试以只读方式打开数据库。如果该问题成功解决,则只读数据库对象就会关闭,然后返回一个可读写的数据库对象。
*/
db = helper.getWritableDatabase();
String sql = "insert into t_student (sid,name,age) values (?,?,?)";
db.execSQL(sql, new Object[] { student.getSid(), student.getName(),
student.getAge() });
}
public void update(Student student) {
db = helper.getWritableDatabase();
String sql = "update t_student set name = ?,age = ? where sid = ?";
db.execSQL(sql, new Object[] { student.getName(), student.getAge(),
student.getSid() });
}
public Student query(int sid) {
db = helper.getWritableDatabase();
String sql = "select sid,name,age from t_student where sid=?";
// Cursor实际上就是一种存储数据的集合
Cursor cursor = db.rawQuery(sql, new String[] { String.valueOf(sid) });
// 在cursor查找到的结果集合中将光标移动到到下一行,也就是将光标指向查找到的下一个结果
if (cursor.moveToNext()) {
// 通过getColumnIndex()方法可以得到指定列的名称,如果不存在返回-1
return new Student(cursor.getInt(cursor.getColumnIndex("sid")),
cursor.getString(cursor.getColumnIndex("name")),
cursor.getShort(cursor.getColumnIndex("age")));
}
return null;
}
// 这里使用可变参数,来满足参数个数不固定的情况
public void delete(Integer... sids) {
if (sids.length > 0) {
// StringBuffer线程安全的,多用于多线程中,用来对字符串进行复杂的操作
StringBuffer sb = new StringBuffer();
for (int i = 0; i < sids.length; i++) {
sb.append('?').append(',');
}
sb.deleteCharAt(sb.length() - 1);
SQLiteDatabase database = helper.getWritableDatabase();
String sql = "delete from t_student where sid in (" + sb + ")";
database.execSQL(sql, (Object[]) sids);
}
}
public List<Student> getScrollData(int start, int count) {
List<Student> students = new ArrayList<Student>();
db = helper.getWritableDatabase();
String sql = "select * from t_student limit ?,?";
Cursor cursor = db.rawQuery(sql, new String[] { String.valueOf(start),
String.valueOf(count) });
while (cursor.moveToNext()) {
students.add(new Student(
cursor.getInt(cursor.getColumnIndex("sid")),
cursor.getString(cursor.getColumnIndex("name")),
cursor.getShort(cursor.getColumnIndex("age"))));
}
return students;
}
public long getCount(){
db=helper.getWritableDatabase();
String sql="select count(sid) from t_student";
Cursor cursor=db.rawQuery(sql,null);
if(cursor.moveToNext()){
return cursor.getLong(0);
}
return 0;
}
}
android开发之路09(浅谈SQLite数据库01)的更多相关文章
- android开发之路04(初级android工程师必会,你懂得!)
Android初级Android工程师重点掌握内容如下: 1.Android开发基础: ①UI界面设计: ②SQLite数据库: ③android四大组件: ④android网络编程: ⑤androi ...
- android开发之路02(浅谈BroadcastReceiver)
一.BroadcastReceiver (广播接收者)的作用是用来接收来自系统和应用中的广播.应用如下: 1.开机完成后系统会产生一条广播----->接收到这条广播就能实现开机启动服务的功能: ...
- android开发之路06(浅谈单例设计模式)
设计模式之单例模式: 一.单例模式实现特点:①单例类在整个应用程序中只能有一个实例(通过私有无参构造器实现):②单例类必须自己创建这个实例并且可供其他对象访问(通过静态公开的访问权限修饰的getIns ...
- Toast显示图文界面——Android开发之路1
Toast的多种使用方法 Toast其实是一个功能特别强大的组件,不仅仅可以吐司一个文本内容,还可以吐司图片以及图文混排的界面.具体用法如下: 第一种:简单的纯文本内容的吐司: Toast.makeT ...
- 菜单(Menu)的三中创建方式——Android开发之路2
菜单的三种创建方式 一.OptionsMenu---选项菜单 Android应用中的菜单默认是隐藏的,只有当用户点击手机上的MENU键,系统才会显示菜单.这种菜单叫做选项菜单(Options Menu ...
- Android中隐藏顶部状态栏的那些坑——Android开发之路3
Android中隐藏顶部状态栏的那些坑 先看看常规的隐藏状态栏的方法: 方法一: @Override protected void onCreate(Bundle savedInstanceState ...
- Android中点击隐藏软键盘最佳方法——Android开发之路4
Android中点击隐藏软键盘最佳方法 实现功能:点击EditText,软键盘出现并且不会隐藏,点击或者触摸EditText以外的其他任何区域,软键盘被隐藏: 1.重写dispatchTouchEve ...
- Intent的七大组件——Android开发之路5
------Intent------ Android中三个核心组件——Activity.Services.BroadCastProvider都是通过Intent传递参数. startActivity( ...
- Unity3D 开发之shader教程(浅谈光照之漫反射diffuse)
在游戏开发过程中,光照应该是必不可少部分,当然,这是指大多数的稍微大型一些的3D游戏会需要,给模型或者山山水水加上光照,会看上去更加的真实,获得更好的体验.一个本身不发光物体显示什么颜色,在于本身反射 ...
随机推荐
- A题进行时--浙大PAT 1011-1020
#include<stdio.h> #include<string.h> int main(){ ]; ]; ]; ]; ]; int i; float sum; memset ...
- 【JAVA版】Storm程序整合Kafka、Mongodb示例及部署
一.环境 一台Centos6.5主机 Mongo 3.0 Kafka_2.11-0.8.2.1 Storm-0.9.5 Zookeeper-3.4.6 java 1.7 (后因在mac上打包的jar由 ...
- matplotlib绘制三维图
本文参考官方文档:http://matplotlib.org/mpl_toolkits/mplot3d/tutorial.html 起步 新建一个matplotlib.figure.Figure对象, ...
- java出现no XXX in java.library.path的解决办法及eclipse配置
java一般使用两个path:classpath 和 java.library.path classpath是指向jar包的位置 java.library.path是非java类包的位置如(dll,s ...
- HTML 5的革新:结构之美
HTML 5是什么,无须我在这里赘述了.对于HTML 5的革新,按我的理解,可以总结为语义明确的标签体系.化繁为简的富媒体支持.神奇的本地数据存储技术.不需要插件的富动画(canvas).强大的API ...
- dns解析对SEO产生的影响
DNS 是域名系统 (Domain Name System) 的缩写,它是由解析器和域名服务器组成的.域名服务器是指保存有该网络中所有主机的域名和对应的IP地址,并具有将域名转换为IP地址功能的服务器 ...
- 【Android】Handler的应用(三):从服务器端分页加载更新ListView
在前面两节中,我们了解了如何从服务器中加载JSON数据. 现在,我们将把服务器中的JSON数据加载更新到ListView. 并且,结合之前博文的 “动态追加分页ListView数据”的相关知识,实现 ...
- Castle IOC容器实践之FactorySupport Facility
PDF版本下载:http://file.ddvip.com/2008_10/1223538519_ddvip_4853.rar示例代码下载:http://file.ddvip.com/2008_10/ ...
- Schwarz导数与凹凸性
命题 1: 定义区间$I$上的Schwarz导数$$D^{2}f(x)=\lim_{h\to 0}\frac{f(x+h)+f(x-h)-2f(x)}{h^{2}}$$若$D^{2}f(x)\geq ...
- 通过yum安装Nagios
通过yum安装Nagios 2012年04月05日 ⁄ Nagios ⁄ 暂无评论 QQ空间新浪微博腾讯微博人人网更多3 前提先自行安装好Apache+php 测试环境主监控机:CentOS ...