【Android源码 栏目提醒】:文章导读:在新的一年中,各位网友都进入紧张的学习或是工作阶段。
网学会员整理了Android源码 -Android 小项目之--SQLite 使用法门(附源码) - 编程语言的相关内容供大家参考,祝大家在新的一年里工作和学习顺利!
Android 小项目之--SQLite 使用法门 附
源码 每个应用程序都要使用数据
Android应用程序也不例外
Android使用开源的、与操作系统无关的SQL数据库 --大名鼎鼎的SQLite。
SQLite是一款轻量级数据库它的设计目的是嵌入式而且它占用的资源非常少在嵌入式设备中可能只需要几百KB这也是
Android 系统采用 SQLite 数据库的原因之一吧。
简介 轻量级 使用 SQLite 只需要带一个动态库就可以享受它的全部功能而且那个动态库的尺寸想当小。
独立性 SQLite 数据库的核心引擎不需要依赖第三方软件也不需要所谓的“安装”。
隔离性 SQLite 数据库中所有的信息比如表、视图、触发器等都包含在一个文件夹内方便管理和维护。
跨平台 SQLite 目前支持大部分操作系统不至电脑操作系统更在众多的手机系统也是能够运行比如
Android。
多语言接口 SQLite 数据库支持多语言编程接口。
安全性 SQLite 数据库通过数据库级上的独占性和共享锁来实现独立事务处理。
这意味着多个进程可以在同一时间从同一数据库读取数据但只能有一个可以写入数据。
SQLite使用介绍 首先先来看一下本篇例子继承 SQLiteOpenHelper 类实现的 dbHelper 类。
package com.terry import
android.content.ContentValues import
android.content.Context import
android.database.Cursor import
android.database.sqlite.SQLiteDatabase import
android.database.sqlite.SQLiteOpenHelper import
android.database.sqlite.SQLiteDatabase.CursorFactory public class dbHelper extends SQLiteOpenHelper private final static String DATABASE_NAMEsec_db private final static int DATABASE_VERSION1 private final static String TABLE_NAMEsec_pwd public final static String FIELD_ID_id public final static String FIELD_TITLEsec_Title public dbHelperContext context supercontext DATABASE_NAMEnull DATABASE_VERSION Override public void onCreateSQLiteDatabase db // TODO Auto-generated method stub String sqlCreate table TABLE_NAMEFIELD_ID integer primary key autoincrement FIELD_TITLE text db.execSQLsql Override public void onUpgradeSQLiteDatabase db int oldVersion int newVersion // TODO Auto-generated method stub String sql DROP TABLE IF EXISTS TABLE_NAME db.execSQLsql onCreatedb public Cursor select SQLiteDatabase dbthis.getReadableDatabase Cursor cursordb.queryTABLE_NAME null null null null null _id desc return cursor public long insertString Title SQLiteDatabase dbthis.getWritableDatabase ContentValues cvnew ContentValues cv.putFIELD_TITLE Title long rowdb.insertTABLE_NAME null cv return row public void deleteint id SQLiteDatabase dbthis.getWritableDatabase String whereFIELD_ID String whereValueInteger.toStringid db.deleteTABLE_NAME where whereValue public void updateint idString Title SQLiteDatabase dbthis.getWritableDatabase String whereFIELD_ID String whereValueInteger.toStringid ContentValues cvnew ContentValues cv.putFIELD_TITLE Title db.updateTABLE_NAME cv where whereValue 创建和打开数据库 上篇通过构造函数来创建数据库看一下构造函数的方法
android.database.sqlite.SQLiteOpenHelper.SQLiteOpenHelperContext context String name CursorFactory factory int version public SQLiteOpenHelper Context context String name SQLiteDatabase.CursorFactory factory int version Since: API Level 1 Create a helper object to create open and/or manage a database. The database is not actually created or opened until one of getWritableDatabase or getReadableDatabase is called. Parameters context to use to open or create the database name of the database file or null for an in-memory database factory to use for creating cursor objects or null for the default version number of the database starting at 1 if the database is older onUpgradeSQLiteDatabase int int will be used to upgrade the database Public Methods 大体可以理成如下如果进入此函数不存在此数据库则创建如果存在此数据库则打开连接只要进入此方法就可以用打开的连接获得getWritableDatabase或getReadableDatabase这两个方法。
创建表--》Create Table 一个数据库中可以包含多个表每一条数据都存在指定的表中要创建可以通过 execSQL 方法来执行一条 SQL 语句。
上面的方法为 代码 public void onCreateSQLiteDatabase db // TODO Auto-generated method stub String sqlCreate table TABLE_NAMEFIELD_ID integer primary key autoincrement FIELD_TITLE text db.execSQLsql 上面代码创建了表名为“sec_pwd” 的数据表表内存在一个 integer 类型的主键和一个 text 类型的字段并执行创建该表。
添加数据--》Insert 上面的代码封装了一个使用SQLite 的 insert 方法向表中添加数据但是insert 方法要求把数据都打包到 ContentValues 中 ContentValue 其实可就是一个 HashTableKey值是字段名称Value 值是字段的值。
通过 ContentValues 的put 方法就可以把数据库放到 ContentValue 对象中然后插入到表中去。
代码为 public long insertString Title SQLiteDatabase dbthis.getWritableDatabase ContentValues cvnew ContentValues cv.putFIELD_TITLE Title long rowdb.insertTABLE_NAME null cv return row 删除数据--》Delete 依此类推添加数据用Insert那么删除数据为Delete public void deleteint id SQLiteDatabase dbthis.getWritableDatabase String whereFIELD_ID String whereValueInteger.toStringid db.deleteTABLE_NAME where whereValue 修改数据--》Update public void updateint idString Title SQLiteDatabase dbthis.getWritableDatabase String whereFIELD_ID String whereValueInteger.toStringid ContentValues cvnew ContentValues cv.putFIELD_TITLE Title db.updateTABLE_NAME cv where whereValue 可根据自己需要修改字段自行加参数。
查询数据--》Query public Cursor select SQLiteDatabase dbthis.getReadableDatabase Cursor cursordb.queryTABLE_NAME null null null null null _id desc return cursor 在
Android 中查询数据是通过 Cursor 类来实现的当我们使用SQLiteDatabase.query方法时会得到一个Cursor对象Cursor指向的就是每一条数据。
它提供了很多有关查询的方法具体截图如下 现在dbHelper己经封装完毕接下来正式进入到我们实际例子中要操作的功能吧项目运行效果图 这里用到了Menu做功能按钮实例代码如下 package com.terry import
android.app.Activity import
android.database.Cursor import
android.database.sqlite.SQLiteCursor import
android.os.Bundle import
android.view.Menu import
android.view.MenuItem import
android.view.View import
android.widget.AdapterView import
android.widget.EditText import
android.widget.ListAdapter import
android.widget.ListView import
android.widget.SimpleCursorAdapter import
android.widget.AdapterView.OnItemClickListener import
android.widget.AdapterView.OnItemSelectedListener public class testDbActivity extends Activity private dbHelper db private Cursor myCursor private ListView myListView private EditText myEditText private int _id protected final static int MENU_ADDMenu.FIRST protected final static int MENU_EDITMenu.FIRST1 protected final static int MENU_DELETEMenu.FIRST2 Override public boolean onCreateOptionsMenuMenu menu // TODO Auto-generated method stub super.onCreateOptionsMenumenu menu.addMenu.NONE MENU_ADD 0 R.string.ADD menu.addMenu.NONE MENU_EDIT 0R.string.EDIT menu.addMenu.NONE MENU_DELETE 0R.string.DELETE return true Override public boolean onOptionsItemSelectedMenuItem item // TODO Auto-generated method stub super.onOptionsItemSelecteditem switch item.getItemId case MENU_ADD: operationadd break case MENU_EDIT: operationedit break case MENU_DELETE: operationdelete break default: break return true / Called when the activity is first created. / Override public void onCreateBundle savedInstanceState super.onCreatesavedInstanceState setContentViewR.layout.main myEditTextEditTextfindViewByIdR.id.EditText1 myListViewListViewfindViewByIdR.id.ListView1 dbnew dbHelpertestDbActivity.this myCursordb.select SimpleCursorAdapter adpaternew SimpleCursorAdapterthis R.layout.test myCursor new StringdbHelper.FIELD_TITLE new intR.id.topTextView myListView.setAdapteradpater myListView.setOnItemClickListenernew OnItemClickListener Override public void onItemClickAdapterView arg0 View arg1 int arg2 long arg3 // TODO Auto-generated method stub myCursor.moveToPositionarg2 _idmyCursor.getInt0 myEditText.setTextmyCursor.getString1 myListView.setOnItemSelectedListenernew OnItemSelectedListener Override public void onItemSelectedAdapterView arg0 View arg1 int arg2 long arg3 // TODO Auto-generated method stub SQLiteCursor scSQLiteCursorarg0.getSelectedItem _idsc.getInt0 myEditText.setTextsc.getString1 Override public void onNothingSelectedAdapterView arg0 // TODO Auto-generated method stub private void operationString cmd ifmyEditText.getText.toString.equals return ifcmdadd db.insert myEditText.getText.toString ifcmdedit db.update_id myEditText.getText.toString ifcmddelete db.delete_id myCursor.requery myListView.invalidateViews myEditText.setText _id0 至此功能己经基本完成。
上一篇:
android中c c 程序的调试 eclipse
下一篇:
7*30m公路预应力混凝土连续梁桥上部结构设计