成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

HarmonyOS 數據庫系列之關系型數據庫

數據庫 其他數據庫 OpenHarmony
移動端開發,數據存儲是非常重要的,鴻蒙也不例外,說到數據存儲,首要的就是數據庫了,數據庫的存儲機制是否完善,提供的功能是否簡單方便,直接影響開發者的開發速度和性能。

[[421539]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

前言

移動端開發,數據存儲是非常重要的,鴻蒙也不例外,說到數據存儲,首要的就是數據庫了,數據庫的存儲機制是否完善,提供的功能是否簡單方便,直接影響開發者的開發速度和性能。

作為鴻蒙開發者,最近就深入學習了鴻蒙的數據庫知識點,了解了存儲機制并且嘗試了使用,發現鴻蒙的數據庫真的做到了應有盡有,操作還簡單的地步。

概念

先來看看 鴻蒙的 關系型數據庫(Relational Database,RDB) 概念。

鴻蒙的RDB 是一種基于關系模型來管理數據的數據庫。

HarmonyOS關系型數據庫基于SQLite組件提供了一套完整的對本地數據庫進行管理的機制,對外提供了一系列的增、刪、改、查接口,也可以直接運行用戶輸入的SQL語句來滿足復雜的場景需要。HarmonyOS提供的關系型數據庫功能更加完善,查詢效率更高。

概念中一句話很重要,HarmonyOS提供的關系型數據庫功能更加完善,查詢效率更高。看到這里我當時是非常激動的,作為開發者難道不是最希望 使用的api在什么情況下都適用嗎?

下面看看鴻蒙數據庫的運作機制,了解機制才能了解數據庫開發的核心,也有利于擴展。

運作機制

HarmonyOS關系型數據庫對外提供通用的操作接口,底層使用SQLite作為持久化存儲引擎,支持SQLite具有的所有數據庫特性,包括但不限于事務、索引、視圖、觸發器、外鍵、參數化查詢和預編譯SQL語句。

關系型數據庫運作機制:

HarmonyOS 數據庫系列之關系型數據庫-鴻蒙HarmonyOS技術社區

看到上面的鴻蒙數據庫的運行機制 不難發現,主要工作還是在framework層做的封裝,然后調用JNI,使用的還是SQLite組件,不管 底層怎么做的開發,只要功能完善,體驗到位,鴻蒙應用端直接使用不是很香嗎?

約束與限制

1、數據庫中連接池的最大數量是4個,用以管理用戶的讀寫操作。

連接池的數量是有限制的 ,最大時4個,不過4個已經足夠使用了。

2、為保證數據的準確性,數據庫同一時間只能支持一個寫操作。

同一時間支持一個寫操作時非常重要的,為了防止數據存儲的正確性,鴻蒙做了這一個限制,但是作為多年的移動端開發者,一般這種多操作或者大數據操作,都會使用多線程,異步線程,或者放在線程池中,這樣就更完美了。

數據庫操作DataAbility

鴻蒙在創建類的時候 有一個 DataAbility,不知道各位開發者使用過了沒,其實這個就是為了數據庫操作爾來的。

添加步驟很簡單:

添加類的時候 選擇Empty DataAbility即可。

一、 配置:

添加類后 會自動生成如下配置:

  1.   "permissions": [ 
  2.     "com.huawei.codelab.DataAbilityShellProvider.PROVIDER" 
  3.   ], 
  4.   "name""com.hadiidbouk.databasemanager.database.DataAbility"
  5.   "icon""$media:icon"
  6.   "description""$string:dataability_description"
  7.   "type""data"
  8.   "uri""dataability://com.huawei.codelab.PersonDataAbility" 

 1、操作數據庫需要權限信息

  1. "permissions": [ 
  2.         "com.huawei.codelab.DataAbilityShellProvider.PROVIDER" 
  3.       ] 

 2、需要配置url,url很重要,在進行數據庫表操作的時候 需要保持一致

二 、DataAbility操作內容

默認創建的DataAbility類會自動重寫 數據庫的增,刪,改,查 幾種操作的函數。可以看下面:

  1. public class DataAbility extends Ability { 
  2.     private static final HiLogLabel LABEL_LOG = new HiLogLabel(3, 0xD001100, "Demo"); 
  3.     private static final String DB_NAME = "persondataability.db"
  4.     private static final String DB_TAB_NAME = "person"
  5.     private static final String DB_COLUMN_PERSON_ID = "id"
  6.     private static final String DB_COLUMN_NAME = "name"
  7.     private static final String DB_COLUMN_GENDER = "gender"
  8.     private static final String DB_COLUMN_AGE = "age"
  9.     private static final int DB_VERSION = 1; 
  10.  
  11.     private StoreConfig config = StoreConfig.newDefaultConfig(DB_NAME); 
  12.     private RdbStore rdbStore; 
  13.     private RdbOpenCallback rdbOpenCallback = new RdbOpenCallback() { 
  14.         @Override 
  15.         public void onCreate(RdbStore store) { 
  16.             store.executeSql("create table if not exists " 
  17.                     + DB_TAB_NAME + " (" 
  18.                     + DB_COLUMN_PERSON_ID + " integer primary key, " 
  19.                     + DB_COLUMN_NAME + " text not null, " 
  20.                     + DB_COLUMN_GENDER + " text not null, " 
  21.                     + DB_COLUMN_AGE + " integer)"); 
  22.         } 
  23.         @Override 
  24.         public void onUpgrade(RdbStore store, int oldVersion, int newVersion) { 
  25.         } 
  26.     }; 
  27.  
  28.     @Override 
  29.     public void onStart(Intent intent) { //創建數據庫操作 
  30.         super.onStart(intent); 
  31.         HiLog.info(LABEL_LOG, "DataAbility onStart"); 
  32.         DatabaseHelper databaseHelper = new DatabaseHelper(this); 
  33.         rdbStore = databaseHelper.getRdbStore(config, DB_VERSION, rdbOpenCallback, null); 
  34.     } 
  35.  
  36. // 數據庫 查詢操作 
  37.     @Override 
  38.     public ResultSet query(Uri uri, String[] columns, DataAbilityPredicates predicates) { 
  39.         RdbPredicates rdbPredicates = DataAbilityUtils.createRdbPredicates(predicates, DB_TAB_NAME); 
  40.         ResultSet resultSet = rdbStore.query(rdbPredicates, columns); 
  41.         if (resultSet == null) { 
  42.             HiLog.info(LABEL_LOG, "resultSet is null"); 
  43.         } 
  44.         return resultSet; 
  45.     } 
  46.  
  47. // 數據庫 插入操作 
  48.     @Override 
  49.     public int insert(Uri uri, ValuesBucket value) { 
  50.         HiLog.info(LABEL_LOG, "DataAbility insert"); 
  51.         String path = uri.getLastPath(); 
  52.         if (!"person".equals(path)) { 
  53.             HiLog.info(LABEL_LOG, "DataAbility insert path is not matched"); 
  54.             return -1; 
  55.         } 
  56.         ValuesBucket values = new ValuesBucket(); 
  57.         values.putInteger(DB_COLUMN_PERSON_ID, value.getInteger(DB_COLUMN_PERSON_ID)); 
  58.         values.putString(DB_COLUMN_NAME, value.getString(DB_COLUMN_NAME)); 
  59.         values.putString(DB_COLUMN_GENDER, value.getString(DB_COLUMN_GENDER)); 
  60.         values.putInteger(DB_COLUMN_AGE, value.getInteger(DB_COLUMN_AGE)); 
  61.         int index = (int) rdbStore.insert(DB_TAB_NAME, values); 
  62.         DataAbilityHelper.creator(this, uri).notifyChange(uri); 
  63.         return index
  64.     } 
  65.  
  66. // 數據庫 刪除操作 
  67.     @Override 
  68.     public int delete(Uri uri, DataAbilityPredicates predicates) { 
  69.         RdbPredicates rdbPredicates = DataAbilityUtils.createRdbPredicates(predicates, DB_TAB_NAME); 
  70.         int index = rdbStore.delete(rdbPredicates); 
  71.         HiLog.info(LABEL_LOG, "delete: " + index); 
  72.         DataAbilityHelper.creator(this, uri).notifyChange(uri); 
  73.         return index
  74.     } 
  75.  
  76. // 數據庫 更新操作 
  77.     @Override 
  78.     public int update(Uri uri, ValuesBucket value, DataAbilityPredicates predicates) { 
  79.         RdbPredicates rdbPredicates = DataAbilityUtils.createRdbPredicates(predicates, DB_TAB_NAME); 
  80.         int index = rdbStore.update(value, rdbPredicates); 
  81.         HiLog.info(LABEL_LOG, "update: " + index); 
  82.         DataAbilityHelper.creator(this, uri).notifyChange(uri); 
  83.         return index
  84.     } 
  85.  
  86.     @Override 
  87.     public FileDescriptor openFile(Uri uri, String mode) { 
  88.         return null
  89.     } 
  90.  
  91.     @Override 
  92.     public String[] getFileTypes(Uri uri, String mimeTypeFilter) { 
  93.         return new String[0]; 
  94.     } 
  95.  
  96.  
  97.     @Override 
  98.     public PacMap call(String method, String arg, PacMap extras) { 
  99.         return null
  100.     } 
  101.  
  102.     @Override 
  103.     public String getType(Uri uri) { 
  104.         return null
  105.     } 

1、添加DataAbility 會自動重寫四個接口函數,有關數據庫的增,刪,改,查。

2、該DataAbility在運行項目后會自行執行onStart 方法 進行數據庫及其數據表的創建工作

3、通過RdbPredicates 數據庫進行數據庫關系的關聯進行操作。

三 、數據庫操作

這里的數據庫操作 時開發需求做的數據庫操作,可以通過自己的需求來開發數據庫的調用操作,最終還是通過使用 DataAbility直接調用系統的數據庫。

  1. public class DataBaseAbilitySlice extends AbilitySlice { 
  2.     private static final HiLogLabel LABEL_LOG = new HiLogLabel(3, 0xD001100, "Demo"); 
  3.     private DataAbilityHelper databaseHelper; 
  4.  
  5.     private static final String BASE_URI = "dataability:///com.huawei.codelab.PersonDataAbility"
  6.     private static final String DATA_PATH = "/person"
  7.     private static final String DB_COLUMN_PERSON_ID = "id"
  8.     private static final String DB_COLUMN_NAME = "name"
  9.     private static final String DB_COLUMN_GENDER = "gender"
  10.     private static final String DB_COLUMN_AGE = "age"
  11.  
  12.     @Override 
  13.     public void onStart(Intent intent) { 
  14.         super.onStart(intent); 
  15.         super.setUIContent(ResourceTable.Layout_ability_data_base); 
  16.         databaseHelper = DataAbilityHelper.creator(this); 
  17.  
  18.         Text text = (Text)findComponentById(ResourceTable.Id_text_helloworld); 
  19.         text.setClickedListener(new Component.ClickedListener() { 
  20.             @Override 
  21.             public void onClick(Component component) { 
  22.                 query(); 
  23.                 insert(100, "Tom""male", 20); 
  24.                 insert(101, "Jerry""female", 21); 
  25.                 insert(102, "Bob""male", 22); 
  26.                 query(); // 查看插入后的結果 
  27.                 update(); 
  28.                 query(); // 查看更新后的結果 
  29.                 delete(); 
  30.                 query(); // 查看刪除后的結果 
  31.             } 
  32.         }); 
  33.     } 
  34.  
  35.     @Override 
  36.     public void onActive() { 
  37.         super.onActive(); 
  38.     } 
  39.  
  40.     @Override 
  41.     public void onForeground(Intent intent) { 
  42.         super.onForeground(intent); 
  43.     } 
  44.  
  45.     private void insert(int id, String name, String gender, int age) { 
  46.         ValuesBucket valuesBucket = new ValuesBucket(); 
  47.         valuesBucket.putInteger(DB_COLUMN_PERSON_ID, id); 
  48.         valuesBucket.putString(DB_COLUMN_NAME, name); 
  49.         valuesBucket.putString(DB_COLUMN_GENDER, gender); 
  50.         valuesBucket.putInteger(DB_COLUMN_AGE, age); 
  51.         try { 
  52.             if (databaseHelper.insert(Uri.parse(BASE_URI + DATA_PATH), valuesBucket) != -1) { 
  53. //            if (databaseHelper.insert(Uri.parse(BASE_URI + DATA_PATH), valuesBucket) != -1) { 
  54.                 HiLog.info(LABEL_LOG, "insert successful"); 
  55.             } 
  56.         } catch (DataAbilityRemoteException | IllegalStateException exception) { 
  57.             HiLog.error(LABEL_LOG, "insert: dataRemote exception|illegalStateException"); 
  58.         } 
  59.     } 
  60.  
  61.     private void delete() { 
  62.         DataAbilityPredicates predicates = new DataAbilityPredicates() 
  63.                 .equalTo(DB_COLUMN_PERSON_ID, 100); 
  64.         try { 
  65.             if (databaseHelper.delete(Uri.parse(BASE_URI + DATA_PATH), predicates) != -1) { 
  66.                 HiLog.info(LABEL_LOG, "delete successful"); 
  67.             } 
  68.         } catch (DataAbilityRemoteException | IllegalStateException exception) { 
  69.             HiLog.error(LABEL_LOG, "delete: dataRemote exception | illegalStateException"); 
  70.         } 
  71.     } 
  72.  
  73.     private void update() { 
  74.         DataAbilityPredicates predicates = new DataAbilityPredicates(); 
  75.         predicates.equalTo(DB_COLUMN_PERSON_ID, 102); 
  76.         ValuesBucket valuesBucket = new ValuesBucket(); 
  77.         valuesBucket.putString(DB_COLUMN_NAME, "ZhangSanPlus"); 
  78.         valuesBucket.putInteger(DB_COLUMN_AGE, 28); 
  79.         try { 
  80.             if (databaseHelper.update(Uri.parse(BASE_URI + DATA_PATH), valuesBucket, predicates) != -1) { 
  81.                 HiLog.info(LABEL_LOG, "update successful"); 
  82.             } 
  83.         } catch (DataAbilityRemoteException | IllegalStateException exception) { 
  84.             HiLog.error(LABEL_LOG, "update: dataRemote exception | illegalStateException"); 
  85.         } 
  86.     } 
  87.  
  88.     private void query() { 
  89.         String[] columns = new String[] {DB_COLUMN_PERSON_ID, 
  90.                 DB_COLUMN_NAME, DB_COLUMN_GENDER, DB_COLUMN_AGE}; 
  91.         // 構造查詢條件 
  92.         DataAbilityPredicates predicates = new DataAbilityPredicates(); 
  93.         predicates.between(DB_COLUMN_AGE, 15, 40); // 查詢時間段 
  94.         try { 
  95.             ResultSet resultSet = databaseHelper.query(Uri.parse(BASE_URI + DATA_PATH), 
  96.                     columns, predicates); 
  97.             if (resultSet == null || resultSet.getRowCount() == 0) { 
  98.                 HiLog.info(LABEL_LOG, "query: resultSet is null or no result found"); 
  99.                 return
  100.             } 
  101.             resultSet.goToFirstRow(); 
  102.             do { 
  103.                 int id = resultSet.getInt(resultSet.getColumnIndexForName(DB_COLUMN_PERSON_ID)); 
  104.                 String name = resultSet.getString(resultSet.getColumnIndexForName(DB_COLUMN_NAME)); 
  105.                 String gender = resultSet.getString(resultSet.getColumnIndexForName(DB_COLUMN_GENDER)); 
  106.                 int age = resultSet.getInt(resultSet.getColumnIndexForName(DB_COLUMN_AGE)); 
  107.                 HiLog.info(LABEL_LOG, "query: Id :" + id + " Name :" + name + " Gender :" + gender + " Age :" + age); 
  108.             } while (resultSet.goToNextRow()); 
  109.         } catch (DataAbilityRemoteException | IllegalStateException exception) { 
  110.             HiLog.error(LABEL_LOG, "query: dataRemote exception | illegalStateException"); 
  111.         } 
  112.     } 

1、數據插入 使用 對象類 ValuesBucket

2、使用 DataAbilityPredicates 實例 進行數據查詢的條件設置

到此有關數據庫的關系型數據庫操作 基本就完成了,是不是非常,非常簡單,可以直接拿來主義 驗證一下。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-09-03 15:41:00

鴻蒙HarmonyOS應用

2018-07-18 09:16:39

關系型非關系型數據庫

2021-07-28 14:40:57

鴻蒙HarmonyOS應用

2017-03-17 14:44:04

關系型數據庫原理

2010-12-10 10:17:21

關系型數據庫

2022-06-13 08:30:01

數據庫管理系統

2020-12-29 11:26:22

鴻蒙HarmonyOS數據庫

2013-06-28 11:28:21

Facebook數據庫大數據

2013-04-26 16:18:29

大數據全球技術峰會

2021-01-26 13:31:48

數據庫關系型數據庫冗余

2023-05-20 08:11:55

2023-05-22 16:10:51

動態共享包數據庫

2022-07-27 08:32:01

數據庫MySQL

2022-12-27 08:38:45

關系型數據庫設計

2016-08-23 14:25:19

MySQL約束數據庫

2018-03-26 12:58:52

數據庫OracleMySQL

2015-04-24 13:59:41

2009-03-26 09:58:55

云計算關系型數據庫關系數據庫

2023-09-05 10:25:35

數據庫性能

2018-06-07 08:31:33

Oracle分布式內存
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品熟人一区二区三区四区 | 91免费小视频 | 在线黄色网 | 亚洲最新网址 | 在线观看亚洲专区 | www.av在线 | 日韩aⅴ在线观看 | 毛片免费观看 | 狠狠操狠狠干 | 久久日韩粉嫩一区二区三区 | 久久一级大片 | 日本a v在线播放 | 精品欧美一区二区三区久久久 | 久久精品国产一区二区电影 | 国产丝袜一区二区三区免费视频 | 欧美午夜精品 | 先锋影音资源网站 | 久久精品这里 | 国产精品精品久久久 | 欧美日本韩国一区二区 | 91社区在线观看高清 | 亚洲国产免费 | 精品综合久久 | 亚洲精品二区 | 久久99精品国产自在现线小黄鸭 | 91精品国产色综合久久不卡98 | 日韩在线 | 欧美精品一区二区三区蜜桃视频 | 中文字幕欧美日韩 | 亚洲三区在线播放 | 久久精品亚洲欧美日韩精品中文字幕 | 日韩在线观看一区二区三区 | 综合五月 | 久久国产精品免费一区二区三区 | 欧美大片久久久 | 精品一二区 | 成年人网站国产 | 国产一区二区三区在线免费 | 日韩午夜场 | 精品国产乱码久久久久久牛牛 | 北条麻妃一区二区三区在线视频 |