【鸿蒙】数据库--创建数据库

1.创建数据库

做小demo那我们可以用Storeconfig类。这个可以创建数据库名,其余的值设为默认。我给的名字是RdbStoreTest.db。

onstart方法内

//
private static final RdbOpenCallback Callback = new RdbOpenCallback() {
        @Override
        public void onCreate(RdbStore rdbStore) {
            //数据库创建时被回调,开发者可以在该方法中初始化表结构,并添加一些应用使用到的初始化数据。
            rdbStore.executeSql("CREATE TABLE IF NOT EXISTS test"
                    +"(id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL, age INTEGER, INTEGER, salary REAL)");

        }

        @Override
        public void onUpgrade(RdbStore rdbStore, int i, int i1) {

        }
    };
    	@Override
    	public void onStart(Intent intent) {
	        super.onStart(intent);
	        super.setUIContent(ResourceTable.Layout_ability_main);
			// 创建数据库 准备配置信息,只配置数据库名字,其他为默认值
	        StoreConfig config = StoreConfig.newDefaultConfig("RdbStoreTest.db");
	
	        //创建数据库的实质循环,重要的核心类
	        DatabaseHelper helper=new DatabaseHelper(this);
	        //进一步通过helper,获取数据库对象
	        
	        //传入四个参数
	        RdbStore rdbStore = helper.getRdbStore(config, 1, Callback, null);

在这里插入图片描述

在这里插入图片描述
getRdbStore传入参数:

第一个参数数据库基本信息,也就是config
第二个参数为版本号,便于开发者识别。这里设为1
第三个参数回调
第四个可以填null

然后通过RdbOpenCallback做初始化表结构,
在这里插入图片描述
因为这个类是抽象类,所以实例化时会自动创建抽象方法onCreate,onUpgrade

类名接口名描述
RdbOpenCallbackpublic abstract void onCreate(RdbStore store)数据库创建时被回调,开发者可以在该方法中初始化表结构,并添加一些应用使用到的初始化数据。
RdbOpenCallbackpublic abstract void onUpgrade(RdbStore store, int currentVersion, int targetVersion)数据库升级时被回调

用sql语句创建表格,当然也可以不用。

public void onCreate(RdbStore rdbStore) {
            //开发者可以在该方法中初始化表结构,并添加一些应用使用到的初始化数据。
            rdbStore.executeSql("CREATE TABLE IF NOT EXISTS test"
                    +"(id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL, age INTEGER, INTEGER, salary REAL)");
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

弈鸣coding

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值