精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

HarmonyOS 數(shù)據(jù)庫系列之關(guān)系型數(shù)據(jù)庫

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

[[421539]]

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

前言

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

作為鴻蒙開發(fā)者,最近就深入學(xué)習(xí)了鴻蒙的數(shù)據(jù)庫知識點,了解了存儲機(jī)制并且嘗試了使用,發(fā)現(xiàn)鴻蒙的數(shù)據(jù)庫真的做到了應(yīng)有盡有,操作還簡單的地步。

概念

先來看看 鴻蒙的 關(guān)系型數(shù)據(jù)庫(Relational Database,RDB) 概念。

鴻蒙的RDB 是一種基于關(guān)系模型來管理數(shù)據(jù)的數(shù)據(jù)庫。

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

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

下面看看鴻蒙數(shù)據(jù)庫的運作機(jī)制,了解機(jī)制才能了解數(shù)據(jù)庫開發(fā)的核心,也有利于擴(kuò)展。

運作機(jī)制

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

關(guān)系型數(shù)據(jù)庫運作機(jī)制:

HarmonyOS 數(shù)據(jù)庫系列之關(guān)系型數(shù)據(jù)庫-鴻蒙HarmonyOS技術(shù)社區(qū)

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

約束與限制

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

連接池的數(shù)量是有限制的 ,最大時4個,不過4個已經(jīng)足夠使用了。

2、為保證數(shù)據(jù)的準(zhǔn)確性,數(shù)據(jù)庫同一時間只能支持一個寫操作。

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

數(shù)據(jù)庫操作DataAbility

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

添加步驟很簡單:

添加類的時候 選擇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、操作數(shù)據(jù)庫需要權(quán)限信息

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

 2、需要配置url,url很重要,在進(jìn)行數(shù)據(jù)庫表操作的時候 需要保持一致

二 、DataAbility操作內(nèi)容

默認(rèn)創(chuàng)建的DataAbility類會自動重寫 數(shù)據(jù)庫的增,刪,改,查 幾種操作的函數(shù)。可以看下面:

  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) { //創(chuàng)建數(shù)據(jù)庫操作 
  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. // 數(shù)據(jù)庫 查詢操作 
  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. // 數(shù)據(jù)庫 插入操作 
  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. // 數(shù)據(jù)庫 刪除操作 
  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. // 數(shù)據(jù)庫 更新操作 
  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 會自動重寫四個接口函數(shù),有關(guān)數(shù)據(jù)庫的增,刪,改,查。

2、該DataAbility在運行項目后會自行執(zhí)行onStart 方法 進(jìn)行數(shù)據(jù)庫及其數(shù)據(jù)表的創(chuàng)建工作

3、通過RdbPredicates 數(shù)據(jù)庫進(jìn)行數(shù)據(jù)庫關(guān)系的關(guān)聯(lián)進(jìn)行操作。

三 、數(shù)據(jù)庫操作

這里的數(shù)據(jù)庫操作 時開發(fā)需求做的數(shù)據(jù)庫操作,可以通過自己的需求來開發(fā)數(shù)據(jù)庫的調(diào)用操作,最終還是通過使用 DataAbility直接調(diào)用系統(tǒng)的數(shù)據(jù)庫。

  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(); // 查看插入后的結(jié)果 
  27.                 update(); 
  28.                 query(); // 查看更新后的結(jié)果 
  29.                 delete(); 
  30.                 query(); // 查看刪除后的結(jié)果 
  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.         // 構(gòu)造查詢條件 
  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、數(shù)據(jù)插入 使用 對象類 ValuesBucket

2、使用 DataAbilityPredicates 實例 進(jìn)行數(shù)據(jù)查詢的條件設(shè)置

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

想了解更多內(nèi)容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

 

責(zé)任編輯:jianghua 來源: 鴻蒙社區(qū)
相關(guān)推薦

2021-09-03 15:41:00

鴻蒙HarmonyOS應(yīng)用

2018-07-18 09:16:39

關(guān)系型非關(guān)系型數(shù)據(jù)庫

2021-07-28 14:40:57

鴻蒙HarmonyOS應(yīng)用

2020-12-29 11:26:22

鴻蒙HarmonyOS數(shù)據(jù)庫

2010-12-10 10:17:21

關(guān)系型數(shù)據(jù)庫

2022-06-13 08:30:01

數(shù)據(jù)庫管理系統(tǒng)

2017-03-17 14:44:04

關(guān)系型數(shù)據(jù)庫原理

2013-06-28 11:28:21

Facebook數(shù)據(jù)庫大數(shù)據(jù)

2022-12-27 08:38:45

關(guān)系型數(shù)據(jù)庫設(shè)計

2023-05-22 16:10:51

動態(tài)共享包數(shù)據(jù)庫

2023-05-20 08:11:55

2021-01-26 13:31:48

數(shù)據(jù)庫關(guān)系型數(shù)據(jù)庫冗余

2016-08-23 14:25:19

MySQL約束數(shù)據(jù)庫

2022-07-27 08:32:01

數(shù)據(jù)庫MySQL

2013-04-26 16:18:29

大數(shù)據(jù)全球技術(shù)峰會

2018-03-26 12:58:52

數(shù)據(jù)庫OracleMySQL

2011-04-13 16:13:53

云計算關(guān)系型數(shù)據(jù)庫

2018-06-07 08:31:33

Oracle分布式內(nèi)存

2023-12-13 08:22:45

SQLite關(guān)系型數(shù)據(jù)庫

2013-01-08 14:24:23

點贊
收藏

51CTO技術(shù)棧公眾號

国产69精品久久久| 欧美日韩日日骚| 国产美女99p| 在线观看天堂av| 24小时成人在线视频| 国产精品盗摄一区二区三区| 成人av.网址在线网站| 成人免费毛片xxx| 亚洲精品aⅴ| 婷婷六月综合亚洲| 日本婷婷久久久久久久久一区二区| 日韩中文字幕高清| 99视频精品全部免费在线视频| 欧美一区日本一区韩国一区| 亚洲欧洲精品一区二区| 国内精品久久久久久久久久| 91久久视频| 亚洲天堂久久av| 欧洲美女亚洲激情| 日韩脚交footjobhd| 久久久精品国产免大香伊| 国产精品香蕉av| 久草视频精品在线| 国产一区三区在线播放| 91精品婷婷国产综合久久竹菊| 欧美精品久久久久久久自慰| h视频网站在线观看| 国产乱码精品一区二区三区忘忧草| 国内揄拍国内精品少妇国语| 欧美一区二区三区粗大| 大香伊人久久精品一区二区| 欧美综合一区二区| 屁屁影院ccyy国产第一页| 激情视频在线观看免费| 国产东北露脸精品视频| 亲爱的老师9免费观看全集电视剧| 人与动物性xxxx| 久草在线综合| 日韩一级免费一区| 日韩肉感妇bbwbbwbbw| 草莓视频丝瓜在线观看丝瓜18| 国产亚洲成年网址在线观看| 国产传媒一区二区| 国产又粗又猛又爽又黄视频| 久久精品卡一| 欧美激情成人在线视频| 女人裸体性做爰全过| 视频福利一区| 欧美不卡一区二区三区四区| 最新天堂在线视频| 激情开心成人网| 午夜精品久久久久久| 黄色网址在线免费看| 日本高清中文字幕二区在线| 国产91高潮流白浆在线麻豆 | 一区二区三区久久久久| 日韩精品成人在线观看| 欧美日韩亚洲综合一区二区三区| 日本福利视频在线| 男女啪啪在线观看| 久久综合国产精品| 北条麻妃高清一区| www.av88| 久久亚洲图片| 日本精品免费一区二区三区| 午夜精品三级久久久有码| 亚洲黄色成人| 午夜欧美大片免费观看| 欧美成人精品欧美一级私黄| 亚洲精品国产成人影院| 日韩色av导航| 肉色超薄丝袜脚交69xx图片 | 四虎永久精品在线| 欧美最猛性xxxxx直播| 日本www高清视频| 日韩电影免费观| 欧美日韩国产区| 国产黄色一级网站| 女厕盗摄一区二区三区| 欧美日韩中国免费专区在线看| 日韩精品―中文字幕| 51漫画成人app入口| 亚洲国产色一区| 中文字幕无码精品亚洲资源网久久| 日本高清成人vr专区| 一区二区三区在线观看欧美| 欧美黄色免费网址| 黄色小说在线播放| 亚洲成人在线免费| 草草久久久无码国产专区| 外国成人直播| 欧美日韩一级片网站| 黄色小视频免费网站| 99精品国产九九国产精品| 91精品国产免费久久综合| 一区二区三区人妻| 久久精品色播| 国产小视频91| 欧美h片在线观看| 欧美aa国产视频| 高清一区二区三区四区五区| 日韩欧美不卡视频| 久久亚洲欧美| 1卡2卡3卡精品视频| 日本黄色免费视频| 久久久99精品免费观看| 永久免费精品视频网站| 97超碰在线公开在线看免费| 婷婷开心激情综合| 国产精品人人爽人人爽| 日韩国产在线不卡视频| 日韩经典一区二区三区| www.涩涩爱| 激情综合激情| 国产精品美女午夜av| 中文字幕第3页| 成人av手机在线| 成人91在线观看| 日韩欧美激情一区二区| 精品黄色免费中文电影在线播放| 一区二区三区四区不卡在线| 日本一本二本在线观看| 日本一区二区三区电影免费观看 | 久久久成人精品视频| 国产精选第一页| 欧美aⅴ一区二区三区视频| 99九九视频| 国产高清免费av在线| 亚洲免费色视频| 日韩精品免费播放| jizz久久精品永久免费| 中文字幕精品在线视频| 一级免费在线观看| 国产精品自拍三区| 色999五月色| www.九色在线| 欧美一区二区在线播放| 日韩乱码人妻无码中文字幕久久| 欧美日韩精品| 国产精品视频网| 少妇激情av一区二区| 一区二区三区小说| 久久黄色片网站| 国产一区二区三区探花| 性色av一区二区咪爱| 精品人妻一区二区三区蜜桃| 国产精品久久久久久久久久免费看| 美女av免费在线观看| 哺乳挤奶一区二区三区免费看| 精品国产一区二区三区在线观看| 成人免费毛片男人用品| 成人av动漫在线| 日韩专区第三页| 95精品视频| 中文字幕日韩高清| 国产成人愉拍精品久久| 国产成人精品影视| 国产精品88久久久久久妇女| 亚洲精品一区二区在线播放∴| 国产亚洲欧美日韩美女| 欧产日产国产69| 久久众筹精品私拍模特| 久久久久久久久久久99| 999精品视频在这里| 欧美老肥婆性猛交视频| 国产毛片一区二区三区va在线 | 超碰人人在线| 欧美精品乱码久久久久久按摩| 成人无码av片在线观看| 丝袜亚洲精品中文字幕一区| 精品产品国产在线不卡| 国产精品偷拍| 亚洲第一中文字幕| 91蜜桃视频在线观看| 波多野结衣一区二区三区 | 精品国产乱码久久久久久1区2匹| 欧美精品videos另类日本| 成人精品在线播放| 精品人伦一区二区三区蜜桃网站| 色综合久久五月| 99在线精品免费视频九九视| 久久亚洲国产精品日日av夜夜| √天堂8资源中文在线| 日韩精品久久久久| 免费在线观看av的网站| 亚洲欧美在线aaa| 日本美女久久久| 在线观看的日韩av| 欧美大香线蕉线伊人久久国产精品 | 91精品欧美久久久久久动漫| 国产午夜精品理论片| 国产91高潮流白浆在线麻豆 | 国产破处视频在线观看| 久久国产尿小便嘘嘘| 在线观看18视频网站| 超碰97久久国产精品牛牛| 欧美亚洲国产视频| 高清国产福利在线观看| 91精品国产综合久久精品图片 | 欧美在线 | 亚洲| 日韩欧美高清在线视频| 性生交大片免费全黄| 波波电影院一区二区三区| 国产精品乱码久久久久| 中文字幕乱码亚洲无线精品一区 | 国产精品自在线拍| 国产成人亚洲综合91| 色网站在线看| 精品国产乱码久久久久久图片 | 91精品国产乱码久久久久久| 国产伦精品一区二区三区免费视频| 波多视频一区| 久久久国产影院| 亚洲欧美日韩动漫| 91麻豆精品国产自产在线 | 日本高清免费不卡视频| www.xxxx日本| 国产色爱av资源综合区| 日本精品一二三区| 日本中文一区二区三区| 草b视频在线观看| 久久国产综合| 极品日韩久久| 欧美片网站免费| 国产精品高潮粉嫩av| 高清电影在线观看免费| 自拍偷拍免费精品| 五月婷婷狠狠干| 日韩一区二区三区高清免费看看| 久久精品偷拍视频| 亚洲高清视频的网址| 91香蕉国产视频| 91蝌蚪porny| av不卡中文字幕| 麻豆精品一区二区| 情侣黄网站免费看| 激情综合电影网| 做爰高潮hd色即是空| 国产欧美日韩一区二区三区四区| 999久久久| 祥仔av免费一区二区三区四区| 国产成人在线一区| 牛牛精品一区二区| 欧美激情亚洲另类| 午夜小视频福利在线观看| 自拍偷拍亚洲欧美| 精品电影在线| 亚洲美女在线看| 亚洲 欧美 激情 另类| 精品国产乱码久久久久久老虎| 国产精品熟女久久久久久| 欧美性xxxxxxxx| www.欧美色| 欧美午夜视频一区二区| 国产大片中文字幕在线观看| 亚洲免费av观看| 久久精品一区二区三区四区五区| 国产农村妇女精品| 第一次破处视频| 久久久精品国产免大香伊| xxxxx在线观看| 91香蕉视频mp4| 久久久老熟女一区二区三区91| 国产精品一二三四| 国产精品igao网网址不卡| 久久97超碰色| 日本人视频jizz页码69| 麻豆久久精品| 国产视频一区二区三区在线播放| 日韩中文字幕亚洲一区二区va在线| 欧美精品色婷婷五月综合| 亚洲男人影院| 超碰av在线免费观看| 蜜臀精品一区二区三区在线观看 | 日韩爱爱小视频| 久久99国产精品免费网站| 午夜影院免费观看视频| 国产成人日日夜夜| 美女伦理水蜜桃4| 91丨九色丨尤物| 国产精品久久久久久在线观看| www.66久久| av电影在线不卡| 国产日韩影视精品| 人与动物性xxxx| 一区二区三区四区五区视频在线观看| 久久久久久免费观看| 亚洲成人av一区二区| 欧美h在线观看| 欧洲av一区二区嗯嗯嗯啊| 国产毛片毛片毛片毛片| 亚洲大胆人体在线| 飘雪影院手机免费高清版在线观看| 亚洲午夜精品久久久久久久久久久久| 自拍视频在线免费观看| 超碰97人人做人人爱少妇| gogo久久| 国产精品69av| 日韩精品中文字幕一区二区| 精品久久久久亚洲| 欧美一区二区三区激情视频 | yourporn在线观看视频| 久久国产精品影视| 国内精彩免费自拍视频在线观看网址| 国产成人精品久久久| 国产高清视频一区二区| 91在线视频九色| 日本韩国欧美超级黄在线观看| 亚洲视频在线二区| 黑人一区二区| 成人在线看视频| 国产精品亚洲人在线观看| 欧美熟妇精品黑人巨大一二三区| 国产精品久久久久久久久久久免费看| 欧美偷拍第一页| 日韩欧美精品中文字幕| 国产福利第一页| 亚洲第一精品夜夜躁人人爽| 日本中文在线| 97在线看福利| 日韩毛片免费视频一级特黄| 国产一区二区高清不卡| 91青青国产在线观看精品| 日本午夜激情视频| 国产一区二区三区不卡在线观看| 亚洲精品乱码久久久久久久| 国产精品久久久久久久第一福利 | 好男人免费精品视频| 欧美黑人视频一区| 欧美大片网站| 久久青青草原| 欧美日韩亚洲一区| 免费精品99久久国产综合精品应用| 99re66热这里只有精品3直播| 中日韩一级黄色片| 在线免费观看日本一区| 凸凹人妻人人澡人人添| 欧美乱妇高清无乱码| 欧美xnxx| 久久99影院| 亚洲美女视频| 亚洲 高清 成人 动漫| 国产又黄又大久久| 人成免费在线视频| 色综合欧美在线| 性感美女福利视频| 欧美大奶子在线| 国产精品美女久久久久人| 亚洲欧美精品在线观看| 久热精品在线| 女人被狂躁c到高潮| 亚洲女同ⅹxx女同tv| 97超视频在线观看| 在线视频免费一区二区| 蜜桃视频动漫在线播放| 亚洲aa中文字幕| 久久免费大视频| 波多野结衣xxxx| 久久综合成人精品亚洲另类欧美 | 亚洲精品在线视频| 日韩av影片| 欧美一区亚洲二区| 爽好多水快深点欧美视频| 中字幕一区二区三区乱码| 日韩欧美有码在线| 国产中文字幕在线播放| 国产成人激情小视频| 精品大片一区二区| 日本中文字幕高清| 国产精品久久免费看| 97免费观看视频| 美女av一区二区| 91成人噜噜噜在线播放| 日本丰满少妇xxxx| 99国产精品久久| 成人h动漫精品一区二区下载| 亚洲人a成www在线影院| 最新欧美电影| 一区二区不卡在线观看| 韩国欧美国产1区| 久久国产一级片| 亚洲黄色有码视频| 精品日韩视频| 中文字幕中文字幕一区三区| 国产一区高清在线| 久久精品国产亚洲av高清色欲 | 成人免费a**址| 欧美午夜精品理论片| 亚洲综合激情网| 色播色播色播色播色播在线| 91精品国产成人www| 免费成人网www| 午夜精品中文字幕| 国产亚洲一本大道中文在线| 亚洲av综合一区| 欧美日韩不卡合集视频| 九九精品在线| 久草视频福利在线| 欧美高清www午色夜在线视频| 乡村艳史在线观看|