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;

}

}

时间: 2024-08-25 08:07:35

android开发之路09(浅谈SQLite数据库01)的相关文章

android开发之路02(浅谈BroadcastReceiver)

一.BroadcastReceiver (广播接收者)的作用是用来接收来自系统和应用中的广播.应用如下: 1.开机完成后系统会产生一条广播----->接收到这条广播就能实现开机启动服务的功能: 2.网络状态改变时系统会产生一条广播,接收到这条广播就能及时地做出提示和保存数据等操作: 当电池电量改变时,系统会产生一条广播,接收到这条广播就能在电量低时告知用户及时保存进度: Android中的广播机制设计的非常出色,大大减少了开发的工作量和开发周期. 二.静态注册广播接收者和动态注册广播接收者 ①创

android开发之路01

一.android系统被分为4个层次:1.最下层的是linux核心,包括多个驱动程序,提供了操作系统应该具备的核心功能:2.在linux核心之上,包括两个部分,一部分是Android Runtime(包括Dalvik虚拟机,和Core Libraries相当于java中的jdk)和LIBRARIES:3.是Application Framework这一层,该层包括多个Android开发框架(即各种管理器,如资源管理器等):4.Aplication层(该层既是我们工作的领域app)二.基于组件的应

Unity3D 开发之shader教程(浅谈GPU渲染入门)

这篇随笔,就不按照各种专业的解释来描述了,完全看自己发挥吧,写到哪儿算哪儿.若是哪里有说的不对的地方,请各位看官直说无妨! 说到游戏研发,就不可避免会提到图形学,图形学里面细去研究,就会牵涉到各种各样的数学知识,向量,矩阵之类的!而到这儿,咱们先开始从shader谈起,什么是shader?咱们通常说写个shader,其实也就是写了一个执行某种功能的程序,跟你写个普通的程序原理上说一样的,而不同之处在于,shader是写个GPU执行的,说到GPU执行,那么就得谈到3D游戏里面的那些人物啊,花鸟啊,

android开发之路03

一.Activity1.如何在一个应用程序中定义多个Activity:①定义一个类,继承Activity:②在该类当中,复写Activity当中的onCreate方法:③在AndroidManifest.xml文件当中注册该Activity:2.如何启动一个Activity:①生成一个意图(Intent)对象:②调用setClass方法设置所要启动的Activity:③调用startActivity方法启动Activity3.Android当中的back stack(返回栈即返回按钮):栈这种数

菜单(Menu)的三中创建方式——Android开发之路2

菜单的三种创建方式 一.OptionsMenu---选项菜单 Android应用中的菜单默认是隐藏的,只有当用户点击手机上的MENU键,系统才会显示菜单.这种菜单叫做选项菜单(Options Menu)或系统菜单. 从3.0开始,Android不要求手机设备上必须提供MENU按键.因此Android推荐使用ActionBar来代替Menu. 在不同的版本中菜单显示效果有差异 二.ContextMenu---上下文菜单 三.PopupMenu---弹出式菜单 可以在指定的组件上设置弹出式菜单,默认

android开发之路11(用SharedPreferences存储数据)

Android平台给我们提供了一个SharedPreferences类,实际上SharedPreferences处理的就是一个key-value(键值对),它是 一个轻量级的存储类,特别适合用于保存软件配置参数及用户的偏好设置参数,比如登录时候的记住密码功能等.使用 SharedPreferences保存数据,实际上是用xml文件存放数据,文件存放在/data/data/<package name>/shared_prefs目录下 : 1.获取SharedPreferences对象的两种方式:

android开发之路08(ListView&amp;Adapter)

ListView控件介绍:用于将数据库中的数据或者网络中的数据通过列表的形式显示出来:ListView采用MVC模式将前端显示和后端数据进行分离. 也就是说,ListView控件在装载数据时并不是直接使用ListView.add或者类似的方法添加数据,而是需要指定一个Adapter对象.该对象相当于MVC模式中的C(控制器),ListView相当于MVC模式中的V(视图),用于显示数据.为ListView提供数据的List或数组相当于MVC模式中的M(模型)在ListView控件中通过Adapt

Unity3D 开发之shader教程(浅谈GPU渲染之shader language概述)

尊重他人智慧成果,欢迎转载,请注明作者 心若透明 地址  http://www.cnblogs.com/ubanck/p/4110618.html 在上一篇博客里,大致讲解了一下3D渲染的原理,即从一个简单的模型到渲染到屏幕的过程!其中提到了重要的坐标变换方式,说的不够清楚!今天来谈谈shader语言的执行过程 从硬件上讲,GPU内部有顶点着色器与片段着色器,从渲染管线来看,顶点着色器控制这顶点的坐标转换过程,片段着色器控制像素的颜色计算过程.顶点着色器将顶点转换完成,输入到片段着色器进行处理(

Android开发之SQLite数据库详解

Android开发之SQLite数据库详解 请尊重他人的劳动成果,转载请注明出处:Android开发之SQLite数据库详解 http://blog.csdn.net/fengyuzhengfan/article/details/40194393 Android系统集成了一个轻量级的数据库:SQLite, SQLite并不想成为像Oracle.MySQL那样的专业数据库.SQLite只是一个嵌入式的数据库引擎,专门适用于资源有限的设备上(如手机.PDA等)适量数据存取. 虽然SQLite支持绝大