本章节翻译自《Beginning-Android-4-Application-Development》,如有翻译不当的地方,敬请指出。
原书购买地址http://www.amazon.com/Beginning-Android-4-Application-Development/dp/1118199545/
DBAdapter已经创建好了,现在我们可以去使用数据库了。下面的章节,将介绍常规的CRUD(增加,读取,更新,删除)。
往表中添加联系人。
1. 使用之前的项目,在DatabasesActivity.java中添加一些代码。
public class DatabasesActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
DBAdapter db = new DBAdapter(this);
//---add a contact---
db.open();
long id = db.insertContact("Manoel", "manoel@hotmail.com");
id = db.insertContact("Mary", "mary@hotmail.com");
db.close();
}
}
2. 按F11在模拟器上面调试。
首先,创建一个DBAdapter类的实例:
DBAdapter db = new DBAdapter(this);
insertContact()方法返回被插入的行的id。如果这个过程发生错误,返回-1。
使用DDMS查看Android设备或模拟器,在databases文件夹下面将会看见名为MyDB的数据库。
获取所有的联系人。
使用getAllContacts() 方法,可以获取所有的联系人信息。
1. 使用之前的例子,并添加一些代码。
public class DatabasesActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
DBAdapter db = new DBAdapter(this);
/* //---add a contact---
db.open();
long id = db.insertContact("Manoel", "manoel@hotmail.com");
id = db.insertContact("Mary", "Mary@hotmail.com");
db.close();
*/
//--get all contacts---
db.open();
Cursor c = db.getAllContacts();
if (c.moveToFirst())
{
do {
DisplayContact(c);
} while (c.moveToNext());
}
db.close();
public void DisplayContact(Cursor c)
{
Toast.makeText(this,
"id: " + c.getString(0) + "\n" +
"Name: " + c.getString(1) + "\n" +
"Email: " + c.getString(2),
Toast.LENGTH_LONG).show();
}
}
2. 按F11在模拟器上面测试。
获取单独一条联系人信息。
db.open();
Cursor c = db.getContact(2);
if (c.moveToFirst())
DisplayContact(c);
else
Toast.makeText(this, "No contact found", Toast.LENGTH_LONG).show();
db.close();
更新联系人信息。
db.open();
if (db.updateContact(1, "Manoel, "Manoel@gmail.com"))
Toast.makeText(this, "Update successful.", Toast.LENGTH_LONG).show();
else
Toast.makeText(this, "Update failed.", Toast.LENGTH_LONG).show();
db.close();
删除一条联系人信息。
db.open();
if (db.deleteContact(1))
Toast.makeText(this, "Delete successful.", Toast.LENGTH_LONG).show();
else
Toast.makeText(this, "Delete failed.", Toast.LENGTH_LONG).show();
db.close();
这些操作都十分的类似,我就不一一赘述了。
更新数据库。
有些时候,可能需要往数据库中添加一个新的表,或者是往表里添加一些新的列。在这种情况下,就需要把数据从旧数据库迁移到新数据库。
如果想要更新数据库,那么改变DATADASE_VERSION常量即可。
DATABASE_VERSION之前为1,现改为2。
public class DBAdapter {
static final String KEY_ROWID = "_id";
static final String KEY_NAME = "name";
static final String KEY_EMAIL = "email";
static final String TAG = "DBAdapter";
static final String DATABASE_NAME = "MyDB";
static final String DATABASE_TABLE = "contacts";
static final int DATABASE_VERSION = 2;
重新跑一遍程序,就会看到如下的log信息。
这个例子里面,只是简单地删除数据库,然后重新创建了一个新的空白数据库。在真实的项目中,可能会保存之前的数据,然后把这些数据重新放入新的数据库里面。
分享到:
相关推荐
Android_开发教程之数据库连通性 Android_开发教程之数据库连通性
新版Android开发教程&笔记--基础入门一.pdf 新版Android开发教程&笔记--基础入门二.pdf 新版Android开发教程&笔记三--环境搭建与解析.pdf ...新版Android开发教程+笔记十二--文件存取、数据库编程.pdf
一个比较详细的android手机开发入门教程 目录: 新版Android开发教程&笔记--基础入门一 ...新版Android开发教程+笔记十二--文件存取、数据库编程 新版Android开发教程+笔记十三应用、permission、资源
文档介绍了引言,使用 Android 进行数据库访问 ,在一个单独的线程上插入数据库,结束语
不错的笔记 新版Android开发教程&笔记--基础入门一 新版Android开发教程&笔记--基础入门二 ...新版Android开发教程+笔记十二--文件存取、数据库编程 新版Android开发教程+笔记十三(待续)--应用、permission、资源
新版Android开发教程 新版Android开发教程&笔记01--基础入门 新版Android开发教程&笔记02--基础入门 ...新版Android开发教程+笔记12--文件存取、数据库编程 新版Android开发教程+笔记13(待续)--应用、permission、资源
新版Android开发教程&笔记--基础入门一.pdf 新版Android开发教程&笔记--基础入门二.pdf ...新版Android开发教程+笔记十二--文件存取、数据库编程.pdf 新版Android开发教程+笔记十三(待续)--应用、permission、资源.pdf
Android开发学习教程—Android使用SQLite数据库
新版Android开发教程&笔记--基础入门一.pdf 新版Android开发教程&笔记--基础入门二.pdf ...新版Android开发教程+笔记十二--文件存取、数据库编程.pdf 新版Android开发教程+笔记十三(待续)--应用、permission、资源.pdf
android基础教程,里边包括新版Android开发教程&笔记1--基础入门,Android开发教程&笔记2--基础入门二,Android开发教程&笔记3--环境...文件存取、数据库编程.Android开发教程+笔记13(待续)--应用、permission、资源
包含内容如下: 新版Android开发教程&笔记--基础入门一 新版Android开发教程&笔记--基础入门二 新版Android开发教程&笔记三--环境搭建与解析 ...新版Android开发教程+笔记十二--文件存取、数据库编程
开办新的Android技术交流群:147064080,欢迎大家加入! android基础教程,里边包括 ...新版Android开发教程+笔记12--文件存取、数据库编程.pdf 新版Android开发教程+笔记13(待续)--应用、permission、资源.pdf
android数据库开发--入门经典 - 基于sqlite的Android数据库开发经典教程,很适合Android初学者
的 Android SDK 提供了在 Android 平台上使用 JaVa 语言进行 Android 应用开发必须的工具和 API 接口。 特性 • 应用程序框架 支持组件的重用与替换 • Dalvik Dalvik Dalvik Dalvik 虚拟机 专为移动设备优化 • ...
新版Android开发教程+笔记12--文件存取、数据库编程 新版Android开发教程+笔记12--文件存取、数据库编程
Android 在运行时集成了 SQLite,所以每个 Android 应用程序都可以使用 SQLite 数据库。对数熟悉 SQL 的开发人员来时,使用 SQLite 相当简单。可以,由于 JDBC 不适合手机这种内存受限设备,所以 Android 开发人员...
Android基础教程,入门很好的 新版Android开发教程&笔记1--基础入门一 新版Android开发教程&...新版Android开发教程+笔记12--文件存取、数据库编程.pdf 新版Android开发教程+笔记13(待续)--应用、permission、资源.pdf
新版Android开发教程 笔记12--文件存取、数据库编程
【第一版第十三章】老罗Android开发视频--异步加载数据库(2集) 【第一版第十四章】老罗Android开发视频--多线程编程(7集) 【第一版第十五章】老罗Android开发视频--百度地图实战开发(10集)
├新版Android开发教程+笔记十二--文件存取、数据库编程.pdf ├新版Android开发教程+笔记十--基础UI编程4.pdf ├新版Android开发教程+笔记十三(待续)--应用、permission、资源.pdf ├新版Android开发教程+笔记十一--...