在Android开发中SQLite起着很重要的作用,网上SQLite的教程有很多很多,不过那些教程大多数都讲得不是很全面。本人总结了一些SQLite的常用的方法,借着论坛的大赛,跟大家分享分享的。

一.SQLite的介绍

1.SQLite简介

SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入  式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持 Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如Tcl、PHP、Java、C++、.Net等,还有ODBC接口,同样比起 Mysql、PostgreSQL这两款开源世界著名的数据库管理系统来讲,它的处理速度比他们都快。

2.SQLite的特点:

  • 轻量级

SQLite和C/S模式的数据库软件不同,它是进程内的数据库引擎,因此不存在数据库的客户端和服务器。使用SQLite一般只需要带上它的一个动态  库,就可以享受它的全部功能。而且那个动态库的尺寸也挺小,以版本3.6.11为例,Windows下487KB、Linux下347KB。

  • 不需要"安装"

SQLite的核心引擎本身不依赖第三方的软件,使用它也不需要"安装"。有点类似那种绿色软件。

  • 单一文件

数据库中所有的信息(比如表、视图等)都包含在一个文件内。这个文件可以自由复制到其它目录或其它机器上。

  • 跨平台/可移植性

除了主流操作系统 windows,linux之后,SQLite还支持其它一些不常用的操作系统。

  • 弱类型的字段

同一列中的数据可以是不同类型

  • 开源

这个相信大家都懂的!!!!!!!!!!!!

3.SQLite数据类型

一般数据采用的固定的静态数据类型,而SQLite采用的是动态数据类型,会根据存入值自动判断。SQLite具有以下五种常用的数据类型:

NULL: 这个值为空值

VARCHAR(n):长度不固定且其最大长度为 n 的字串,n不能超过 4000。

CHAR(n):长度固定为n的字串,n不能超过 254。

INTEGER: 值被标识为整数,依据值的大小可以依次被存储为1,2,3,4,5,6,7,8.

REAL: 所有值都是浮动的数值,被存储为8字节的IEEE浮动标记序号.

TEXT: 值为文本字符串,使用数据库编码存储(TUTF-8, UTF-16BE or UTF-16-LE).

BLOB: 值是BLOB数据块,以输入的数据格式进行存储。如何输入就如何存储,不改  变格式。

DATA :包含了 年份、月份、日期。

TIME: 包含了 小时、分钟、秒。

相信学过数据库的童鞋对这些数据类型都不陌生的!!!!!!!!!!

二.SQLiteDatabase的介绍

Android提供了创建和是用SQLite数据库的API。SQLiteDatabase代表一个数据库对象,提供了操作数据库的一些方法。在Android的SDK目录下有sqlite3工具,我们可以利用它创建数据库、创建表和执行一些SQL语句。下面是SQLiteDatabase的常用方法。 

SQLiteDatabase的常用方法

方法名称
方法表示含义
openOrCreateDatabase(String path,SQLiteDatabase.CursorFactory  factory)
打开或创建数据库
insert(String table,String nullColumnHack,ContentValues  values)
插入一条记录
delete(String table,String whereClause,String[]  whereArgs)
删除一条记录
query(String table,String[] columns,String selection,String[]  selectionArgs,String groupBy,String having,String  orderBy)
查询一条记录
update(String table,ContentValues values,String whereClause,String[]  whereArgs)
修改记录
execSQL(String sql)
执行一条SQL语句
close()
关闭数据库

Google公司命名这些方法的名称都是非常形象的。例如openOrCreateDatabase,我们从字面英文含义就能看出这是个打开或创建数据库的方法。

1、打开或者创建数据库

在Android 中使用SQLiteDatabase的静态方法openOrCreateDatabase(String  path,SQLiteDatabae.CursorFactory  factory)打开或者创建一个数据库。它会自动去检测是否存在这个数据库,如果存在则打开,不存在则创建一个数据库;创建成功则返回一个SQLiteDatabase对象,否则抛出异常FileNotFoundException。

下面是创建名为“stu.db”数据库的代码:
openOrCreateDatabase(String  path,SQLiteDatabae.CursorFactory  factory)
参数1  数据库创建的路径

参数2  一般设置为null就可以了

  1. db=SQLiteDatabase.openOrCreateDatabase("/data/data/com.lingdududu.db/databases/stu.db",null);

2、创建表

创建一张表的步骤很简单:

  • 编写创建表的SQL语句
  • 调用SQLiteDatabase的execSQL()方法来执行SQL语句

下面的代码创建了一张用户表,属性列为:id(主键并且自动增加)、sname(学生姓名)、snumber(学号)

  1. private void createTable(SQLiteDatabase db){
  2. //创建表SQL语句
  3. String stu_table="create table usertable(_id integer primary key autoincrement,sname text,snumber text)";
  4. //执行SQL语句
  5. db.execSQL(stu_table);
  6. }

3、插入数据
插入数据有两种方法:
①SQLiteDatabase的insert(String table,String nullColumnHack,ContentValues  values)方法,
  参数1  表名称,
  参数2  空列的默认值
  参数3  ContentValues类型的一个封装了列名称和列值的Map;
②编写插入数据的SQL语句,直接调用SQLiteDatabase的execSQL()方法来执行
第一种方法的代码:

  1. private void insert(SQLiteDatabase db){
  2. //实例化常量值
  3. ContentValues cValue = new ContentValues();
  4. //添加用户名
  5. cValue.put("sname","xiaoming");
  6. //添加密码
  7. cValue.put("snumber","01005");
  8. //调用insert()方法插入数据
  9. db.insert("stu_table",null,cValue);
  10. }

第二种方法的代码:

  1. private void insert(SQLiteDatabase db){
  2. //插入数据SQL语句
  3. String stu_sql="insert into stu_table(sname,snumber) values('xiaoming','01005')";
  4. //执行SQL语句
  5. db.execSQL(sql);
  6. }

4、删除数据

删除数据也有两种方法:

①调用SQLiteDatabase的delete(String table,String whereClause,String[]  whereArgs)方法
参数1  表名称 
参数2  删除条件
参数3  删除条件值数组

②编写删除SQL语句,调用SQLiteDatabase的execSQL()方法来执行删除。

第一种方法的代码:

  1. private void delete(SQLiteDatabase db) {
  2. //删除条件
  3. String whereClause = "id=?";
  4. //删除条件参数
  5. String[] whereArgs = {String.valueOf(2)};
  6. //执行删除
  7. db.delete("stu_table",whereClause,whereArgs);
  8. }

第二种方法的代码:

  1. private void delete(SQLiteDatabase db) {
  2. //删除SQL语句
  3. String sql = "delete from stu_table where _id = 6";
  4. //执行SQL语句
  5. db.execSQL(sql);
  6. }

5、修改数据

修改数据有两种方法:

①调用SQLiteDatabase的update(String table,ContentValues values,String  whereClause, String[]  whereArgs)方法
参数1  表名称
参数2  跟行列ContentValues类型的键值对Key-Value
参数3  更新条件(where字句)
参数4  更新条件数组

②编写更新的SQL语句,调用SQLiteDatabase的execSQL执行更新。

第一种方法的代码:

  1. private void update(SQLiteDatabase db) {
  2. //实例化内容值 ContentValues values = new ContentValues();
  3. //在values中添加内容
  4. values.put("snumber","101003");
  5. //修改条件
  6. String whereClause = "id=?";
  7. //修改添加参数
  8. String[] whereArgs={String.valuesOf(1)};
  9. //修改
  10. db.update("usertable",values,whereClause,whereArgs);
  11. }

第二种方法的代码:

  1. private void update(SQLiteDatabase db){
  2. //修改SQL语句
  3. String sql = "update stu_table set snumber = 654321 where id = 1";
  4. //执行SQL
  5. db.execSQL(sql);
  6. }

6、查询数据

在Android中查询数据是通过Cursor类来实现的,当我们使用SQLiteDatabase.query()方法时,会得到一个Cursor对象,Cursor指向的就是每一条数据。它提供了很多有关查询的方法,具体方法如下:

public  Cursor query(String table,String[] columns,String selection,String[]  selectionArgs,String groupBy,String having,String orderBy,String limit);

各个参数的意义说明:

参数table:表名称

参数columns:列名称数组

参数selection:条件字句,相当于where

参数selectionArgs:条件字句,参数数组

参数groupBy:分组列

参数having:分组条件

参数orderBy:排序列

参数limit:分页查询限制

参数Cursor:返回值,相当于结果集ResultSet

Cursor是一个游标接口,提供了遍历查询结果的方法,如移动指针方法move(),获得列值方法getString()等.

Cursor游标常用方法

方法名称
方法描述
getCount()
获得总的数据项数
isFirst()
判断是否第一条记录
isLast()
判断是否最后一条记录
moveToFirst()
移动到第一条记录
moveToLast()
移动到最后一条记录
move(int offset)
移动到指定记录
moveToNext()
移动到下一条记录
moveToPrevious()
移动到上一条记录
getColumnIndexOrThrow(String  columnName)
根据列名称获得列索引
getInt(int columnIndex)
获得指定列索引的int类型值
getString(int columnIndex)
获得指定列缩影的String类型值

下面就是用Cursor来查询数据库中的数据,具体代码如下:

  1. private void query(SQLiteDatabase db) {
  2. //查询获得游标
  3. Cursor cursor = db.query ("usertable",null,null,null,null,null,null);
  4. //判断游标是否为空
  5. if(cursor.moveToFirst() {
  6. //遍历游标
  7. for(int i=0;i<cursor.getCount();i++){
  8. cursor.move(i);
  9. //获得ID
  10. int id = cursor.getInt(0);
  11. //获得用户名
  12. String username=cursor.getString(1);
  13. //获得密码
  14. String password=cursor.getString(2);
  15. //输出用户信息 System.out.println(id+":"+sname+":"+snumber);
  16. }
  17. }
  18. }

7、删除指定表
编写插入数据的SQL语句,直接调用SQLiteDatabase的execSQL()方法来执行

  1. private void drop(SQLiteDatabase db){
  2. //删除表的SQL语句
  3. String sql ="DROP TABLE stu_table";
  4. //执行SQL
  5. db.execSQL(sql);
  6. }

三. SQLiteOpenHelper
该类是SQLiteDatabase一个辅助类。这个类主要生成一  个数据库,并对数据库的版本进行管理。当在程序当中调用这个类的方法getWritableDatabase()或者 getReadableDatabase()方法的时候,如果当时没有数据,那么Android系统就会自动生成一个数据库。 SQLiteOpenHelper 是一个抽象类,我们通常需要继承它,并且实现里面的3个函数:

1.onCreate(SQLiteDatabase)

在数据库第一次生成的时候会调用这个方法,也就是说,只有在创建数据库的时候才会调用,当然也有一些其它的情况,一般我们在这个方法里边生成数据库表。

2.  onUpgrade(SQLiteDatabase,int,int) 
当数据库需要升级的时候,Android系统会主动的调用这个方法。一般我们在这个方法里边删除数据表,并建立新的数据表,当然是否还需要做其他的操作,完全取决于应用的需求。

3.  onOpen(SQLiteDatabase):

这是当打开数据库时的回调函数,一般在程序中不是很常使用。

写了这么多,改用用实际例子来说明上面的内容了。下面这个操作数据库的实例实现了创建数据库,创建表以及数据库的增删改查的操作。
该实例有两个类:
com.lingdududu.testSQLite 调试类
com.lingdududu.testSQLiteDb  数据库辅助类

SQLiteActivity.java

  1. package com.lingdududu.testSQLite;
  2. import com.lingdududu.testSQLiteDb.StuDBHelper;
  3. import android.app.Activity;
  4. import android.content.ContentValues;
  5. import android.database.Cursor;
  6. import android.database.sqlite.SQLiteDatabase;
  7. import android.os.Bundle;
  8. import android.view.View;
  9. import android.view.View.OnClickListener;
  10. import android.widget.Button;
  11. /*
  12. * @author lingdududu
  13. */
  14. public class SQLiteActivity extends Activity {
  15. /** Called when the activity is first created. */
  16. //声明各个按钮
  17. private Button createBtn;
  18. private Button insertBtn;
  19. private Button updateBtn;
  20. private Button queryBtn;
  21. private Button deleteBtn;
  22. private Button ModifyBtn;
  23. @Override
  24. public void onCreate(Bundle savedInstanceState) {
  25. super.onCreate(savedInstanceState);
  26. setContentView(R.layout.main);
  27. //调用creatView方法
  28. creatView();
  29. //setListener方法
  30. setListener();
  31. }
  32. //通过findViewById获得Button对象的方法
  33. private void creatView(){
  34. createBtn = (Button)findViewById(R.id.createDatabase);
  35. updateBtn = (Button)findViewById(R.id.updateDatabase);
  36. insertBtn = (Button)findViewById(R.id.insert);
  37. ModifyBtn = (Button)findViewById(R.id.update);
  38. queryBtn = (Button)findViewById(R.id.query);
  39. deleteBtn = (Button)findViewById(R.id.delete);
  40. }
  41. //为按钮注册监听的方法
  42. private void setListener(){
  43. createBtn.setOnClickListener(new CreateListener());
  44. updateBtn.setOnClickListener(new UpdateListener());
  45. insertBtn.setOnClickListener(new InsertListener());
  46. ModifyBtn.setOnClickListener(new ModifyListener());
  47. queryBtn.setOnClickListener(new QueryListener());
  48. deleteBtn.setOnClickListener(new DeleteListener());
  49. }
  50. //创建数据库的方法
  51. class CreateListener implements OnClickListener{
  52. @Override
  53. public void onClick(View v) {
  54. //创建StuDBHelper对象
  55. StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1);
  56. //得到一个可读的SQLiteDatabase对象
  57. SQLiteDatabase db =dbHelper.getReadableDatabase();
  58. }
  59. }
  60. //更新数据库的方法
  61. class UpdateListener implements OnClickListener{
  62. @Override
  63. public void onClick(View v) {
  64. // 数据库版本的更新,由原来的1变为2
  65. StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,2);
  66. SQLiteDatabase db =dbHelper.getReadableDatabase();
  67. }
  68. }
  69. //插入数据的方法
  70. class InsertListener implements OnClickListener{
  71. @Override
  72. public void onClick(View v) {
  73. StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1);
  74. //得到一个可写的数据库
  75. SQLiteDatabase db =dbHelper.getWritableDatabase();
  76. //生成ContentValues对象 //key:列名,value:想插入的值
  77. ContentValues cv = new ContentValues();
  78. //往ContentValues对象存放数据,键-值对模式
  79. cv.put("id", 1);
  80. cv.put("sname", "xiaoming");
  81. cv.put("sage", 21);
  82. cv.put("ssex", "male");
  83. //调用insert方法,将数据插入数据库
  84. db.insert("stu_table", null, cv);
  85. //关闭数据库
  86. db.close();
  87. }
  88. }
  89. //查询数据的方法
  90. class QueryListener implements OnClickListener{
  91. @Override
  92. public void onClick(View v) {
  93. StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1);
  94. //得到一个可写的数据库
  95. SQLiteDatabase db =dbHelper.getReadableDatabase();
  96. //参数1:表名
  97. //参数2:要想显示的列
  98. //参数3:where子句
  99. //参数4:where子句对应的条件值
  100. //参数5:分组方式
  101. //参数6:having条件
  102. //参数7:排序方式
  103. Cursor cursor = db.query("stu_table", new String[]{"id","sname","sage","ssex"}, "id=?", new String[]{"1"}, null, null, null);
  104. while(cursor.moveToNext()){
  105. String name = cursor.getString(cursor.getColumnIndex("sname"));
  106. String age = cursor.getString(cursor.getColumnIndex("sage"));
  107. String sex = cursor.getString(cursor.getColumnIndex("ssex"));
  108. System.out.println("query------->" + "姓名:"+name+" "+"年龄:"+age+" "+"性别:"+sex);
  109. }
  110. //关闭数据库
  111. db.close();
  112. }
  113. }
  114. //修改数据的方法
  115. class ModifyListener implements OnClickListener{
  116. @Override
  117. public void onClick(View v) {
  118. StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1);
  119. //得到一个可写的数据库
  120. SQLiteDatabase db =dbHelper.getWritableDatabase();
  121. ContentValues cv = new ContentValues();
  122. cv.put("sage", "23");
  123. //where 子句 "?"是占位符号,对应后面的"1",
  124. String whereClause="id=?";
  125. String [] whereArgs = {String.valueOf(1)};
  126. //参数1 是要更新的表名
  127. //参数2 是一个ContentValeus对象
  128. //参数3 是where子句
  129. db.update("stu_table", cv, whereClause, whereArgs);
  130. }
  131. }
  132. //删除数据的方法
  133. class DeleteListener implements OnClickListener{
  134. @Override
  135. public void onClick(View v) {
  136. StuDBHelper dbHelper = new StuDBHelper(SQLiteActivity.this,"stu_db",null,1);
  137. //得到一个可写的数据库
  138. SQLiteDatabase db =dbHelper.getReadableDatabase();
  139. String whereClauses = "id=?";
  140. String [] whereArgs = {String.valueOf(2)};
  141. //调用delete方法,删除数据
  142. db.delete("stu_table", whereClauses, whereArgs);
  143. }
  144. }
  145. }

StuDBHelper.java

  1. package com.lingdududu.testSQLiteDb;
  2. import android.content.Context;
  3. import android.database.sqlite.SQLiteDatabase;
  4. import android.database.sqlite.SQLiteDatabase.CursorFactory;
  5. import android.database.sqlite.SQLiteOpenHelper;
  6. import android.util.Log;
  7. public class StuDBHelper extends SQLiteOpenHelper {
  8. private static final String TAG = "TestSQLite";
  9. public static final int VERSION = 1;
  10. //必须要有构造函数
  11. public StuDBHelper(Context context, String name, CursorFactory factory,
  12. int version) {
  13. super(context, name, factory, version);
  14. }
  15. // 当第一次创建数据库的时候,调用该方法
  16. public void onCreate(SQLiteDatabase db) {
  17. String sql = "create table stu_table(id int,sname varchar(20),sage int,ssex varchar(10))";
  18. //输出创建数据库的日志信息
  19. Log.i(TAG, "create Database------------->");
  20. //execSQL函数用于执行SQL语句
  21. db.execSQL(sql);
  22. }
  23. //当更新数据库的时候执行该方法
  24. public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  25. //输出更新数据库的日志信息
  26. Log.i(TAG, "update Database------------->");
  27. }
  28. }

main.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <TextView
  8. android:layout_width="fill_parent"
  9. android:layout_height="wrap_content"
  10. android:text="@string/hello"
  11. />
  12. <Button
  13. android:id="@+id/createDatabase"
  14. android:layout_width="fill_parent"
  15. android:layout_height="wrap_content"
  16. android:text="创建数据库"
  17. />
  18. <Button
  19. android:id="@+id/updateDatabase"
  20. android:layout_width="fill_parent"
  21. android:layout_height="wrap_content"
  22. android:text="更新数据库"
  23. />
  24. <Button
  25. android:id="@+id/insert"
  26. android:layout_width="fill_parent"
  27. android:layout_height="wrap_content"
  28. android:text="插入数据"
  29. />
  30. <Button
  31. android:id="@+id/update"
  32. android:layout_width="fill_parent"
  33. android:layout_height="wrap_content"
  34. android:text="更新数据"
  35. />
  36. <Button
  37. android:id="@+id/query"
  38. android:layout_width="fill_parent"
  39. android:layout_height="wrap_content"
  40. android:text="查询数据"
  41. />
  42. <Button
  43. android:id="@+id/delete"
  44. android:layout_width="fill_parent"
  45. android:layout_height="wrap_content"
  46. android:text="删除数据"
  47. />
  48. </LinearLayout>

程序运行的效果图:

使用adb命令查看数据库:

1.在命令行窗口输入adb  shell回车,就进入了Linux命令行,现在就可以使用Linux的命令了。

2.ls回车,显示所有的东西,其中有个data。

3.cd data回车,再ls回车,cd  data回车,ls回车后就会看到很多的com................,那就是系统上的应用程序包名,找到你数据库程序的包名,然后进入。

4.进去后在查看所有,会看到有databases,进入databases,显示所有就会发现你的数据库名字,这里使用的是"stu_db"。

5.sqlite3 stu_db回车就进入了你的数据库了,然后“.schema”就会看到该应用程序的所有表及建表语句。

6.之后就可以使用标准的SQL语句查看刚才生成的数据库及对数据执行增删改查了。
注:ls,cd等命令都是linux的基本命令,不了解的同学可以看看有关这方面的资料。

下面介绍几个在SQLite中常用到的adb命令:

查看
.database 显示数据库信息;
.tables 显示表名称;
.schema 命令可以查看创建数据表时的SQL命令;
.schema table_name 查看创建表table_name时的SQL的命令;

插入记录
insert into table_name values (field1, field2, field3...);

查询
select * from table_name;查看table_name表中所有记录;
select * from table_name where field1='xxxxx'; 查询符合指定条件的记录;

删除
drop table_name;     删除表;
drop index_name;     删除索引;
-------------------------------------------查询,插入,删除等操作数据库的语句记得不要漏了;----------------------------------------

# sqlite3 stu_db
sqlite3 stu_db
SQLite version 3.6.22
Enter  ".help" for instructions
Enter SQL statements terminated with a  ";"
sqlite> .schema
.schema
CREATE TABLE  android_metadata (locale TEXT);
CREATE TABLE stu_table(id int,sname varchar(20),sage int,ssex  varchar(10));  --->创建的表
sqlite> select * from stu_table;
select * from  stu_table;
1|xiaoming|21|male
sqlite>

插入数据

sqlite> insert into stu_table  values(2,'xiaohong',20,'female');

插入的数据记得要和表中的属性一一对应
insert into stu_table  values(2,'xiaohong',20,'female');
sqlite> select * from  stu_table;
select * from  stu_table;
1|xiaoming|21|male
2|xiaohong|20|female   --------------> 插入的数据
sqlite>

当点击修改数据的按钮时候

sqlite> select * from stu_table;
select * from  stu_table;
1|xiaoming|23|male  -------------->年龄被修改为23
2|xiaohong|20|female
sqlite>

当点击删除数据的按钮

sqlite> select * from stu_table;
select * from  stu_table;
1|xiaoming|23|male        id=2的数据已经被删除

总之,我们可以在代码中执行数据库的增删改查,也可以在adb命令行下实现。不过因为SQLite没有客户端,不能直接的查看数据库变化后的信息,所以常用adb命令行查看数据库改变后的信息。

Android SQLite数据库使用的更多相关文章

  1. Android Sqlite 数据库版本更新

      Android Sqlite 数据库版本更新 http://87426628.blog.163.com/blog/static/6069361820131069485844/ 1.自己写一个类继承 ...

  2. Android SQLite 数据库详细介绍

    Android SQLite 数据库详细介绍 我们在编写数据库应用软件时,需要考虑这样的问题:因为我们开发的软件可能会安装在很多用户的手机上,如果应用使用到了SQLite数据库,我们必须在用户初次使用 ...

  3. Android sqlite数据库存取图片信息

    Android sqlite数据库存取图片信息 存储图片:bitmap private byte[] getIconData(Bitmap bitmap){ int size = bitmap.get ...

  4. Android SQLite 数据库 增删改查操作

    Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...

  5. 图解IntelliJ IDEA 13版本对Android SQLite数据库的支持

    IntelliJ IDEA 13版本的重要构建之一是支持Android程序开发.当然对Android SQLite数据库的支持也就成为了Android开发者对IntelliJ IDEA 13版本的绝对 ...

  6. Android——SQLite/数据库 相关知识总结贴

    android SQLite简介 http://www.apkbus.com/android-1780-1-1.html Android SQLite基础 http://www.apkbus.com/ ...

  7. Android Sqlite数据库加密

    Android使用的是开源的SQLite数据库,数据库本身没有加密,加密思路通常有两个: 1. 对几个关键的字段使用加密算法,再存入数据库 2. 对整个数据库进行加密 SQLite数据库加密工具: 收 ...

  8. android: SQLite 数据库的最佳实践

    6.5.1    使用事务 前面我们已经知道,SQLite 数据库是支持事务的,事务的特性可以保证让某一系列的操 作要么全部完成,要么一个都不会完成.那么在什么情况下才需要使用事务呢?想象以下场 景, ...

  9. Android—SQLITE数据库的设计和升降级

    Google为Andriod的较大的数据处理提供了SQLite,他在数据存储.管理.维护等各方面都相当出色,功能也非常的强大.SQLite具备下列特点: 1.轻量级 使用 SQLite 只需要带一个动 ...

随机推荐

  1. OpenGL 小游戏 贪吃蛇1(2D)

    #include "stdafx.h" #include <GL/glut.h> #include <stdlib.h> #pragma comment(l ...

  2. 深入分析 Java 中的中文编码问题

    登录 (或注册) 中文 IBM 技术主题 软件下载 社区 技术讲座 打印本页面 用电子邮件发送本页面 新浪微博 人人网 腾讯微博 搜狐微博 网易微博 Digg Facebook Twitter Del ...

  3. php Output Control 函数 ob_系列函数详解

    <?php /* * 输出缓冲控制 * * flush — 刷新输出缓冲 ob_clean — 清空(擦掉)输出缓冲区 ob_end_clean — 清空(擦除)缓冲区并关闭输出缓冲 ob_en ...

  4. jdk安装配置具体分析

    JDK 选择安装目录 安装过程中会出现两次 安装提示 .第一次是安装 jdk ,第二次是安装 jre .建议两个都安装在同一个java文件夹中的不同文件夹中.(不能都安装在java文件夹的根目录下,j ...

  5. php-fpm配置文件的优化

    php-fpm中比较重要的两项参数是:request_terminate_timeoutpm.max_children request_terminate_timeout该值决定了php-fpm进程的 ...

  6. Win8.1密钥

    Win8.1 在线永久激活密钥一枚!  78BHN-M3KRH-PCP9W-HQJYR-Q9KHD [剩余次数:7K多+] 继续增加 [Key]:HPCJW-VGYW4-CR7W2-JG6Q7-K4Q ...

  7. jQuery判断对象是否是函数

    var show=function () { // body... } if($.isFunction(show)){ //是函数 }else{ //不是函数 }

  8. ubuntu编译运行xv6

    最近想找个简单的类Unix系统学习下, xv6不错的, 所有代码加起来不到一万行,首先把代码跑起来还是很重要的. # 下载xv6源码并编译 git clone git://pdos.csail.mit ...

  9. 【转】Ubuntu防火墙设置

    1.安装 sudo apt-get install ufw 2.启用 sudo ufw enable sudo ufw default deny 运行以上两条命令后,开启了防火墙,并在系统启动时自动开 ...

  10. 20145320《Java程序设计》第二次实验报告

    20145320<Java程序设计>第二次实验报告 北京电子科技学院(BESTI)实验报告 课程:Java程序设计 班级:1453 指导教师:娄嘉鹏 实验日期:2016.04.12 15: ...