当前位置:   article > 正文

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

rdbstore ndk

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);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28

在这里插入图片描述

在这里插入图片描述
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
  • 2
  • 3
  • 4
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/294883
推荐阅读
相关标签
  

闽ICP备14008679号