MySQLiteHelper.java
import android.content.Context; //引入相关类
import android.database.sqlite.SQLiteDatabase; //引入相关类
import android.database.sqlite.SQLiteOpenHelper; //引入相关类
import android.database.sqlite.SQLiteDatabase.CursorFactory; //引入相关类
//继承自SQLiteOpenHelper的子类
public class MySQLiteHelper extends SQLiteOpenHelper{
public MySQLiteHelper(Context context, String name, CursorFactory factory,
int version) {
super(context, name, factory, version); //调用父类的构造器
}
@Override
public void onCreate(SQLiteDatabase db) { //重写onCreate方法
db.execSQL("create table if not exists hero_info(" //调用execSQL方法创建表
+ "id integer primary key,"
+ "name varchar,"
+ "level integer)");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
主Activity
package wyf.wpf; //声明包语句
import android.app.Activity; //引入相关类
import android.content.ContentValues; //引入相关类
import android.database.Cursor; //引入相关类
import android.database.sqlite.SQLiteDatabase; //引入相关类
import android.os.Bundle; //引入相关类
import android.widget.TextView; //引入相关类
//继承自Activity的子类
public class Sample_4_3 extends Activity {
MySQLiteHelper myHelper; //数据库辅助类对象的引用
TextView tv; //TextView对象的引用
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);//设置显示的屏幕
tv = (TextView)findViewById(R.id.tv); //获得TextView对象的引用
myHelper = new MySQLiteHelper(this, "my.db", null, 1); //创建MySQLiteOpenHelper辅助类对象
insertAndUpdateData(myHelper); //向数据库中插入和更新数据
String result = queryData(myHelper); //向数据库中查询数据
tv.setText("名字\t等级\n"+result); //将查询到的数据显示到屏幕上
}
//方法:向数据库中的表中插入和更新数据
public void insertAndUpdateData(MySQLiteHelper myHelper){
SQLiteDatabase db = myHelper.getWritableDatabase(); //获取数据库对象
//使用execSQL方法向表中插入数据
db.execSQL("insert into hero_info(name,level) values('Hero1',1)");
//使用insert方法向表中插入数据
ContentValues values = new ContentValues(); //创建ContentValues对象存储“列名-列值”映射
values.put("name", "hero2");
values.put("level", 2);
db.insert("hero_info", "id", values); //调用方法插入数据
//使用update方法更新表中的数据
values.clear(); //清空ContentValues对象
values.put("name", "hero2");
values.put("level", 3);
db.update("hero_info", values, "level = 2", null); //更新表中level为2的那行数据
db.close(); //关闭SQLiteDatabase对象
}
//方法:从数据库中查询数据
public String queryData(MySQLiteHelper myHelper){
String result="";
SQLiteDatabase db = myHelper.getReadableDatabase(); //获得数据库对象
Cursor cursor = db.query("hero_info", null, null, null, null, null, "id asc"); //查询表中数据
int nameIndex = cursor.getColumnIndex("name"); //获取name列的索引
int levelIndex = cursor.getColumnIndex("level"); //获取level列的索引
for(cursor.moveToFirst();!(cursor.isAfterLast());cursor.moveToNext()){ //遍历查询结果集,将数据提取出来
result = result + cursor.getString(nameIndex)+" ";
result = result + cursor.getInt(levelIndex)+" \n";
}
cursor.close(); //关闭结果集
db.close(); //关闭数据库对象
return result;
}
@Override
protected void onDestroy() {
SQLiteDatabase db = myHelper.getWritableDatabase(); //获取数据库对象
db.delete("hero_info", "1", null); //删除hero_info表中的所有数据
super.onDestroy();
}
}
分享到:
相关推荐
CuteSqlite,是轻量级数据库sqlite的图形化管理客户端,使用C++/WTL实现,支持Windows操作系统。
SQLite是一款开源、轻量级的嵌入式关系型数据库,被广泛应用于移动设备、桌面系统以及服务器环境。它不需要单独的服务器进程,而是作为一个库直接集成到应用程序中,因此得名“轻量级”。SQLite支持多种编程语言,...
作为轻量级数据库,它不需要独立的数据库服务器进程,可以直接在应用进程中运行,节省了资源,提高了效率。SQLite3 的设计目标是提供可靠的数据存储,同时保持易于使用和高效。 SQLite3 的主要特点包括: 1. **小巧...
SQLlite为一款轻量级的数据库,此文件里包含了System.Data.SQLite.dll文件,SQliteHelper.cs代码文件,SQLite的使用介绍文件,直接导入dll和cs文件即可,不需要写代码,调用示例在介绍文件内
在Android开发中,SQLite是一个非常重要的轻量级数据库系统,尤其适用于存储应用程序的结构化数据。SQLite被集成在Android系统中,为开发者提供了一个高效、可靠且易于使用的数据存储解决方案。在这个“学生管理系统...
sqlite3,轻量级数据库
在Android开发中,SQLite是一个非常重要的组件,它是一个轻量级的、开源的、嵌入式的SQL数据库引擎,被广泛用于存储和管理应用程序中的数据。SQLite数据库的优势在于其小巧、高效且无需单独的服务进程,使得它成为...
SQLite是一款广泛应用于嵌入式系统和个人计算机上的轻量级数据库引擎,由D. Richard Hipp创建并维护。它的设计目标是实现可移植性、可靠性和高效性,使得它可以在无需管理员或单独服务器进程的情况下运行,非常适合...
SQLiteExpert是一款专为SQLite数据库设计的轻量级内存数据库管理工具,它提供了高效、便捷的方式来创建、管理和维护SQLite数据库。SQLite是一种开源、无服务器、自包含的SQL数据库引擎,广泛应用于移动设备、嵌入式...
SQLite是一款轻量级的、开源的、自包含的数据库引擎,特别适合于嵌入式应用,无需单独的服务器进程,可以被直接集成到各种应用程序中。它的设计目标是提供一个可移植的、可靠的、高性能的数据库解决方案,尤其适用于...
在Android系统中,SQLite是一个非常重要的组成部分,它是一个轻量级的、开源的、关系型数据库,被广泛用于存储和管理应用程序中的数据。这个压缩包文件"Android源码——数据库SQLite.zip"可能包含了关于Android中...
《Android轻量级数据库框架解析》 在移动应用开发领域,Android系统以其开源、免费的特性,成为了全球最受欢迎的操作系统之一。在Android应用中,数据存储是不可或缺的一部分,而SQLite作为Android内置的关系型...
总的来说,SQLite是一个强大的轻量级数据库解决方案,适用于各种场景,包括作为Subversion等版本控制系统的工作副本数据存储。而“sqlite-shell-win32-x86”则提供了直观的命令行界面,便于数据库管理和维护。对于...
轻量级数据库如SQLite或 Realm,它们提供了面向对象的API和数据模型,使得开发者能够更直观地处理数据。 基于给定的标签“数据库 Android 架构设计 移动架构”,我们可以推断这是一个关于Android平台上数据库管理的...
4. **Web应用**: 作为轻量级数据库,可用于简单的Web应用后端。 #### 四、事务管理 SQLite支持事务处理机制,这在保证数据一致性方面非常重要。一个典型的事务周期包括开始、执行和提交/回滚几个阶段。具体来说: ...
5. **SQL支持**:虽然SQLite是一个轻量级数据库,但它支持标准SQL查询语言的大部分语法,使得数据操作更加灵活。 6. **内存数据库模式**:SQLite支持将整个数据库加载到内存中运行,从而极大地提高了数据访问速度。 ...
### 数据库SQLite在嵌入式系统中的...综上所述,SQLite作为一种轻量级的嵌入式数据库,在嵌入式系统中展现出强大的优势。无论是从其功能特性还是实际应用的角度来看,SQLite都是嵌入式系统开发者不可或缺的强大工具。
在Android应用开发中,SQLite是一个重要的组成部分,它是一个轻量级的、嵌入式的数据库引擎,用于存储应用程序的数据。SQLite ORM(对象关系映射)框架则简化了Android开发者与SQLite数据库之间的交互,使得数据操作...
Better.db 轻量级数据库,替代Sqlite3安装: npm install better.db 或使用速记npm i better.db输入: 用节点require()导入const better = require ( "better.db" ) ;创建一个新的数据库从记忆里const db = new ...