`
king_tt
  • 浏览: 2329928 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

【Android 开发教程】使用数据库

 
阅读更多

本章节翻译自《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开发中的数据库连通性,特别是使用SQLite数据库。SQLite是Android平台上的默认数据库,它是一个轻量级的关系型数据库,适用于移动设备,因为它不需要服务器进程,且能高效管理数据。 首先,介绍...

    Android开发教程(完整版)

    新版Android开发教程&笔记--基础入门一.pdf 新版Android开发教程&笔记--基础入门二.pdf 新版Android开发教程&笔记三--环境搭建与解析.pdf ...新版Android开发教程+笔记十二--文件存取、数据库编程.pdf

    Android_开发教程之数据库连通性

    ### Android开发教程之数据库连通性详解 #### 引言 在移动应用开发领域,特别是Android平台上,数据库的使用极为普遍。本地数据库可以为用户提供离线功能,提高应用性能,并支持复杂的查询操作。本篇文章将重点...

    新版android开发教程 笔记

    不错的笔记 新版Android开发教程&笔记--基础入门一 新版Android开发教程&笔记--基础入门二 ...新版Android开发教程+笔记十二--文件存取、数据库编程 新版Android开发教程+笔记十三(待续)--应用、permission、资源

    新版Android开发教程及笔记-完整版.pdf

    新版Android开发教程&笔记--基础入门一.pdf 新版Android开发教程&笔记--基础入门二.pdf ...新版Android开发教程+笔记十二--文件存取、数据库编程.pdf 新版Android开发教程+笔记十三(待续)--应用、permission、资源.pdf

    新版Android开发教程

    新版Android开发教程 新版Android开发教程&笔记01--基础入门 新版Android开发教程&笔记02--基础入门 ...新版Android开发教程+笔记12--文件存取、数据库编程 新版Android开发教程+笔记13(待续)--应用、permission、资源

    Android开发教程笔记完全版 pdf

    这份"Android开发教程笔记完全版"涵盖了Android开发的基础到高级主题,旨在帮助开发者全面理解并掌握Android应用的构建过程。 一、Android系统概述 Android是由Google主导的开源操作系统,基于Linux内核。它的开放...

    Android开发教程完全版

    新版Android开发教程&笔记--基础入门一.pdf 新版Android开发教程&笔记--基础入门二.pdf ...新版Android开发教程+笔记十二--文件存取、数据库编程.pdf 新版Android开发教程+笔记十三(待续)--应用、permission、资源.pdf

    Android开发中使用SQLite数据库的教程chm版最新版本

    Android使用SQLite数据库进行开发的教程,chm格式,SQLite 是一款非常流行的嵌入式数据库,它支持 SQL 查询,并且只用很少的内存。Android 在运行时集成了 SQLite,所以每个 Android 应用程序都可以使用 SQLite ...

    Android 安卓 开发教程 PDF 电子书

    总之,《Android 安卓 开发教程》虽然年代稍久,但其内容仍然适用于当前的Android开发学习。通过这本书,读者可以全面了解Android开发的基本概念和实践,为进一步深入学习和项目开发打下坚实基础。

    最详细的Android开发教程实例

    本教程"最详细的Android开发教程实例"旨在提供一个全面的学习路径,帮助新手和有经验的开发者深入理解Android开发的核心概念和技术。 【Android开发入门】: Android开发入门是学习Android编程的第一步。"101- ...

    Android开发教程基础版 Android中文开发教程

    《Android开发教程基础版》是一本专为初学者设计的Android应用开发指南,旨在帮助读者快速掌握Android开发的基础知识和技能。本教程以其清晰易懂的特性,为想要踏入Android开发领域的学习者提供了全面的指导。 一、...

    Android零基础教程视频链接

    android基础教程,里边包括新版Android开发教程&笔记1--基础入门,Android开发教程&笔记2--基础入门二,Android开发教程&笔记3--环境...文件存取、数据库编程.Android开发教程+笔记13(待续)--应用、permission、资源

    新版Android开发教程&笔记--基础入门

    包含内容如下: 新版Android开发教程&笔记--基础入门一 新版Android开发教程&笔记--基础入门二 新版Android开发教程&笔记三--环境搭建与解析 ...新版Android开发教程+笔记十二--文件存取、数据库编程

    Android 新手开发教程 开发技巧合集 开发教程详细版 开发入门经典

    其次,"Android开发教程详细版.pdf"将深入探讨更复杂的主题,如多线程处理、网络编程、SQLite数据库操作、ContentProvider的使用,以及各种传感器和硬件接口的访问。此外,还可能涉及UI设计,如自定义View,以及动画...

    android基础教程

    开办新的Android技术交流群:147064080,欢迎大家加入! android基础教程,里边包括 ...新版Android开发教程+笔记12--文件存取、数据库编程.pdf 新版Android开发教程+笔记13(待续)--应用、permission、资源.pdf

    Android开发教程1

    "新版Android开发教程+笔记十二--文件存取、数据库编程.pdf"涵盖了Android中的数据存储,包括内部存储、外部存储、SQLite数据库的使用,以及ContentProvider的基本概念,这些都是Android应用中数据管理的重要部分。...

    Android开发学习教程—Android使用SQLite数据库

    ### Android开发学习教程—深入解析Android使用SQLite数据库 #### SQLite数据库概述 SQLite是一款轻量级、高性能的嵌入式数据库,被广泛应用于各种资源受限的环境中,如移动设备。它支持标准的SQL语言,占用内存极...

    经典Android开发教程奉献

    在Android开发领域,掌握核心概念和技术是至关重要的。这篇教程集合了全面的Android开发知识,旨在帮助初学者和有经验的开发者...这个“经典Android开发教程”将引导你逐步掌握这些技能,祝你在开发旅程中取得成功。

Global site tag (gtag.js) - Google Analytics