在android studio中用SQLiteOpenHelper()方法建立数据库

在android studio中存储数据有三个方法,分别是:
(1)简单存储——SharedPreferences
(2)文件存储:
内部存储——应用程序私有文件
外部存储——SD卡
资源文件——只读( RAW 、XML)
(3)数据库存储——SQLiteDataBase

今天我们讲讲在android studio中利用数据库存储中的SQLiteOpenHelper()方法建立数据库
SQLiteOpenHelper中需要重载函数:
onCreate( ):利用SQL语句,在系统中创建数据库(表)功能
onUpgrade( ):利用SQL语句,在系统中升级数据库(表)功能
注:
onCreate()方法只有第一次数据库创建时会用到
onUpgrade( )方法在版本更新会用到

SQLiteOpenHelper中被调用的函数:
getWritableDatabase( ):获取一个可读写的SQLiteDatabase对象
getReadableDatabase( ):获取一个只读的SQLiteDatabase对象

创建数据库

1.新建一个类继承SQLiteOpenHelper
在这里插入图片描述
这里按Alt+Enter俩次添加构造方法
在这里插入图片描述

public class MySQLOpenHelper extends SQLiteOpenHelper {
    public MySQLOpenHelper(@Nullable Context context , @Nullable String name , @Nullable SQLiteDatabase.CursorFactory factory , int version) {
        super( context , name , factory , version );
    }

(1)这个方法里面是用来创建数据库的
context是一个访问application环境全局信息的接口,通过它可以访问application的资源和相关的类
context其主要功能如下:
启动Activity
启动和停止Service
发送广播消息(Intent)
注册广播消息(Intent)接收者
可以访问APK中各种资源(如Resources和AssetManager等)
可以访问Package的相关信息
APK的各种权限管理

Context就是一个对APK包无所不知的大管家,大家需要什么,直接问它就可以了
(2)name是数据库的名字
(3)CursorFactory factory游标工厂,用来指向数据库里面的某一行
CursorFactory 用来创建游标的,默认值为null,指向一开始的位置
(4)version数据库的版本号
版本号只能增加,不能递减,要不然程序会崩溃

其他俩个方法是用来创建表的,接下来会讲到
我们继续构建数据库:
在 MySQLOpenHelper类中重构代码:

public class MySQLOpenHelper extends SQLiteOpenHelper {
    public MySQLOpenHelper(@Nullable Context context ) {//name是数据库名字,后缀加.db
        super( context , "SQLite.db" , null , 1 );
    }

在MainActivity类中调用这个方法

MySQLOpenHelper helper=new MySQLOpenHelper( this );

然后再在MainActivity类中实例化数据库
添加代码如下

 MySQLOpenHelper helper=new MySQLOpenHelper( this );
        //创建一个可读可写的数据库
        SQLiteDatabase writableDatabase=helper.getWritableDatabase();
        //创建一个只可读的数据库
        SQLiteDatabase readableDatabase=helper.getReadableDatabase();

这个读者看需要自行构建代码,(只能存在一个)

我们的数据库创建完成了,接下来看看我们的数据库是否创建成功了呢
在看之前我们先运行我们的虚拟机,因为数据库是建立在虚拟机里面的,运行完之后我们去找创建的文件。
android3.0以前打开虚拟机中的文件是用导航栏中的Tools中Android,3.0以后为了提供的更新工具把它舍弃了
但我们可以通过View导航栏中Tool Windows中的Device File Explorer打开,找到data目录下的data下的程序的包名,找到创建的数据库(.db文件//另一个是相对应的日记文件),右键重新建立目录,然后用SQLite Expert Professional打开
SQLite Expert Professional下载地址:http://www.sqliteexpert.com
找到的文件如图
在这里插入图片描述
用SQLite Expert Professional 打开后如图
在这里插入图片描述
说明我们数据库已经创建好了

Android Studio中使用SQLite数据库,需要先创建一个SQLiteOpenHelper类来帮助我们创建和更新数据库和表。 SQLiteOpenHelper是一个抽象类,需要继承它并实现它的3个方法: 1. onCreate():当数据库创建时会调用此方法,通常在此方法中创建表和初始化数据。 2. onUpgrade():当数据库升级时会调用此方法,通常在此方法中进行表结构的更改等操作。 3. onDowngrade():当数据库降级时会调用此方法,通常在此方法中进行数据备份等操作。 除此之外,还需要使用以下类和方法: 1. SQLiteDatabase:用于执行SQL语句和管理数据库连接。 2. ContentValues:用于存储数据,相当于一个键值对的集合。 3. Cursor:用于查询数据并返回结果集。 下面是一个简单的SQLiteOpenHelper类的示例代码: ``` public class DatabaseHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "my_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 sql = "CREATE TABLE student (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER)"; db.execSQL(sql); } // 升级表 @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String sql = "ALTER TABLE student ADD COLUMN gender TEXT"; db.execSQL(sql); } // 降级表 @Override public void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) { String sql = "CREATE TABLE IF NOT EXISTS student_backup (id INTEGER PRIMARY KEY AUTOINCREMENT, name TEXT, age INTEGER)"; db.execSQL(sql); sql = "INSERT INTO student_backup SELECT * FROM student"; db.execSQL(sql); sql = "DROP TABLE student"; db.execSQL(sql); sql = "ALTER TABLE student_backup RENAME TO student"; db.execSQL(sql); } } ``` 在使用该SQLiteOpenHelper类时,需要先创建一个该类的实例,然后调用getWritableDatabase()或getReadableDatabase()方法获取一个SQLiteDatabase对象,再使用该对象执行SQL语句或查询操作。例如: ``` DatabaseHelper dbHelper = new DatabaseHelper(context); SQLiteDatabase db = dbHelper.getWritableDatabase(); String sql = "INSERT INTO student (name, age) VALUES ('张三', 18)"; db.execSQL(sql); Cursor cursor = db.query("student", new String[]{"id", "name", "age"}, null, null, null, null, null); while (cursor.moveToNext()) { int id = cursor.getInt(cursor.getColumnIndex("id")); String name = cursor.getString(cursor.getColumnIndex("name")); int age = cursor.getInt(cursor.getColumnIndex("age")); Log.d(TAG, "id=" + id + ", name=" + name + ", age=" + age); } cursor.close(); db.close(); ```
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值