Android开发:SQLite3数据库基础入门教程

需积分: 10 5 下载量 174 浏览量 更新于2024-09-14 收藏 111KB PDF 举报
"这篇文档是关于Android中SQLite3的基础入门教程,适合初学者学习。SQLite3是一个广泛应用的嵌入式数据库系统,具有轻量级、高效且免费的特点,被广泛集成在各大公司和开源项目中,包括Android。尽管SQLite3在功能上与传统关系数据库相比有些限制,如缺少外键约束、右外连接和全外连接,以及ALTER TABLE等操作,但其基本的SQL语句如SELECT、INSERT、UPDATE和CREATE/DROP依然支持。" 在Android开发环境中,SQLite数据库是每个应用程序默认可以使用的。对于熟悉JDBC的开发者来说,使用SQLite数据库的过程相对简单。SQLite3的主要数据类型包括TEXT、NUMERIC、INTEGER和REAL,同时它不区分大小写。 创建SQLite数据库主要有两种方法: 1. **命令行方式**:通过ADB工具进入Android设备的Linux控制台,导航到应用的data目录,然后创建databases目录,并使用sqlite3命令创建数据库文件。例如,创建一个名为`friends.db`的数据库后,可以使用SQLite命令行工具进行交互操作。完成操作后,可以在目录下看到生成的数据库文件。 2. **编码方式**:利用Android提供的`Context`类或其子类(如`Activity`)的方法来创建数据库。可以调用`openOrCreateDatabase()`方法,传入数据库名称和一个空的`SQLiteDatabase.CursorFactory`对象,以及一个标志来决定是否启用读写。这将在必要时创建新的数据库文件,或者打开已存在的数据库。 除了创建数据库,我们还需要进行表的创建和数据的操作。在Android中,可以使用SQLiteOpenHelper类来辅助数据库的版本管理和表的创建。通常,我们需要覆写它的`onCreate()`方法来执行CREATE TABLE语句,以及`onUpgrade()`方法来处理数据库升级。 例如,创建一个表的SQL语句可能是这样的: ```sql CREATE TABLE IF NOT EXISTS Users ( _id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT NOT NULL, age INTEGER ); ``` 在这个例子中,`Users`表包含三个字段:`_id`作为主键,`name`为文本类型且不能为空,`age`为整数类型。 对数据的插入、查询、更新和删除则可以通过SQLiteOpenHelper的子类实例创建的SQLiteDatabase对象来执行。例如,插入一条记录: ```java SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("name", "John Doe"); values.put("age", 30); db.insert("Users", null, values); ``` 查询、更新和删除同样可以通过调用对应的SQLiteDatabase方法完成,如`query()`, `update()`, `delete()`。 Android中的SQLite3是开发移动应用时存储数据的重要工具,它提供了便捷的API供开发者进行数据库操作,而无需复杂的服务器设置。了解和掌握SQLite3的基础知识对Android开发者来说是非常必要的。