Android SQLite数据库实例教程与使用指南
版权申诉
157 浏览量
更新于2024-10-13
收藏 36KB RAR 举报
资源摘要信息:"Android SQLite数据库使用实例与介绍"
1. Android SQLite数据库概述
SQLite是一个轻量级的数据库,它包含在Android SDK中,允许开发者在Android应用程序中使用SQL语言来创建和操作数据库。它以文件的形式存储在设备上,适合用于存储少量数据,如应用配置信息、轻量级的数据缓存等。SQLite作为一个嵌入式数据库,不需要配置或安装,因此特别适合在移动设备上使用。
2. SQLite数据库在Android中的使用场景
在Android应用开发中,SQLite数据库可以用来处理数据存储的多种需求。例如,可以用来保存应用的设置选项、用户数据、搜索历史、应用日志等。尽管Android提供了SharedPreferences用于轻量级的数据存储,但当需要存储结构化数据时,使用SQLite数据库会更加方便和有效。
3. 使用SQLiteOpenHelper类管理数据库
在Android开发中,通常使用SQLiteOpenHelper类来管理数据库的创建和版本管理。SQLiteOpenHelper提供了onCreate()和onUpgrade()两个回调方法,分别用于数据库创建时执行的初始化操作和数据库升级时的处理。开发者可以通过覆写这些方法来执行建表、添加或修改表结构等操作。
4. Android数据库操作示例
以下是一个简单的示例,演示如何在Android中使用SQLite数据库来创建一个用户表,并进行简单的增删改查操作。
```java
public class DatabaseHelper extends SQLiteOpenHelper {
private static final String DATABASE_NAME = "example.db";
private static final int DATABASE_VERSION = 1;
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
// 创建用户表
String CREATE_USERS_TABLE = "CREATE TABLE users (_id INTEGER PRIMARY KEY AUTOINCREMENT, "
+ "name TEXT, age INTEGER, address TEXT)";
db.execSQL(CREATE_USERS_TABLE);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// 升级数据库时删除旧表并创建新表
db.execSQL("DROP TABLE IF EXISTS users");
onCreate(db);
}
// 添加用户
public void addUser(String name, int age, String address) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", name);
values.put("age", age);
values.put("address", address);
db.insert("users", null, values);
db.close();
}
// 获取所有用户
public ArrayList<User> getAllUsers() {
ArrayList<User> users = new ArrayList<>();
String query = "SELECT * FROM users";
SQLiteDatabase db = this.getReadableDatabase();
Cursor cursor = db.rawQuery(query, null);
if (cursor.moveToFirst()) {
do {
User user = new User();
user.setId(cursor.getInt(cursor.getColumnIndex("_id")));
user.setName(cursor.getString(cursor.getColumnIndex("name")));
user.setAge(cursor.getInt(cursor.getColumnIndex("age")));
user.setAddress(cursor.getString(cursor.getColumnIndex("address")));
users.add(user);
} while (cursor.moveToNext());
}
cursor.close();
db.close();
return users;
}
// 更新用户信息
public int updateUser(int id, String name, int age, String address) {
SQLiteDatabase db = this.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", name);
values.put("age", age);
values.put("address", address);
return db.update("users", values, "_id = ?", new String[] { String.valueOf(id) });
}
// 删除用户
public void deleteUser(int id) {
SQLiteDatabase db = this.getWritableDatabase();
db.delete("users", "_id = ?", new String[] { String.valueOf(id) });
db.close();
}
}
```
在上述代码中,首先创建了DatabaseHelper类继承自SQLiteOpenHelper,实现了创建和更新数据库的方法。通过onCreate()方法创建了一个用户表,表中包含了_id、name、age和address四个字段。然后,通过addUser()、getAllUsers()、updateUser()和deleteUser()方法分别实现了向数据库中添加用户、获取所有用户、更新用户信息和删除用户的操作。
5. Android WebView组件介绍
Android WebView是用于在Android应用程序中显示网页内容的一个组件。它允许开发者将Web内容嵌入到应用程序中,提供了一个浏览器环境来渲染网页。WebView可以加载任何有效的网址,也可以加载本地HTML文件。
6. WebView的使用示例
以下是一个简单的示例,演示如何在Android应用中使用WebView来加载一个网页。
```java
public class WebViewActivity extends AppCompatActivity {
private WebView myWebView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_web_view);
myWebView = (WebView) findViewById(R.id.webview);
myWebView.getSettings().setJavaScriptEnabled(true); // 启用JavaScript
myWebView.loadUrl("***"); // 加载网页
}
@Override
public void onBackPressed() {
if (myWebView.canGoBack()) {
myWebView.goBack(); // 在网页中可以返回则返回上一页面
} else {
super.onBackPressed();
}
}
}
```
在WebViewActivity中,首先获取布局中的WebView组件,并在onCreate()方法中进行配置,启用JavaScript并加载指定的网页URL。同时,重写了onBackPressed()方法来处理用户按下返回键时的行为,若WebView中有可返回的网页历史记录,则先返回到上一个页面,否则调用super.onBackPressed()方法执行默认的返回操作。
总结:在Android开发中,SQLite数据库提供了一种便捷的方式来进行本地数据存储。通过SQLiteOpenHelper类的帮助,开发者可以高效地管理数据库的版本、创建和升级操作。同时,WebView组件允许开发者在Android应用中嵌入网页,提供了一种简便的方式来显示网页内容。这两个知识点在构建复杂的Android应用时非常有用,能够帮助开发者处理数据存储和网页显示的需求。
2179 浏览量
2022-09-14 上传
2022-09-21 上传
2021-08-11 上传
2011-09-21 上传
2021-08-11 上传
2022-09-20 上传
122 浏览量
2022-09-20 上传
weixin_42653672
- 粉丝: 110
- 资源: 1万+
最新资源
- 第33课
- 行业分类-设备装置-一种扩散性纸张增湿设备.zip
- 电子发票管理系统 衡德电子发票台账 v2.4
- qle:QMK徽标编辑器
- sEMG_Basic_Hand_movements:sEMG 基本手部运动的 Matlab 代码-matlab开发
- 立体像对的空间前方交会-点投影系数法+共线方程严密法(C# winform)
- 塔夫
- ImDisk Toolkit:Windows 版 Ramdisk 和映像文件的挂载-开源
- weatherForcast
- 行业分类-设备装置-一种承托、贴靠式安装的装配式墙体.zip
- 贷款合同管理 宏达贷款合同管理系统 v1.0
- shopping-list-modules-day
- psiat1
- Meross:研究Meross MSS310智能插头
- apache-maven-3.6.3-bin
- Eduonix-[removed]JavaScript游乐场,该资源库探索了不同的JS组件,功能以及如何使工具直观