SQLite

SQLite试试一个嵌入式的数据库引擎,专门用于资源有限的设备(如手机、PDA)上适量数据存取。

SQLite支持绝大部分SQL92语法,同样允许开发者使用SQL语句操作数据库中的数据,但SQLite并不像Oracle、MySQL数据库需要安装、启动服务进程,SQLite数据库只是一个文件。

从本质上来看,SQLite的操作方式只是一种更为便捷的文件操作。

SQLiteDatebase

Android提供了SQLiteDatabase代表一个数据库(底层就是一个数据库文件),一旦应用程序获得了代表指定数据库SQLiteDatabase对象,就可通过SQLiteDatabase对象来管理、操作数据库了。

SQLiteDatebase提供如下静态方法来打开一个文件对应的数据库:

1.static SQLiteDatebase openDatabase(String path,SQLiteDatebase.CursorFactory factory,int flags)——打开path文件所代表的SQLite数据库;

2.static SQLiteDatebase openOrCreateDatabase(File file,SQLiteDatebase.CursorFactory factory)——打开或创建file文件所代表的SQLite数据库;

3.static SQLiteDatebase openOrCreateDatabase(String path,SQLiteDatebase.CursorFactory factory)——打开或创建path文件所代表的SQLite数据库;

在程序中获取SQLiteDatebase对象后,即可调用SQLiteDatebase的如下方法来操作数据库:

execSQL(String sql,Object[] bindArgs) 执行带占位符的SQL语句
execSQL(String sql) 执行SQL语句
insert(String table,String nullColumnHack,ContentValues values) 向执行表中插入数据
update(String table,ContentValues values,String whereClause,String[] whereArgs) 更新指定表中的特定数据
delete(String table,String whereClause,String[] whereArgs) 删除指定表中的特定数据

Cursor query(String table,String[] columns,String selection,String[] selectonArgs,

String groupby,String having,String orderby)

对执行数据表执行排序

Cursor query(String table,String[] columns,String selection,String[] selectonArgs,

String groupby,String having,String orderby,String limit)

对执行数据表执行查询。limit参数控制最多查询记录数量

(用于控制分页的参数)

Cursor query(boolean distinct,String table,String[] columns,String selection,String[] selectonArgs,String groupby,String having,String orderby,String limit)

对指定表执行查询操作,第一个参数控制是否去除重复值
rawQuery(String sql,String[] selectionAgrs) 执行带占位符的SQL语句
beginTransaction 开始事务
endTransaction   结束事务

以上查询方法都是返回一个Cursor对象,Android中的Cursor类似于JDBC的ResultSet,Cursor同样提供了对应的方法来移动查询结果的记录指针,如下所示:

move(int offset) 将记录指针向上/下移动指定的行数,offset为正数就是向下移动,为负数就是向上移动
boolean moveToFirst() 将记录指针移动到第一行,如果移动成功返回true
boolean moveToLast() 将记录指针移动到最后一行,如果移动成功返回true
boolean moveToNext() 将记录指针移动到下一行,如果移动成功返回true
boolean moveToPisition(int position) 将记录指针移动到指定的行,如果移动成功返回true
boolean moveToPrevious() 将记录指针移动到上一行,如果移动成功返回true

一旦将记录指针移动的指定行之后,就可以调用Cursor的getXxx()方法获取该行的指定列的数据。

创建数据库和表

SQLiteDatebase可使用静态方法打开或创建数据库如下:

SQLiteDatebase.openOrCreateDatebase("/mnt/db/temp.db3",null);

——没有指定SQLiteDatebase.CursorFactory factory,该参数是一个用于返回Cursor工厂,如果指定该参数为null,则意味着使用默认的工厂。

注意:

SQLiteDatebase.openOrCreateDatebase("/mnt/db/temp.db3",null);可返回一个SQLiteDatebase对象,

该对象的execSQL可执行任意的SQL语句,因此程序可通过如下代码创建数据库表:

sql="create table userInfo (id integer primary key,name varchar(50))";

db.execSQL(sql);

使用SQL语句操作SQLite数据库

如以上所提,SQLiteDatebase的execSQL方法可执行任意SQL语句,包括带占位符的SQL语句。

但由于该方法没有返回值,一般用于执行DDL语句或DML语句,如果需要执行查询语句,则可调用SQLiteDatebase的rawQuery(String sql,String[] selecttionArgs)方法.

Eg:如下代码可执行DML语句:

db.execSQL("insert into tableInfo values(null,?,?)",new String[]{title,content});

sql组成:

  DDL:数据库模式定义语言,关键字:create

  DML:数据操纵语言,关键字:Insert、delete、update

  DCL:数据库控制语言 ,关键字:grant、remove

  DQL:数据库查询语言,关键字:select

实例如下:

布局文件==》main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" > <EditText
android:id="@+id/editOne"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="" /> <EditText
android:id="@+id/editTwo"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="" /> <Button
android:id="@+id/btnInsert"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="insert" /> <ListView
android:id="@+id/lv"
android:layout_width="wrap_content"
android:layout_height="wrap_content" /> </LinearLayout> ==>line.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal" > <TextView
android:id="@+id/tv1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/tv2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" /> </LinearLayout> 实现代码
package com.example.mysqlite1; import android.os.Bundle;
import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter; public class MainActivity extends Activity
{
EditText Edit1;
EditText Edit2;
SQLiteDatabase db; @Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
String filePath = this.getFilesDir().toString() + "my.db3";
db = SQLiteDatabase.openOrCreateDatabase(filePath, null);
Edit1 = (EditText) this.findViewById(R.id.editOne);
Edit2 = (EditText) this.findViewById(R.id.editTwo); Button btnInsert = (Button) this.findViewById(R.id.btnInsert); btnInsert.setOnClickListener(new OnClickListener()
{
@Override
public void onClick(View v)
{
try
{
InsertDataAndInflateList();
} catch (Exception e)
{
Log.i("swg", "error" + e.getMessage());
db.execSQL("create table SQLiteTest2(_id integer primary key autoincrement,text1 varchar(50),text2 varchar(50))");
InsertDataAndInflateList();
} } private void InsertDataAndInflateList()
{
insertData(db, Edit1.getText().toString(), Edit2.getText().toString());
Cursor crusor = db.rawQuery("select * from SQLiteTest2", null);
Log.i("swg", "查询完成");
inflateList(crusor);
} private void insertData(SQLiteDatabase db, String text, String text2)
{
db.execSQL("insert into SQLiteTest2 values(null,?,?)", new String[] { text, text2 });
Log.i("swg", "插入成功");
} @SuppressWarnings("deprecation")
private void inflateList(Cursor crusor)
{
Log.i("swg", "inflateList");
SimpleCursorAdapter adapter = new SimpleCursorAdapter(MainActivity.this,
R.layout.line, crusor, new String[] { "text1", "text2" }, new int[] {
R.id.tv1, R.id.tv2 }); Log.i("swg", "inflateList==" + adapter.getCount()); ListView lv = (ListView) findViewById(R.id.lv);
lv.setAdapter(adapter);
}
});
} @Override
protected void onDestroy()
{
super.onDestroy();
// 退出时关闭SQLiteDatabase
if (db != null && db.isOpen())
db.close();
} @Override
public boolean onCreateOptionsMenu(Menu menu)
{
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
} }

运行效果;

注意:使用SimpleCursorAdapter封装Cursor时要求底层数据表中的主键列的列名为_id,SimpleCursorAdapter只能识别列名为_id的主键。

因此以上实例中创建表时,主键列名为_id.否则就会出现java.lang.IllegalArgumentException:column '_id' does not exist异常。

总结:

使用SQLiteDatabase进行数据库操作的步骤如下:

1.获取SQLiteDatabase对象,其代表了与数据库的连接;

2.调用SQLiteDatabase的方法执行SQL语句;

3.操作SQL语句的执行结果,例如:用SimpleCursorAdapter封装Cursor;

4.管理SQLiteDatabase,回收资源。

android学习笔记48——SQLite的更多相关文章

  1. Android学习笔记(SQLite的简单使用)

    1.SQLite介绍 SQLite,是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中.它是D.RichardHipp建立的公有领域项目.它的设计目标是嵌入式的,而且 ...

  2. android学习笔记51——SQLite 手势Gesture

    手势Gesture 所谓手势,是指用户手指或触摸笔在触摸屏幕上的连续触碰行为. Androi对两种手势行为都提供了支持: 1.对于第一种手势而言,android提供了手势检测,并为手势检测提供了相应的 ...

  3. Android学习笔记36:使用SQLite方式存储数据

    在Android中一共提供了5种数据存储方式,分别为: (1)Files:通过FileInputStream和FileOutputStream对文件进行操作.具体使用方法可以参阅博文<Andro ...

  4. 【转】 Pro Android学习笔记(五五):调试和分析(3):adb命令、模拟器控制台和StrictMode

    目录(?)[-] adb命令 模拟器Console StrictMode adb命令 我们在学习SQLite的使用,介绍过部分adb命令的使用,见Pro Android学习笔记(五):了解Conten ...

  5. 【转】Pro Android学习笔记(七):了解Content Provider(下上)

    我们通过一个Content Provider小例子进行详细说明.数据源是一个SQLite数据库,名字为books.db,该数据库只含有一个表格,名字为books.表格中含有name,isbn,auth ...

  6. 【转】Pro Android学习笔记(五):了解Content Provider(上)

    Content Provider是抽象数据封装和数据访问机制,例如SQLite是Android设备带有的数据源,可以封装到一个content provider中.要通过content provider ...

  7. udacity android 学习笔记: lesson 4 part a

    udacity android 学习笔记: lesson 4 part a 作者:干货店打杂的 /titer1 /Archimedes 出处:https://code.csdn.net/titer1 ...

  8. Android 学习笔记之Volley(七)实现Json数据加载和解析...

    学习内容: 1.使用Volley实现异步加载Json数据...   Volley的第二大请求就是通过发送请求异步实现Json数据信息的加载,加载Json数据有两种方式,一种是通过获取Json对象,然后 ...

  9. Android学习笔记进阶之在图片上涂鸦(能清屏)

    Android学习笔记进阶之在图片上涂鸦(能清屏) 2013-11-19 10:52 117人阅读 评论(0) 收藏 举报 HandWritingActivity.java package xiaos ...

随机推荐

  1. 设置mysql远程连接root权限

    在远程连接mysql的时候应该都碰到过,root用户无法远程连接mysql,只可以本地连,对外拒绝连接.需要建立一个允许远程登录的数据库帐户,这样才可以进行在远程操作数据库.方法如下:默认情况下MYS ...

  2. 1password密码文件重装后恢复

    因为重装系统,加上Time machine硬盘损坏. 只能从之前零散Time machine的恢复数据中找到最近的一个备份. 1password是会自己执行备份的,起备份文件在 ~/Library/C ...

  3. android布局中的divider(目前只知道TableLayout)

    目前在genymotion中设置了之后显示不出来行与行之间的分割线,但是在真机上面是没有问题的 1.使用xml属性添加(3.0以上版本) 设置LinearLayout标签的 android:showD ...

  4. win7 一些快捷系统工具命令

    1.cleanmgr: 打开磁盘清理工具 2.compmgmt.msc: 计算机管理 3.conf: 启动系统配置实用程序 4.charmap: 启动字符映射表 5.calc: 启动计算器 6.chk ...

  5. 153. Find Minimum in Rotated Sorted Array

    Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...

  6. jquery中prop()方法和attr()方法的区别

    最近在用jquery的时候遇到一个问题,那就是attr()方法,发现这个方法有时候使用会有一些说不出原因的问题.翻翻自己之前笔记发现,还有个函数prop(). 这两个函数都可以用来获取属性. jque ...

  7. JavaScript 遗漏知识再整理;错误处理,类型转换以及获取当前时间、年份、月份、日期;

    1.JavaScript 错误处理 Throw.Try 和 Catch try 语句测试代码块的错误. catch 语句处理错误. throw 语句创建自定义错误. JavaScript 错误 当 J ...

  8. ZOJ-3933 Team Formation (二分图最佳完美匹配)

    题目大意:n个人,分为两个阵营.现在要组成由若干支队伍,每支队伍由两个人组成并且这两个人必须来自不同的阵营.同时,每个人都有m个厌恶的对象,并且厌恶是相互的.相互厌恶的人不能组成一支队伍.问最多能组成 ...

  9. HDU-4035 Maze (概率DP求期望)

    题目大意:在一个树形迷宫中,以房间为节点.有n间房间,每间房间存在陷阱的概率为ki,存在出口的概率为ei,如果这两种情况都不存在(概率为pi),那么只能做出选择走向下一个房间(包括可能会走向上一个房间 ...

  10. Java设计模式之责任链设计模式

    职责链模式(Chain of Responsibility):使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系,将所有处理对象连成一条链,并沿着这条链传递请求,直到有一个对象处理 ...