- 浏览: 264260 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (88)
- JAVA / base (26)
- JAVA / web (12)
- JAVA / Lib-tools (5)
- SERVER / tomcat (4)
- DB / mysql (4)
- DB / mongodb (2)
- DB / memcached (2)
- DB / redis (2)
- WEB / Front-end (3)
- WEB / security (4)
- WEB / css (2)
- WEB / js (4)
- OS / linux (3)
- IT / Architecture (4)
- IT / other (2)
- Android (9)
- Go (1)
- Other (1)
- OS / Mac (2)
最新评论
-
Zero2Max:
哈哈,马士兵老师也发现了。
java实现接口的bug -
xly1981:
能像CSRF攻击一样带个图就更棒了
XSS跨站攻击 -
xmong:
df274119386 写道在javascript中看到下面的 ...
CSRF攻击与防御策略 -
df274119386:
在javascript中看到下面的语句 e.value = t ...
CSRF攻击与防御策略 -
xmong:
yzxqml 写道xmong 写道yzxqml 写道tomca ...
Tomcat集群
android数据存储之Sqlite
Sqlite是轻量级的嵌入式数据库,支持基本的sql语句,android系统集成了Sqlite数据库,所以在android应用程序中可以使用Sqlite数据库。
更多Sqlite学习可参见sqlite官网:http://www.sqlite.org/
在android移动开发中不是使用JDBC来操作数据库,因为JDBC会消耗太多系统资源,所以android提供了自己的一套API来使用Sqlite数据库。
(1)SQLiteOpenHelper(android.database.sqlite.SQLieOpenHelper),这是一个抽象类,我们可以继承这个类来使用它。它的构造方法如下:
SQLiteOpenHelper(Context context, String name, CursorFactory factory, int version)
在该构造方法中:第一个参数:是android的context类对象,第二个参数:是数据库名称,第三个参数:游标的工厂类,一般设为null,第四个参数:是数据库版本,一般是正整数。
public void onCreate(SQLiteDatabase db)
该方法是数据库被创建时被调用,可以在该方法中完成数据库的初始化工作(如创建数据库表)。即是说在调用SQLiteOpenHelper的getReadableDatabase()或getWritableDatabase()方法时该方法会被调用,而且只是数据库创建时才被调用,如果数据库已经存在,那么就不会调用该方法。
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
可在该方法中完成数据库的更新操作。即是说当数据库的version改变时该方法会被调用。
SQLiteDatabase getReadableDatabase();
调用该方法可以获取可读的SQLiteDatabase对象。
SQLiteDatabase getWritableDatabase();
调用该方法可以获取可写的SQLiteDatabase对象。
(2)SQLiteDatabase(android.database.sqlite.SQLiteDatabase),这个类实现了很多关于操作Sqlite数据库的方法,如对数据库增、删、改、查等操作都可以在这个类中完成。
要获取SQLiteDatabase对象我们可以通过SQLiteOpenHelper构建。
execSQL(String sql);
调用这个方法可以非常方便的执行一些基本的sql语句来操作SQLite数据库。如增、删、改、等操作,该方法适用于不返回结果的sql语句操作。除了该方法外SQLiteDatabase还提供一些常用方法实现数据库的增、删、改、查等操作。
long insert(String tableName, String nullColumHack, ContentValues values);
调用该方法可以向数据库中插入数据,第一个参数是数据要插入的表名,第二参数是表示如果插入的数据每一列都为空的话,需要指定此行中某一列的名称,系统将此列设置为null,不至于出错,第三个参数是ContentValues类型的变量,该变量可以存储key-value格式的值,只是key只能是字符串类型的值代表列名,value只能是一些基本类型的值代表要插入的值。
int delete(String tableName, String whereClause, String[] whereArgs);
调用该方法可以删除数据库中的数据,第一个参数是要删除数据的表名,第二个参数是删除中的where条件,第三个参数是where条件中的条件值,即可以在第二个参数的where条件设下占位符,然后通过第三个参数来设置该占位符的值。
int update(String table, ContentValues values, String whereClause, String[] whereArgs);
可以调用该方法来修改数据库中的数据,方法中的参数同上。
Cursor query(String tableName, String[] colums, String seletion, String[] selectionArgs, String groupby, String having, String orderby);
可以通过该方法查取数据库的数据,第一个参数是要查取的表名,第二个参数是需要查取的列,第三个参数查去的条件相当于where条件,第四个参数是查取条件的值,第五个参数是group by,第六个参数是having,第七个参数是order by,还有其他两个query方法,比该方法还要多两个参数,一个是distinct去重参数,一个是limit参数。
Cursor rawQuery(String sql, String[] selectionArgs);
通过该方法可以执行sql语句来查去数据,第一个参数是sql语句,第二参数是指定sql中的占位符的值。
(3)Cursor(android.database.Cursor)是SQLiteDatabase的查取数据库后返回的一个结果对象,它代表数据集的游标。我们可以遍历游标的数据集获取查取的数据。
上面是android提供的几个操作数据库对象的常用方法,如果想了解更多可以查看android自身的API.
下面我们可以通过一个列子来叙述android中怎样对Sqlite数据库进行操作。
实现如下:
MyDatabase:数据库结构类,存储数据库表结构信息。
MySqliteDatabase:sqlite数据库操作类,包含有实现SQLiteOpenHelper的内部类。
Activity3:activity类。
MySqliteDatabase实现如下:
Activity3实现如下
运行程序如下:
第一次运行程序的时候后台输出:create table:user
在输入框输入“xmong”,点击insert按钮,后台输出:insert data count:1
点击query按钮,后台输出:_id:1,name:xmong
在输入框中输入“1,xzm”,点击update按钮,清空输入框,在点击query按钮,后台输出:_id:1,name:xzm
在输入看输入“xzm”,点击delete按钮,在点击query按钮,后台无数据输出,xzm数据已经被删除。
上面演示过程表明该程序对sqlite数据库实现了一些基本增,删,改,查操作。
当然除了后台输出结果可以表明操作书库成功外,我们也可以同过android自带的工具adb来查看Sqlite数据库。
当我们第一次运行程序后,可以通过adb shell或者DDMS的File Explor查看/data/data/<包名>/databases目录下有一个db_test文件,该文件就是db_test数据库存储数据的文件。
运行cmd:
在adb shell中我们还可以通过命令来操作数据库:
源代码下载:http://xmong.iteye.com/blog/1852204
Sqlite是轻量级的嵌入式数据库,支持基本的sql语句,android系统集成了Sqlite数据库,所以在android应用程序中可以使用Sqlite数据库。
更多Sqlite学习可参见sqlite官网:http://www.sqlite.org/
在android移动开发中不是使用JDBC来操作数据库,因为JDBC会消耗太多系统资源,所以android提供了自己的一套API来使用Sqlite数据库。
(1)SQLiteOpenHelper(android.database.sqlite.SQLieOpenHelper),这是一个抽象类,我们可以继承这个类来使用它。它的构造方法如下:
SQLiteOpenHelper(Context context, String name, CursorFactory factory, int version)
在该构造方法中:第一个参数:是android的context类对象,第二个参数:是数据库名称,第三个参数:游标的工厂类,一般设为null,第四个参数:是数据库版本,一般是正整数。
public void onCreate(SQLiteDatabase db)
该方法是数据库被创建时被调用,可以在该方法中完成数据库的初始化工作(如创建数据库表)。即是说在调用SQLiteOpenHelper的getReadableDatabase()或getWritableDatabase()方法时该方法会被调用,而且只是数据库创建时才被调用,如果数据库已经存在,那么就不会调用该方法。
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)
可在该方法中完成数据库的更新操作。即是说当数据库的version改变时该方法会被调用。
SQLiteDatabase getReadableDatabase();
调用该方法可以获取可读的SQLiteDatabase对象。
SQLiteDatabase getWritableDatabase();
调用该方法可以获取可写的SQLiteDatabase对象。
(2)SQLiteDatabase(android.database.sqlite.SQLiteDatabase),这个类实现了很多关于操作Sqlite数据库的方法,如对数据库增、删、改、查等操作都可以在这个类中完成。
要获取SQLiteDatabase对象我们可以通过SQLiteOpenHelper构建。
execSQL(String sql);
调用这个方法可以非常方便的执行一些基本的sql语句来操作SQLite数据库。如增、删、改、等操作,该方法适用于不返回结果的sql语句操作。除了该方法外SQLiteDatabase还提供一些常用方法实现数据库的增、删、改、查等操作。
long insert(String tableName, String nullColumHack, ContentValues values);
调用该方法可以向数据库中插入数据,第一个参数是数据要插入的表名,第二参数是表示如果插入的数据每一列都为空的话,需要指定此行中某一列的名称,系统将此列设置为null,不至于出错,第三个参数是ContentValues类型的变量,该变量可以存储key-value格式的值,只是key只能是字符串类型的值代表列名,value只能是一些基本类型的值代表要插入的值。
int delete(String tableName, String whereClause, String[] whereArgs);
调用该方法可以删除数据库中的数据,第一个参数是要删除数据的表名,第二个参数是删除中的where条件,第三个参数是where条件中的条件值,即可以在第二个参数的where条件设下占位符,然后通过第三个参数来设置该占位符的值。
int update(String table, ContentValues values, String whereClause, String[] whereArgs);
可以调用该方法来修改数据库中的数据,方法中的参数同上。
Cursor query(String tableName, String[] colums, String seletion, String[] selectionArgs, String groupby, String having, String orderby);
可以通过该方法查取数据库的数据,第一个参数是要查取的表名,第二个参数是需要查取的列,第三个参数查去的条件相当于where条件,第四个参数是查取条件的值,第五个参数是group by,第六个参数是having,第七个参数是order by,还有其他两个query方法,比该方法还要多两个参数,一个是distinct去重参数,一个是limit参数。
Cursor rawQuery(String sql, String[] selectionArgs);
通过该方法可以执行sql语句来查去数据,第一个参数是sql语句,第二参数是指定sql中的占位符的值。
(3)Cursor(android.database.Cursor)是SQLiteDatabase的查取数据库后返回的一个结果对象,它代表数据集的游标。我们可以遍历游标的数据集获取查取的数据。
c.move(int offset); //以当前位置为参考,移动到指定行 c.moveToFirst(); //移动到第一行 c.moveToLast(); //移动到最后一行 c.moveToPosition(int position); //移动到指定行 c.moveToPrevious(); //移动到前一行 c.moveToNext(); //移动到下一行 c.isFirst(); //是否指向第一条 c.isLast(); //是否指向最后一条 c.isBeforeFirst(); //是否指向第一条之前 c.isAfterLast(); //是否指向最后一条之后 c.isNull(int columnIndex); //指定列是否为空(列基数为0) c.isClosed(); //游标是否已关闭 c.getCount(); //总数据项数 c.getPosition(); //返回当前游标所指向的行数 c.getColumnIndex(String columnName);//返回某列名对应的列索引值 c.getString(int columnIndex); //返回当前行指定列的值
上面是android提供的几个操作数据库对象的常用方法,如果想了解更多可以查看android自身的API.
下面我们可以通过一个列子来叙述android中怎样对Sqlite数据库进行操作。
实现如下:
MyDatabase:数据库结构类,存储数据库表结构信息。
MySqliteDatabase:sqlite数据库操作类,包含有实现SQLiteOpenHelper的内部类。
Activity3:activity类。
package com.sqlite; import android.provider.BaseColumns; /** * 常量类表示数据库表结构 * @author xmong */ public class MyDatabase { //数据库名 public final static String DB_NAME = "db_test"; //数据库版本 public final static int DB_VERSION = 1; /** * User表结构, * 实现BaseColumns常量接口,包含两个默认属性_ID和_COUNT */ public class User implements BaseColumns{ public final static String TAB_NAME = "user"; //表名 public final static String COL_NAME = "name"; //用户名 } }
MySqliteDatabase实现如下:
package com.sqlite; import android.content.ContentValues; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; /** * @author xmong */ public class MySqliteDatabase{ //sqlite数据库对象 private SQLiteDatabase sqliteDatabase = null; /** * 数据库帮助类,继承SQLiteOpenHelper */ static class DatabaseHelper extends SQLiteOpenHelper{ /** * 构造数据库对象 * @param context context对象 * @param name 数据库名 * @param factory 可选游标工厂,通常可是null * @param version 当前数据库版本 */ public DatabaseHelper(Context context, String name, CursorFactory factory, int version) { super(context, name, factory, version); } //根据context构建数据库帮助对象 public DatabaseHelper(Context context) { //调用自身构造方法 this(context, MyDatabase.DB_NAME, null, MyDatabase.DB_VERSION); } /** * 该函数是在第一次创建数据库的时候执行,即第一次调用SQLiteOpenHelper对象的 * getWritableDatabase()或getReadableDatabase()方法时才执行该方法 * 可用于执行数据库初始化工作 */ @Override public void onCreate(SQLiteDatabase db) { System.out.println("create table:"+ MyDatabase.User.TAB_NAME); //创建表sql语句 String sql = "create table "+MyDatabase.User.TAB_NAME +" ("+MyDatabase.User._ID+" integer primary key autoincrement," +MyDatabase.User.COL_NAME+" varchar(20))"; //执行sql语句 db.execSQL(sql); } /** * 第一个参数是SQLiteDatabase对象,第二个参数是旧的数据库版本,第三个参数是新的数据库版本号, * 可用于执行数据库的升级,将一个数据库从旧版本转变到新版本执行相应的操作 */ @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { //可执行一些升级或修改数据库操作 System.out.println("update database"); } } /** * 根据context构建sqlite数据库对象 * @param context */ public MySqliteDatabase(Context context) { /** * 通过调用数据库帮助对象SQLiteOpenHelper的getWritableDatabase()方法 * 获取一个可读写的数据库对象sqliteDatabase */ sqliteDatabase = (new DatabaseHelper(context)).getWritableDatabase(); } /** * 插入数据库记录 * @param name 用户名称 * @return 返回插入的记录条数 */ public long insertData(String name){ //通过ContentValues来保存表字段对应的数据值 ContentValues cv = new ContentValues(); cv.put(MyDatabase.User.COL_NAME, name); /** * 第一个参数:数据库表名, * 第二个参数:插入中值都为空则指定某一列的值null * 第三个参数:需插入数据 */ return sqliteDatabase.insert(MyDatabase.User.TAB_NAME, null, cv); } /** * 查取所有表记录数据 * @return 返回数据游标 */ public Cursor queryData(){ return sqliteDatabase.query(MyDatabase.User.TAB_NAME, new String[]{MyDatabase.User._ID, MyDatabase.User.COL_NAME}, null, null, null, null, null); } /** * 根据用户名查取数据 * @param name 用户名 * @return 返回数据游标 */ public Cursor queryData(String name){ return sqliteDatabase.query(MyDatabase.User.TAB_NAME, new String[]{MyDatabase.User._ID, MyDatabase.User.COL_NAME}, MyDatabase.User.COL_NAME+"=?", new String[]{name}, null, null, null); } /** * 根据用户id修改用户名 * @param id 用户id * @param name 用户名 * @return 返回修改的记录数 */ public int updateData(int id, String name){ ContentValues cv = new ContentValues(); cv.put(MyDatabase.User.COL_NAME, name); return sqliteDatabase.update(MyDatabase.User.TAB_NAME, cv, MyDatabase.User._ID+"=?", new String[]{id+""}); } /** * 根据用户名删除数据 * @param name 用户名 * @return 返回删除的记录数 */ public int deleteData(String name){ return sqliteDatabase.delete(MyDatabase.User.TAB_NAME, MyDatabase.User.COL_NAME+"=?", new String[]{name}); } /** * 删除数据库 * @param context */ public void deleteDatabase(Context context){ System.out.println("delete database:"+MyDatabase.DB_NAME); context.deleteDatabase(MyDatabase.DB_NAME); } /** * 关闭数据库,数据库操作完后需要释放资源 */ public void close() { sqliteDatabase.close(); } }
Activity3实现如下
package com.sqlite; import com.example.R; import android.os.Bundle; import android.view.KeyEvent; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.EditText; import android.app.Activity; import android.database.Cursor; public class Activity3 extends Activity { private EditText editText; //输入框 private Button insertBtn; //插入按钮 private Button queryBtn; //查询按钮 private Button updateBtn; //更新按钮 private Button deleteBtn; //删除按钮 //数据库对象 private MySqliteDatabase mySqliteDatabase; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity3); //从视图中获取控件对象 editText = (EditText)findViewById(R.id.text); insertBtn = (Button)findViewById(R.id.insert); queryBtn = (Button)findViewById(R.id.query); updateBtn = (Button)findViewById(R.id.update); deleteBtn = (Button)findViewById(R.id.delete); //为按钮对象设置点击事件 insertBtn.setOnClickListener(insertBtnClick); queryBtn.setOnClickListener(queryBtnClick); updateBtn.setOnClickListener(updateBtnClick); deleteBtn.setOnClickListener(deleteBtnClick); //构建sqlite数据库对象 mySqliteDatabase = new MySqliteDatabase(Activity3.this); //mySqliteDatabase.deleteDatabase(Activity3.this);//删除数据库 } //插入按钮点击事件监听器 OnClickListener insertBtnClick = new OnClickListener() { @Override public void onClick(View v) { //获取文本输入的用户名,将其插入数据库 String text = editText.getText().toString().trim(); long i = mySqliteDatabase.insertData(text); System.out.println("insert data count:"+i); } }; //查取按钮点击事件监听器 OnClickListener queryBtnClick = new OnClickListener() { @Override public void onClick(View v) { String text = editText.getText().toString().trim(); //根据输入框文本查取数据库数据,文本问空默认查取所有数据 Cursor cursor = null; if ("".equals(text)) { cursor = mySqliteDatabase.queryData(); }else{ cursor = mySqliteDatabase.queryData(text); } //遍历游标输出查取的数据 for(cursor.moveToFirst();!cursor.isAfterLast();cursor.moveToNext()){ String str = MyDatabase.User._ID+":"+cursor.getInt(cursor.getColumnIndex(MyDatabase.User._ID)) +","+MyDatabase.User.COL_NAME+":"+cursor.getString(cursor.getColumnIndex(MyDatabase.User.COL_NAME)); System.out.println(str); } } }; //修改按钮点击事件监听器 OnClickListener updateBtnClick = new OnClickListener() { @Override public void onClick(View v) { //根据输入文本修改用户数据,id和用户名用逗号分隔,根据id号修改用户名 String text = editText.getText().toString().trim(); String[] arr = text.split(","); mySqliteDatabase.updateData(Integer.parseInt(arr[0]), arr[1]); } }; //删除按钮点击事件监听器 OnClickListener deleteBtnClick = new OnClickListener() { @Override public void onClick(View v) { //根据输入的用户名输出数据 String text = editText.getText().toString().trim(); mySqliteDatabase.deleteData(text); } }; //按键事件 public boolean onKeyUp(int keyCode, KeyEvent event) { //当按键为回退键是结束这个activity if (keyCode == KeyEvent.KEYCODE_BACK) { //关闭数据库,释放资源 mySqliteDatabase.close(); Activity3.this.finish(); } return true; }; }
运行程序如下:
第一次运行程序的时候后台输出:create table:user
在输入框输入“xmong”,点击insert按钮,后台输出:insert data count:1
点击query按钮,后台输出:_id:1,name:xmong
在输入框中输入“1,xzm”,点击update按钮,清空输入框,在点击query按钮,后台输出:_id:1,name:xzm
在输入看输入“xzm”,点击delete按钮,在点击query按钮,后台无数据输出,xzm数据已经被删除。
上面演示过程表明该程序对sqlite数据库实现了一些基本增,删,改,查操作。
当然除了后台输出结果可以表明操作书库成功外,我们也可以同过android自带的工具adb来查看Sqlite数据库。
当我们第一次运行程序后,可以通过adb shell或者DDMS的File Explor查看/data/data/<包名>/databases目录下有一个db_test文件,该文件就是db_test数据库存储数据的文件。
运行cmd:
>adb shell #cd /data/data/com.example/databases #ls db_test
在adb shell中我们还可以通过命令来操作数据库:
#sqlite3 db_test sqlite>.schema CREATE TABLE android_metadata (locale TEXT); CREATE TABLE user(id integer primary key autoincrement, name varchar(20)); sqlite>select * from user 1|xmong sqlite>.quit
源代码下载:http://xmong.iteye.com/blog/1852204
发表评论
-
android数据存储之Network
2013-04-24 00:00 1128android数据存储之Network ... -
android数据存储之SDCard
2013-04-24 00:00 1574android数据存储之SDCard 我们都知道androi ... -
android数据存储之ContentProvider
2013-04-23 23:08 2106android数据存储之ContentPr ... -
android数据存储之Files
2013-04-23 23:03 1529android数据存储之Files Files存储可以通过A ... -
android数据存储之SharedPreferences
2013-04-23 23:01 1508android数据存储之SharedPreferences ... -
android数据存储
2013-04-23 17:55 1363Android的数据存储 在Android中提供了6种数据存 ... -
Android和Handler那些事
2013-04-16 18:59 1345Android和Handler那些事 目录 1 HANDL ... -
从java web到android
2013-04-16 15:15 1476几年来一直从事java web的开发,最近组里开始接手一些an ...
相关推荐
Android 数据存储 SQLite Android 数据存储是 Android 应用程序中的一个重要组件,它负责存储和管理应用程序中的数据。在 Android 中,有多种数据存储方式,包括 SharedPreferences、内部文件存储、SD 卡存储和 ...
本文将详细讲解Android数据存储以及SQLiteHelper的使用。 SQLite是Android系统内置的关系型数据库,它轻量级、高效且易于使用。在Android中,SQLite数据库主要用于存储结构化的数据,如用户信息、应用配置等。...
"Android 手机 App 程序中 SQLite 数据存储应用" Android 手机 App 程序中 SQLite 数据存储应用是 Android 手机 App 程序开发中的一个重要组成部分。随着 IT 行业的高速发展,移动通信技术的更新速度日新月异。...
在Android应用开发中,数据存储是一项至关重要的任务,用于保存用户数据、应用程序状态以及其它关键信息。SQLite是一个轻量级的、嵌入式的关系数据库,它被广泛应用于Android系统中,为开发者提供了高效且灵活的数据...
在Android开发中,SQLite是一个重要的组成部分,它是轻量级的数据库系统,被广泛用于本地数据存储。SQLite数据库在Android应用中扮演着至关重要的角色,它允许开发者创建、修改和管理数据库,无需用户干预,提供了...
在Android应用开发中,SQLite是一个重要的本地数据存储方式。SQLite是一个轻量级的、开源的、自包含的关系型数据库系统,它不需要单独的服务器进程,也不需要特定的权限管理。SQLite数据库可以被嵌入到各种应用程序...
Android数据存储SQLite - 事务操作
首先,我们来关注标题中的关键信息:“android数据操作,sqlite”。这意味着我们将讨论如何在Android应用中使用SQLite进行数据的增删改查。在Android中,通常通过SQLiteOpenHelper这个辅助类来创建和管理SQLite...
《数据存储之SQLite详解》 SQLite,作为一款轻量级的数据库引擎,广泛应用于移动设备、嵌入式系统以及各种应用程序中,它以其开源、无服务器、自包含、可移植等特性深受开发者喜爱。本文将深入探讨SQLite的核心概念...
SQLite是一个轻量级的嵌入式数据库,适用于移动设备,它能高效地存储和检索数据。 首先,你需要创建一个SQLite数据库。在Android Studio中,这通常通过实现SQLiteOpenHelper类来完成。在这个例子中,我们有一个名为...
在Android应用开发中,本地数据存储是至关重要的,SQLite数据库作为一种轻量级的数据库系统,被广泛用于存储和管理应用程序中的结构化数据。本篇文章将深入探讨如何在Android中使用SQLite进行基本的增删改查操作,以...
在Android中创建的SQLite数据库存储在:/data/data/<包名>/databases/目录下。 主要特点: -轻量级 -独立性,没有不依赖,无需安装 -跨平台,支持众多操作系统 -支持高达2TB大小的数据库 -每个数据库以单个文件的...
在Android开发中,SQLite是一个非常重要的数据存储工具。SQLite是一个轻量级的、关系型的数据库,它嵌入到Android系统中,为应用程序提供本地数据存储功能。SQLite数据库的优势在于其小巧、快速、稳定,无需单独的...
总的来说,"Android源码——数据库SQLite.zip"的内容涵盖了SQLite在Android中的使用、数据库的创建与管理、SQL操作、事务处理、性能优化等方面的知识,对于深入理解Android应用的数据存储机制具有很高的学习价值。
在Android应用开发中,数据存储是一项至关重要的任务,SQLite数据库是Android系统内置的轻量级数据库,常用于存储结构化数据。本节我们将深入探讨SQLite的进阶使用,特别是关于查询方面的技巧。SQLite数据库提供了...
Android 平台中的 SQLite 数据库在存储 DateTime 类型的数据时会遇到一些问题。本文将详细介绍这些问题和解决方案。 日期类型数据的存储问题 ------------------------- 在 SQLite 中,日期类型数据的存储方式有...
在Android开发中,SQLite是一个非常重要的组成部分,它是一款轻量级的数据库系统,用于存储应用程序中的结构化...对于Android开发者来说,掌握SQLite的使用是必不可少的技能,因为它极大地简化了数据存储和管理的过程。
Android 绿豆通讯录( SQLite数据库 + ListView数据展示控件 ) https://blog.csdn.net/weixin_44949135/article/details/106029404 采用 SQLite数据库 + ListView数据展示控件,可将用户添加的所有信息,分条...
"Android之SQLite实现增删改查" Android平台中,SQLite是一种轻量级的关系型数据库,广泛应用于移动应用开发中。在本例子中,我们将学习如何使用SQLite来实现增删改查操作。 标题解释 "Android之SQLite实现增删改...
在Android开发中,SQLite数据库是应用内数据存储的常用方式,尤其适合小规模的数据存储。SQLite是一个轻量级的、关系型的数据库,它不需要单独的服务器进程,且支持标准SQL语法,使得开发者能方便地进行数据操作。...