日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

android数据库降级_Android SQLite (二.数据库创建,升级及降级)

發布時間:2023/11/27 生活经验 54 豆豆
生活随笔 收集整理的這篇文章主要介紹了 android数据库降级_Android SQLite (二.数据库创建,升级及降级) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

上篇文章簡介和常用語法介紹了SQLite數據庫的基本信息和一些常用的語法操作,本篇文章主要介紹Android開發過程中SQLite數據庫的創建使用和常見問題處理。

一.SQLiteOpenHelper介紹

對于Android平臺來說,我們可以使用系統提供的API輕松實現對SQLite數據庫的操作

Android提供SQLiteOpenHelper類以便我們創建操作數據庫。通常情況下我們會新建一個SQLiteOpenHelper的子類作為一個數據庫的操作類。

數據庫操作類示例 :

DatabaseHelper

public class DatabaseHelper extends SQLiteOpenHelper {

/**

* 數據庫名稱

*/

private static final String DATABASE_NAME = "account.db";

/**

* 數據庫版本-升級用

*/

private static final int DATABASE_VERSION = 1;

public DatabaseHelper(Context context) {

//CursorFactory設置為null,使用默認值

super(context, DATABASE_NAME, null, DATABASE_VERSION);

}

/**

* 數據庫第一次創建時調用

*/

@Override

public void onCreate(SQLiteDatabase db) {

db.execSQL("CREATE TABLE IF NOT EXISTS account " +

"(userId VERCHAR PRIMARY KEY,userName VERCHAR,totalAccount INTEGER)");

}

/**

* @param db 數據庫實際操作類

* @param oldVersion 舊版本

* @param newVersion 新版本

*/

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}

}

二.數據庫創建-構造方法

數據庫的創建以及版本,是由SQLiteOpenHelper的構造方法參數決定的。

SQLiteOpenHelper 有三個構造構造方法:

/**

* @param context 用來打開或者創建數據庫

* @param name 數據庫文件名稱或者傳null為一個內存數據庫

* @param factory 用來創建cursor對象或者傳null使用默認的

* @param version 數據庫版本號 (從1開始);如果數據庫版本比當前版舊,onUpgrade方法會被調用來更新數據庫,

如果比當前新onDowngrade方法會被調用來降級數據庫

*/

public SQLiteOpenHelper(Context context, String name, CursorFactory factory, int version) {

this(context, name, factory, version, null);

}

/**

* @param errorHandler DatabaseErrorHandler數據庫損壞時回調.

*/

public SQLiteOpenHelper(Context context, String name, CursorFactory factory,

int version, DatabaseErrorHandler errorHandler) {

this(context, name, factory, version, 0, errorHandler);

}

/**

* @param minimumSupportedVersion 支持調用onUpgrade更新到version版本的最版本號,

如果當前版本比最小支持的版本還下數據庫就會刪除然后重新創建version版本的數據庫。

在刪除前onBeforeDelete會被調用我們可以在此方法中做一些處理。minimumSupportedVersion 默認為0

* @hide

*/

public SQLiteOpenHelper(Context context, String name, CursorFactory factory,

int version, int minimumSupportedVersion, DatabaseErrorHandler errorHandler) {

if (version < 1) throw new IllegalArgumentException("Version must be >= 1, was " +

version);

mContext = context;

mName = name;

mFactory = factory;

mNewVersion = version;

mErrorHandler = errorHandler;

mMinimumSupportedVersion = Math.max(0, minimumSupportedVersion);

}

最終都會調用第三個構造方法,方法中判斷如果version 小于1會拋出異常,所以Android SQLite數據庫版本必須從1開始。實際上最后一個構造方法被@hide注解了,所以一般情況下在子類中我們是沒有辦法主動調用的,只能調用前兩個構造方法,minimumSupportedVersion 也始終是0。

三.數據庫首次創建回調-onCreate方法

數據庫首次創建的時候onCreate方法會被執行。表的創建和初始化需要在方法中進行。這個是抽象方法,實體類中必須實現。實現很簡單就是做一些創建表的操作。

示例:

/**

* 數據庫第一次創建時調用

*/

@Override

public void onCreate(SQLiteDatabase db) {

db.execSQL("CREATE TABLE IF NOT EXISTS account " +

"(userId VERCHAR PRIMARY KEY,userName VERCHAR,totalAccount INTEGER)");

}

四.數據庫的升級-onUpgrade方法

/**

* @param db The database.

* @param oldVersion 舊數據庫版本

* @param newVersion 新數據庫版本

*/

public abstract void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion);

當數據庫升級時(當前數據庫版本大于已創建的數據庫版本)會執行此方法,首次創建時不會執行。這是個抽象方法,在我們的實體類中必須實現。我們可以在這個方法中根據數據庫版本做一些刪除表,創建表,新增表字段或者重命名表等操作保證數據庫與最新版本數據庫同步。

常用數據庫升級操作:

數據庫的升級一般有三種方式如下:

1.onCreate方法始終保證是最新的,在onUpgrade方法中刪除所有已存在表,在調用onCreate中創建表的方法重新創建所有表,保證表是最新的。(當然如果你想保存數據也可以先將數據保存到內存再插入,如果表很多或者數據量很大的是不建議怎么操作的,非常影響性能)

2.onCreate方法始終保證是最新的,再onUpgrade方法中根據版本號判斷執行創建新表或者更新字段等操作

版本號需要 判斷上下限:

上限(為了再從當前版本x更新到新版本y時不重復執行更新操作):假如我們要升級到新版本x,是我們的當前版本x,需要小于當前版本號x。

下限:如果是創建新表下限就是當前版本之前的所有版本,如果是更新表字段或者重命名表下限是表創建的版本需要大于等于下限版本

舉個栗子:

2.1. 在上面的示例我們創建了版本1數據庫,onCreate方法創建了表account,現在需要在表account中新增字段subAccountId并新增一個表subAccount。

按照上面的方式我們需要更新表版本號為假設為2(可以為更大的,不要求連續,連續方便之后的版本更新迭代),在onCreate方法中修改原來創建表account的SQL新增字段subAccountId,同時新增創建表subAccount的SQL并執行。

然后在onUpgrade中判斷oldVersion版本號大于等于原版本1小于現版本2,執行新增字段和新增表SQL。

具體代碼如下:

public class DatabaseHelper extends SQLiteOpenHelper {

/**

* 數據庫名稱

*/

private static final String DATABASE_NAME = "account.db";

/**

* 數據庫版本-升級用

*/

private static final int DATABASE_VERSION = 2;

public DatabaseHelper(Context context) {

//CursorFactory設置為null,使用默認值

super(context, DATABASE_NAME, null, DATABASE_VERSION);

}

/**

* 數據庫第一次創建時調用

*/

@Override

public void onCreate(SQLiteDatabase db) {

db.execSQL("CREATE TABLE IF NOT EXISTS account " +

"(userId VERCHAR PRIMARY KEY,userName VERCHAR,totalAccount INTEGER," +

"subAccountId VARCHAR default '')");

db.execSQL("CREATE TABLE IF NOT EXISTS subAccount " +

"(userId VERCHAR PRIMARY KEY,subAccountId VERCHAR,totalAccount INTEGER)");

}

/**

* @param db 數據庫實際操作類

* @param oldVersion 舊版本

* @param newVersion 新版本

*/

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

if (oldVersion >= 1 && oldVersion < 2) {

db.execSQL("ALTER TABLE account ADD COLUMN subAccountId VARCHAR default ''");

db.execSQL("CREATE TABLE IF NOT EXISTS subAccount " +

"(userId VERCHAR PRIMARY KEY,subAccountId VERCHAR,totalAccount INTEGER)");

}

}

}

2.2 假設這個時候,還需要升級數據庫到版本3,在表subAccount 中新增個字段userName。

onCreate方法里修改就不說了創建表subAccount 加上userName字段就行。onUpgrade方法中怎么判斷版本號,按照上面的說明可知上限是小于3,下限則是大于等于表創建的版本,subAccount 表創建的版本是2所以需要大于等于2,而不是大于等于初始版本。

具體代碼如下:

/**

* 數據庫版本-升級用

* 版本2:新增數據庫subAccount

*/

private static final int DATABASE_VERSION = 3;

public DatabaseHelper(Context context) {

//CursorFactory設置為null,使用默認值

super(context, DATABASE_NAME, null, DATABASE_VERSION);

}

/**

* 數據庫第一次創建時調用

*/

@Override

public void onCreate(SQLiteDatabase db) {

createAccountTable(db);

createSubAccountTable(db);

}

/**

* 創建subAccount表(最好封裝下,保證onCreate和onUpgrade方法中創建的都是最新表)

*/

private void createSubAccountTable(SQLiteDatabase db) {

db.execSQL("CREATE TABLE IF NOT EXISTS subAccount " +

"(userId VERCHAR PRIMARY KEY,subAccountId VERCHAR,totalAccount INTEGER," +

"userName VARCHAR default '')");

}

private void createAccountTable(SQLiteDatabase db) {

db.execSQL("CREATE TABLE IF NOT EXISTS account " +

"(userId VERCHAR PRIMARY KEY,userName VERCHAR,totalAccount INTEGER," +

"subAccountId VARCHAR default '')");

}

/**

* @param db 數據庫實際操作類

* @param oldVersion 舊版本

* @param newVersion 新版本

*/

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

if (oldVersion >= 1 && oldVersion < 2) {

db.execSQL("ALTER TABLE account ADD COLUMN subAccountId VARCHAR default ''");

createSubAccountTable(db);

}

if (oldVersion >= 2 && oldVersion < 3) {

db.execSQL("ALTER TABLE subAccount ADD COLUMN userName VARCHAR default ''");

}

}

}

升級測試說明:

直接安裝版本3數據庫的APP——走onCreate方法創建最新表

安裝版本2--升級版本3APP——onUpgrade只會走升級subAccount 表的邏輯

安裝版本1--升級版本3APP——onUpgrade只會走升級account 表的邏輯和創建表subAccount 的邏輯,創建表subAccount 和onCreate中執行的是同義SQL,創建的都是最新表。

這種方式更新數據庫一定要注意表的創建版本,所以必要的注釋還是要詳細點。

3.第三種方式和第二種基本是一樣,只是在onUpgrade方法中一步步往上升級,已上面2.2例子說明,初始版本為1,升級到版本3,先升級到版本2再升級到版本3這樣就不需要判斷oldVersion 版本號的上下限了。

使用這種方式升級,onCreate中可以是最新表創建(3.1示例),也可以只進行最初版本的表創建然后調用onUpgrade方法升級數據庫(3.2示例)

3.1 onCreate中最新的數據表,onUpgrade方法中根據版本號一步步往上升級

代碼如下:

/**

* 數據庫名稱

*/

private static final String DATABASE_NAME = "account.db";

/**

* 數據庫版本-升級用

*/

private static final int DATABASE_VERSION = 3;

public DatabaseHelper3(Context context) {

//CursorFactory設置為null,使用默認值

super(context, DATABASE_NAME, null, DATABASE_VERSION);

}

/**

* 數據庫第一次創建時調用

*/

@Override

public void onCreate(SQLiteDatabase db) {

createAccountTable(db);

createSubAccountTable(db);

}

private void createSubAccountTable(SQLiteDatabase db) {

db.execSQL("CREATE TABLE IF NOT EXISTS subAccount " +

"(userId VERCHAR PRIMARY KEY,subAccountId VERCHAR,totalAccount INTEGER," +

"userName VARCHAR default '')");

}

private void createAccountTable(SQLiteDatabase db) {

db.execSQL("CREATE TABLE IF NOT EXISTS account " +

"(userId VERCHAR PRIMARY KEY,userName VERCHAR,totalAccount INTEGER," +

"subAccountId VARCHAR default '')");

}

/**

* @param db 數據庫實際操作類

* @param oldVersion 舊版本

* @param newVersion 新版本

*/

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

int version = oldVersion;

if (version == 1){

db.execSQL("ALTER TABLE account ADD COLUMN subAccountId VARCHAR default ''");

db.execSQL("CREATE TABLE IF NOT EXISTS subAccount " +

"(userId VERCHAR PRIMARY KEY,subAccountId VERCHAR,totalAccount INTEGER)");

version = 2;

}

if (version == 2){

db.execSQL("ALTER TABLE subAccount ADD COLUMN userName VARCHAR default ''");

}

}

3.2 onCreate中創建最初版本的表然后調用onUpgrade方法傳入oldVersion為最初版本,onUpgrade方法中根據版本號一步步往上升級,需要判斷下版本號oldVersion>=newVersion時不做處理(即初始版本不處理)

代碼如下:

/**

* 數據庫名稱

*/

private static final String DATABASE_NAME = "account.db";

/**

* 最初版本

*/

private static final int FIRST_DATABASE_VERSION = 1;

/**

* 數據庫版本-升級用

*/

private static final int DATABASE_VERSION = 3;

public DatabaseHelper2(Context context) {

//CursorFactory設置為null,使用默認值

super(context, DATABASE_NAME, null, DATABASE_VERSION);

}

/**

* 數據庫第一次創建時調用

*/

@Override

public void onCreate(SQLiteDatabase db) {

db.execSQL("CREATE TABLE IF NOT EXISTS account " +

"(userId VERCHAR PRIMARY KEY,userName VERCHAR,totalAccount INTEGER)");

onUpgrade(db,FIRST_DATABASE_VERSION,DATABASE_VERSION);

}

/**

* @param db 數據庫實際操作類

* @param oldVersion 舊版本

* @param newVersion 新版本

*/

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

if (oldVersion >= newVersion){

return;

}

int version = oldVersion;

if (version == 1){

db.execSQL("ALTER TABLE account ADD COLUMN subAccountId VARCHAR default ''");

db.execSQL("CREATE TABLE IF NOT EXISTS subAccount " +

"(userId VERCHAR PRIMARY KEY,subAccountId VERCHAR,totalAccount INTEGER)");

version = 2;

}

if (version == 2){

db.execSQL("ALTER TABLE subAccount ADD COLUMN userName VARCHAR default ''");

}

}

或者直接判斷小于也是可以的,思路和上面是完全一樣的,也是一步步往上升級,僅僅是寫法不一樣,隨變選一個寫法就行,示例代碼如下:

/**

* @param db 數據庫實際操作類

* @param oldVersion 舊版本

* @param newVersion 新版本

*/

@Override

public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

if (oldVersion >= newVersion){

return;

}

if (oldVersion < 2){

db.execSQL("ALTER TABLE account ADD COLUMN subAccountId VARCHAR default ''");

db.execSQL("CREATE TABLE IF NOT EXISTS subAccount " +

"(userId VERCHAR PRIMARY KEY,subAccountId VERCHAR,totalAccount INTEGER)");

}

if (version < 3){

db.execSQL("ALTER TABLE subAccount ADD COLUMN userName VARCHAR default ''");

}

}

總結:

以上三種方式均可以實現數據庫版本的升級。

如果數據庫版本升級不需要保存舊表數據可以選擇方式1升級數據庫,刪除所有表重新創建。

如果數據庫版本升級需要保存數據庫表數據,則可以選擇方式二或者方式三。

個人比較建議選擇方式二,新安裝APP創建數據庫不會做很多多余的操作且邏輯也比較清晰。

當然大家可以根據各自的需求選擇,如果數據庫修改不是很頻繁而且修改較多的情況下,方式三也不失為一個好的選擇,代碼邏輯很清晰。

五.數據庫降級-onDowngrade方法

public void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) {

throw new SQLiteException("Can't downgrade database from version " +

oldVersion + " to " + newVersion);

}

降級方法,當數據庫降級時(當前數據庫版本小于已創建的數據庫版本)執行此方法。

onDowngrade方法是有默認實現的,我們可以看到默認實現就是拋出一個降級異常,所以如果我們不重寫此方法,APP 數據庫是沒法往下降級的,安裝的時候會直接崩潰。除非你卸載了重裝,這樣相當于首次創建數據庫,走onCreate方法。

我們可以根據實際需求來決定是否需要重寫onDowngrade方法,如果應用降級覆蓋安裝不涉及數據庫降級或者是不允許降級就不需要重寫此方法,強制用戶安裝最新的。如果有需要則可以重寫此方法,一般操作為刪除所有表再調用onCreate方法重寫創建表。SQLite數據庫表是不能刪減字段的,這樣做舊版本表可能有冗余字段,但這不影響舊版本操作。

舉個栗子:

@Override

public void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) {

dropTable(db,"account");

dropTable(db,"subAccount");

onCreate(db);

}

/**

* 刪除表

* @param db 數據庫

* @param tableName 表名

*/

public void dropTable(SQLiteDatabase db, String tableName) {

if (TextUtils.isEmpty(tableName)) {

return;

}

db.execSQL("drop table " + tableName);

}

總結

以上是生活随笔為你收集整理的android数据库降级_Android SQLite (二.数据库创建,升级及降级)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产v在线播放 | 日本一区二区不卡高清 | 亚洲欧美在线综合 | 亚洲综合色激情五月 | 免费网站黄 | 国产精品久久伊人 | 国产精品一区二区三区久久 | 中文字幕在线播放一区 | 国产在线视频导航 | 亚洲国产日韩欧美在线 | 国产精品激情偷乱一区二区∴ | 国产精品久久影院 | 亚洲国产精品传媒在线观看 | 91在线中文字幕 | 日韩三级视频 | 国产精品一区二区无线 | 欧美色综合天天久久综合精品 | 日日夜夜天天综合 | 波多野结衣视频一区二区三区 | 狠狠色丁香九九婷婷综合五月 | 天天操人人要 | 国产又粗又猛又色又黄网站 | 网站你懂的 | 91精品在线观看视频 | 激情五月色播五月 | 2019中文最近的2019中文在线 | 日韩精品一区二区三区高清免费 | 免费视频在线观看网站 | 国产精品成人一区二区 | 五月丁香 | 97视频人人 | 狠狠色噜噜狠狠狠狠2022 | 亚洲精品观看 | 国产在线精品一区二区不卡了 | 天天玩夜夜操 | 国产一级视频在线免费观看 | 欧美激情视频在线观看免费 | 99爱视频 | 91免费在线视频 | 欧美极品久久 | 免费观看v片在线观看 | 亚洲性少妇性猛交wwww乱大交 | 国产大陆亚洲精品国产 | 国产视频一区在线 | 日韩一区二区在线免费观看 | 91亚洲精品乱码久久久久久蜜桃 | 91精选在线 | 亚洲精品h| 黄色网址在线播放 | 中文在线最新版天堂 | 国产精品久久久久久av | 成人在线视频免费看 | 在线观看黄网 | 精品久久久久久亚洲综合网站 | 九九久久精品 | 久久精品久久久久电影 | 中文字幕黄色av | 天天操天天干天天干 | 在线免费观看欧美日韩 | 天天看天天操 | 色婷婷天天干 | 探花视频免费在线观看 | 玖玖精品视频 | 在线观看久久久久久 | 久草在线欧美 | 国产精品手机播放 | 中文字幕在线影视资源 | 日批网站免费观看 | 91丨精品丨蝌蚪丨白丝jk | 热久久这里只有精品 | 久久久久久久电影 | 97精品电影院 | 久久精品久久精品久久精品 | 在线免费黄色av | 91麻豆国产福利在线观看 | 亚洲区另类春色综合小说校园片 | 国产精品9999久久久久仙踪林 | 在线亚洲午夜片av大片 | 91av资源网 | 超碰最新网址 | 狠狠伊人 | 三级动图| av网站播放 | 蜜臀久久99精品久久久久久网站 | 亚洲人人射 | 精品中文字幕在线观看 | 五月激情婷婷丁香 | 免费看的av片 | 人人爱人人舔 | 激情视频免费在线观看 | 久久视频在线看 | 日日色综合 | 日韩xxxx视频 | 青春草国产视频 | 免费亚洲黄色 | 日韩免费一级a毛片在线播放一级 | 国产成人一区二区三区 | 毛片黄色一级 | 精品主播网红福利资源观看 | 亚洲电影免费 | 91精品久久久久久综合五月天 | 青青河边草免费观看 | 91手机在线看片 | 久久婷婷一区二区三区 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 欧洲精品视频一区二区 | 国产韩国日本高清视频 | 日韩在线视频二区 | 国产视频观看 | 精品国产一区二区三区不卡 | 日韩精品无码一区二区三区 | 国产高清综合 | 天天操天天操天天操天天操天天操 | 97碰碰精品嫩模在线播放 | 久久99精品久久久久婷婷 | 国产一区二区久久久 | 美腿丝袜一区二区三区 | 91高清免费看 | 国产在线精品一区二区三区 | 亚洲日日夜夜 | 国产精品久久久久影院 | 欧美 亚洲 另类 激情 另类 | 成年人视频在线 | 日日碰狠狠添天天爽超碰97久久 | 精品亚洲网 | 国产人成在线观看 | 久久成人18免费网站 | 久青草国产在线 | 黄色不卡av | 国内丰满少妇猛烈精品播 | 96av视频| 日b视频国产 | 国产精品videossex国产高清 | 色五丁香 | 国产成人av免费在线观看 | 国产精品网红福利 | 999久久精品 | 91视频免费国产 | 麻豆传媒视频在线免费观看 | 亚洲激情小视频 | 91天堂影院 | 免费看片网站91 | 男女激情网址 | 狠狠色综合网站久久久久久久 | 久久久久成人精品 | 欧美性做爰猛烈叫床潮 | 中文字幕在线观看完整版电影 | 成人午夜在线观看 | 国产小视频在线播放 | 开心婷婷色| 91理论片午午伦夜理片久久 | 精品欧美乱码久久久久久 | 亚洲精品乱码久久久久久久久久 | 天天躁日日躁狠狠 | 精品成人a区在线观看 | www日韩视频 | 欧美淫aaa免费观看 日韩激情免费视频 | 久久精品免费电影 | 中文字幕 影院 | 91传媒在线观看 | 狠狠狠色丁香综合久久天下网 | 色婷婷一区 | 亚洲欧美经典 | 中文字幕一区二区三区乱码不卡 | 手机av片 | 免费看麻豆 | 91av播放 | 在线国产99| 在线小视频你懂的 | 国产伦精品一区二区三区无广告 | 99久久久久久 | 久久国产三级 | 久久呀| 在线欧美a| 国产在线播放不卡 | 韩国av永久免费 | 97成人精品视频在线观看 | 日韩精品影视 | 国产精品一区二区果冻传媒 | 97av色| 精品国产一区二区三区免费 | 五月婷久久 | 日韩免费一级a毛片在线播放一级 | www.五月婷婷 | 久久se视频 | 亚洲精品美女在线观看 | 国产婷婷| 99re视频在线观看 | 黄色a视频 | 狠狠色丁香九九婷婷综合五月 | 99久久精品免费看国产麻豆 | 国产婷婷精品av在线 | 久久九九国产精品 | 麻豆视传媒官网免费观看 | 在线激情电影 | va视频在线 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 啪啪av在线 | 国产九九精品视频 | 国产97在线播放 | 九九九热精品免费视频观看网站 | 五月婷婷另类国产 | 999在线精品 | 最近能播放的中文字幕 | 国产精品99久久久久久人免费 | 国产一级片免费视频 | 日韩一级理论片 | 九色91福利 | 欧美激情第28页 | 久久在线 | 成人永久视频 | 免费精品人在线二线三线 | 精品久久久久久国产 | 五月婷婷另类国产 | 九九热精品视频在线观看 | av免费电影在线 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 一区二区激情 | 久草在线免费看视频 | 天天玩天天操天天射 | 最新日本中文字幕 | 免费精品视频在线 | 国产午夜三级一区二区三桃花影视 | 伊人资源站 | 天天曰天天干 | 97在线观视频免费观看 | 国产一级黄色片免费看 | 国产91综合一区在线观看 | 亚洲精品久久久蜜臀下载官网 | 人人涩 | 在线观看www91 | 最近日本韩国中文字幕 | 国产精品系列在线播放 | av黄色免费网站 | 五月天亚洲综合小说网 | 婷婷六月综合网 | 91精品在线免费 | 亚洲电影久久久 | a电影免费看 | 久草视频2| 成人av地址 | a在线视频v视频 | av电影在线不卡 | 在线韩国电影免费观影完整版 | 色狠狠一区二区 | 国产xxxx性hd极品 | 91av中文 | 97人人艹| 色婷婷亚洲 | 黄色.com| 日韩成人看片 | 欧美 日韩 久久 | 狠狠的日 | 丁香婷婷射| 99精品黄色片免费大全 | 在线观看视频 | 黄色91免费观看 | 操老逼免费视频 | 99这里精品 | 91香蕉视频好色先生 | 婷婷丁香花| 亚洲一区视频在线播放 | 日韩视频一区二区三区 | 99久久婷婷国产一区二区三区 | 亚洲天堂网视频 | 久久综合九色综合久99 | 国产日本在线播放 | 中文字幕亚洲精品在线观看 | 欧美精品一区二区在线观看 | 婷婷黄色片 | 日韩中文字幕在线观看 | 91日韩在线播放 | 五月婷婷毛片 | 久久a级片| 国产黄色片一级 | 中文字幕av一区二区三区四区 | 日本精品视频在线观看 | 国产美女无遮挡永久免费 | 久久国产精品一区二区三区四区 | 欧美在线视频一区二区 | 99精品视频观看 | 狠狠躁天天躁综合网 | 成年人在线观看免费视频 | 黄色一级免费网站 | 超碰av免费 | 国产视频中文字幕 | 成人三级网址 | 国产精品丝袜久久久久久久不卡 | 亚洲女同videos | 伊人日日干 | 日本中文字幕在线播放 | 国内三级在线 | 综合色伊人 | 国产视频69 | 国产中文字幕网 | 成人免费毛片aaaaaa片 | 中日韩欧美精彩视频 | 日韩中文在线观看 | 黄色app网站在线观看 | 免费在线观看国产精品 | 91视频免费视频 | 亚洲欧美日韩国产一区二区三区 | 天天看天天干 | 日韩黄色中文字幕 | 成人高清在线观看 | 最近中文国产在线视频 | 国产精品一区二区三区四 | 亚洲免费av在线播放 | 日韩av成人在线观看 | 亚洲国产成人精品在线 | 国产成人av网址 | 久久精品视频在线 | 美女网站视频一区 | 精品一区二区av | 国产精品一区久久久久 | 免费视频91蜜桃 | 久久99在线视频 | 欧美激情第十页 | 91精品视频在线看 | 国产精品久久久久永久免费观看 | 国产破处精品 | 一区二区三区精品在线 | 另类老妇性bbwbbw高清 | 婷婷色在线播放 | www.天天操.com | 丁香花在线视频观看免费 | 在线播放日韩 | 亚洲午夜av电影 | 欧美成人日韩 | 一区二区三区四区久久 | 亚洲精品综合在线 | 欧美日韩在线观看一区二区三区 | 黄色网中文字幕 | 69久久夜色精品国产69 | av免费线看 | 欧美午夜性 | 亚洲国产黄色片 | 在线91观看 | 永久免费的啪啪网站免费观看浪潮 | 在线va网站 | 亚洲激情在线观看 | 日本三级人妇 | 国产一区av在线 | 日本xxxxav| 国产精品综合久久久久久 | 最近免费在线观看 | 日本少妇视频 | 91精品国自产在线偷拍蜜桃 | 99精品视频免费观看视频 | 天天射天天操天天干 | 成年人国产视频 | 亚洲第一香蕉视频 | 天天天天天天操 | 五月婷婷丁香综合 | 欧美成年网站 | 一区二区三区在线电影 | 国产盗摄精品一区二区 | 亚洲精品1区2区3区 超碰成人网 | 色激情五月 | 激情五月伊人 | 2023亚洲精品国偷拍自产在线 | 在线观看免费视频你懂的 | 波多野结衣最新 | 黄色aaa级片 | 天天干,天天操 | 国产精品精品久久久久久 | 国产又粗又硬又长又爽的视频 | 精品影院 | 五月激情在线 | 亚洲精品美女在线观看播放 | 91污视频在线观看 | 91麻豆精品国产自产在线游戏 | 高清国产一区 | 国产黄色片免费观看 | 亚洲欧洲视频 | 国产精品21区 | 黄色成人91 | 91精品入口| 人人爽人人爽人人爽人人爽 | 91亚洲在线观看 | a天堂中文在线 | a级成人毛片 | 久久久久女人精品毛片 | 亚洲国产日韩精品 | 国产91精品在线观看 | 国产免费视频在线 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美极品裸体 | 碰碰影院| 国产中文字幕免费 | 四虎永久精品在线 | 欧美亚洲xxx| 色先锋av资源中文字幕 | 黄色资源在线观看 | 97综合网| 国产91免费在线 | 在线免费观看的av | 国产不卡在线看 | 国产成人一区二区在线观看 | 在线观看视频一区二区三区 | 国内精品久久久精品电影院 | 亚洲va韩国va欧美va精四季 | 91精品国产福利在线观看 | 欧美日韩1区 | 国产91大片| 69视频在线| 国产一区二区观看 | 午夜免费久久看 | 超级碰碰碰视频 | 亚洲精品字幕在线 | 国产vs久久 | 激情网站五月天 | 久久人人97超碰国产公开结果 | 日本精品一区二区在线观看 | 国产探花 | 黄在线免费看 | 狠狠躁夜夜av | 久久国产欧美日韩精品 | 黄色成人av在线 | 国产视频精品网 | 国产.精品.日韩.另类.中文.在线.播放 | 一区二区三区在线观看免费视频 | 国外成人在线视频网站 | 亚洲理论视频 | 国产小视频免费在线观看 | 久久久久成 | 日本超碰在线 | 欧美一区免费观看 | 久久久久麻豆v国产 | 丁香电影小说免费视频观看 | 天天操夜操视频 | 日韩一二三| 亚洲精品在线免费观看视频 | 日本性高潮视频 | 麻豆国产精品视频 | 久久精品爱爱视频 | 国产不卡在线观看 | 97国产一区 | 免费电影一区二区三区 | 久久综合久久综合这里只有精品 | 99在线精品免费视频九九视 | www.黄色网.com | 五月天久久久 | 日韩中文字幕亚洲一区二区va在线 | 九九热免费视频在线观看 | 97国产大学生情侣白嫩酒店 | 亚洲综合在线一区二区三区 | 国产黑丝袜在线 | 手机av网站 | 国产一区国产精品 | 97人人添人澡人人爽超碰动图 | 欧美日韩一区三区 | 中文字幕日韩国产 | 成人免费视频网站在线观看 | 国产精品理论在线观看 | 久久亚洲精品电影 | www.天堂av| 91重口视频 | 国产精品第10页 | 成人黄大片 | 韩国精品一区二区三区六区色诱 | 日韩精品视频在线观看免费 | 免费在线观看成人 | 一本一本久久a久久精品综合妖精 | 色视频在线免费观看 | 人人插超碰 | 久久婷婷色 | 免费在线黄网 | 久久久九色精品国产一区二区三区 | 在线蜜桃视频 | 欧美日韩免费在线视频 | 黄色免费网站下载 | 日本精品久久久久中文字幕 | 免费在线激情电影 | 很黄很污的视频网站 | 久久久国内精品 | 欧美日韩在线看 | 成人观看 | 韩日精品在线 | www在线免费观看 | 九九在线免费视频 | 天堂在线免费视频 | 午夜精品av在线 | 国产资源免费 | 亚洲小视频在线观看 | 五月开心六月伊人色婷婷 | 一区 二区 精品 | 久久视频免费在线观看 | 亚洲欧美日本国产 | 国产剧情在线一区 | 久草免费在线观看视频 | 国产亚洲精品成人av久久ww | 久久调教视频 | 在线综合 亚洲 欧美在线视频 | 99爱视频 | 蜜臀精品久久久久久蜜臀 | 1000部18岁以下禁看视频 | 久久久电影网站 | 色综合久久88色综合天天 | 亚洲精品视频在 | 亚洲综合丁香 | av在线网站免费观看 | 激情伊人五月天久久综合 | 免费的国产精品 | 激情丁香综合五月 | 中文一区二区三区在线观看 | a级国产片| 91av免费观看 | 在线观看免费av网 | 亚洲最新视频在线 | 日韩高清片 | 人人射 | 成年人视频在线免费观看 | 亚州精品成人 | 亚洲专区免费观看 | 亚洲色五月 | 四虎国产精| 在线免费性生活片 | 丁香婷婷激情国产高清秒播 | 天天干,天天操 | 精品久久一二三区 | 夜夜爽www | 超碰人人草人人 | 黄色软件在线观看视频 | 成人欧美一区二区三区黑人麻豆 | 二区精品视频 | 免费日韩一区二区三区 | 丝袜足交在线 | 亚洲一区二区精品视频 | 国产成人精品av在线 | 亚洲精品视频在线观看免费视频 | 久久免费一 | bbb搡bbb爽爽爽 | 亚洲精品男女 | 国产精品私人影院 | 天天躁天天狠天天透 | 色国产视频 | 欧美国产日韩一区 | 激情综合五月婷婷 | www激情网| 国产91精品在线观看 | 精品亚洲午夜久久久久91 | 免费看的黄色录像 | 亚洲人视频在线 | 超碰在线91 | 亚洲免费在线 | 尤物97国产精品久久精品国产 | 日韩欧美高清视频在线观看 | 就要干b | 亚洲午夜精品久久久久久久久 | 99热最新| 国产韩国日本高清视频 | 成人av片免费看 | 亚洲精品一区二区三区高潮 | 美女福利视频网 | 日韩一级电影在线 | 狠狠操狠狠 | 最新中文字幕视频 | 日韩特级黄色片 | 99亚洲国产 | 国产自产在线视频 | 天堂入口网站 | 91精品国产92久久久久 | 91麻豆精品 | 久久99偷拍视频 | 人人澡人人爽欧一区 | 夜色资源站国产www在线视频 | 国产日韩精品欧美 | 99999精品 | 在线观看黄色大片 | 黄色片网站av | 热re99久久精品国产66热 | 欧美一进一出抽搐大尺度视频 | 精品成人a区在线观看 | 九九精品无码 | zzijzzij亚洲日本少妇熟睡 | 亚洲精品在线观看免费 | 五月婷婷六月丁香 | 99久久精品国产毛片 | 久久久亚洲网站 | 国产亚洲综合精品 | 国产免费久久 | 久久久精品视频成人 | 伊人五月在线 | 成人亚洲免费 | 国产精品igao视频网网址 | 黄色大片av | 天天干天天射天天爽 | 国产日韩av在线 | 伊人狠狠干 | 欧美日韩有码 | 九九久久电影 | 波多野结衣在线观看一区二区三区 | 国内精自线一二区永久 | 国产精品成人一区二区三区吃奶 | 美女一二三区 | 日本久久高清视频 | 日韩影片在线观看 | 日韩av一区二区三区在线观看 | 婷婷激情五月 | 日韩国产精品久久 | 免费日韩一级片 | 久久歪歪| 最新日本中文字幕 | 在线免费观看视频你懂的 | 成年人黄色大片在线 | 国产精品嫩草影院123 | 人人搞人人爽 | 一区二区不卡视频在线观看 | 日本99久久 | 久久久久久久久久久高潮一区二区 | 日本韩国精品一区二区在线观看 | 91精品国产综合久久婷婷香蕉 | 欧美日韩69| 免费色视频 | 日韩欧美高清一区二区 | 国产一卡二卡在线 | 在线观看岛国 | 午夜精品福利一区二区 | 国产午夜精品一区二区三区四区 | 亚洲精品视频在线观看免费视频 | 成人a毛片| 亚洲天堂网站 | 最新婷婷色 | 中文字幕永久 | 国产麻豆电影在线观看 | 国产录像在线观看 | 色综合天天天天做夜夜夜夜做 | 在线观看欧美成人 | 99性视频 | 免费91麻豆精品国产自产在线观看 | 四虎永久精品在线 | 日韩精品国产一区 | 亚洲午夜在线视频 | 国产成人一级电影 | 国产一级视屏 | 亚洲精品天天 | 国产男女无遮挡猛进猛出在线观看 | 成人黄色片免费 | 久草视频在线新免费 | 99色在线播放 | 免费开视频 | 国产精品12345 | 欧美色综合久久 | 亚洲综合黄色 | 97福利| 国产在线精品国自产拍影院 | 免费看污在线观看 | 天天射天天 | 亚洲精品自拍视频在线观看 | 国产精品一区二区免费 | 成人精品影视 | 亚洲免费精品一区二区 | 青青色影院 | 四虎影视成人精品国库在线观看 | 综合久久精品 | 九九九热精品免费视频观看 | 色噜噜在线观看视频 | 午夜精品区| 99色在线观看视频 | 91成人精品国产刺激国语对白 | 91资源在线 | 婷婷精品视频 | 在线成人免费av | 欧美伦理电影一区二区 | 久精品视频在线 | 国产精品国产亚洲精品看不卡15 | 国产视频1| 日韩在线| 欧美成人黄色片 | 91污污 | 黄色一级在线观看 | www.狠狠操.com| 日韩高清不卡一区二区三区 | 999毛片| 超碰在线人 | 91亚洲网站| 永久免费在线 | 中文字幕亚洲欧美日韩2019 | 婷婷丁香av| 久久美女电影 | 精品国内自产拍在线观看视频 | 免费在线观看日韩欧美 | 国产亚洲精品久久久久久无几年桃 | 国产成人久 | 久久99热精品 | 精品久久久久久久久久 | 国产黄免费在线观看 | 狠狠色伊人亚洲综合成人 | 久久只精品99品免费久23小说 | 国产精品一区二区三区在线免费观看 | 久久综合国产伦精品免费 | 国产成人精品国内自产拍免费看 | 在线观看免费国产小视频 | 在线日韩视频 | 又黄又爽免费视频 | 国产日韩亚洲 | 亚洲精品www久久久 www国产精品com | 成人播放器 | 国产在线综合视频 | 国产高清黄 | 亚洲一区日韩在线 | 一区二区三区四区在线免费观看 | 天天色天天色 | 亚洲精品乱码久久久久久高潮 | 51久久成人国产精品麻豆 | 久久久久久久影视 | 97av在线视频免费播放 | 88av色| 久久精品国产免费观看 | 久久草在线视频国产 | 91桃色视频| 精品99免费 | 在线免费观看一区二区三区 | 五月天狠狠操 | 天天操天天操天天操 | 6080yy午夜一二三区久久 | 国产永久免费观看 | 国产在线观看你懂得 | 国产美女被啪进深处喷白浆视频 | 成人在线黄色 | 黄色影院在线播放 | 国产黄色精品在线 | 天天综合久久 | 人人爱人人添 | 少妇搡bbbb搡bbb搡忠贞 | 99久久精品费精品 | 国产色爽| 九九热.com| 激情视频免费观看 | 日韩精品最新在线观看 | 日日爱网址 | 91麻豆免费视频 | 韩国av在线 | 成人在线视频你懂的 | 日韩欧美国产精品 | 久久9999久久免费精品国产 | 9999亚洲| 四虎伊人 | 黄色一级免费电影 | 免费av观看网站 | 国产精品12345| 成年人在线免费视频观看 | 人人澡人人爱 | 91在线观看高清 | 日本女人的性生活视频 | 天天色 天天 | 天天激情综合网 | 国产视频在 | 91视频3p | 友田真希x88av | 免费一级片在线观看 | 五月天色中色 | 国产高清在线观看 | 免费在线日韩 | 亚洲精品视频在 | 中文字幕在线色 | 久久久黄色免费网站 | 五月开心网 | 深爱激情综合 | 国产精品18久久久久久不卡孕妇 | 在线www色| 精品亚洲男同gayvideo网站 | 国产精品第二十页 | 欧美日韩破处 | www在线观看国产 | 国产直播av | 日本久久久久久科技有限公司 | 嫩草91影院 | 国产中文字幕网 | 国产主播大尺度精品福利免费 | 九色91视频 | 美女视频免费一区二区 | 九九视频网站 | 成人黄色在线播放 | 久久午夜免费视频 | 尤物九九久久国产精品的分类 | 91成人天堂久久成人 | 国产精品午夜久久久久久99热 | 国产亚洲精品电影 | 91av国产视频| 国产精品久久久久久久久久东京 | 免费av影视| 午夜精品一区二区国产 | 91香蕉视频黄色 | 波多野结衣在线观看一区二区三区 | 精品资源在线 | 日本精品一区二区三区在线播放视频 | 色资源中文字幕 | 欧美日韩性视频在线 | 久草网视频在线观看 | 婷婷电影在线观看 | 国产美女在线精品免费观看 | 日韩亚洲国产精品 | 久久国产精品99久久久久久进口 | 成人性生交大片免费观看网站 | 久久精品视频3 | 麻豆免费视频网站 | 日韩在线高清视频 | 久草在线电影网 | 国产伦理久久精品久久久久_ | 亚洲精品国产精品乱码在线观看 | 成 人 黄 色 免费播放 | 国产手机在线观看 | 日韩精品视频在线免费观看 | 99精品视频免费观看视频 | 麻豆精品在线 | 国产精品一区二区免费在线观看 | 中文一区二区三区在线观看 | 久久天天躁 | 91久久精品一区 | 久久黄色小说视频 | 亚洲做受高潮欧美裸体 | 国内精品久久天天躁人人爽 | 在线看欧美 | 中文字幕国语官网在线视频 | 亚洲一区二区视频在线播放 | 欧美日韩视频 | 久久99视频 | 九九视频精品免费 | 96精品视频| 91亚洲精品在线观看 | 狠狠干狠狠色 | 高清一区二区三区 | 久久久久综合 | 91色在线观看| www.狠狠色.com| 久久久久国产成人精品亚洲午夜 | 91免费国产在线观看 | 欧美色噜噜 | 亚洲国产理论片 | avcom在线| 麻豆免费视频网站 | av中文字幕在线免费观看 | 久久精品毛片基地 | 亚洲高清激情 | 久久久久久久久久久久久国产精品 | av资源在线观看 | 激情久久久久久久久久久久久久久久 | 久久国产精品免费观看 | 久久精品中文字幕一区二区三区 | 中文字幕亚洲精品日韩 | 狠狠色丁香久久婷婷综 | 婷婷丁香狠狠爱 | 天天干干 | 91看片在线免费观看 | 国产中出在线观看 | 韩国视频一区二区三区 | 中文字幕免费在线 | 日日干夜夜干 | 97电影在线| av片免费播放 | 91免费高清观看 | 超碰在线网| 国产女人18毛片水真多18精品 | 日韩欧美精品在线视频 | www.色午夜.com | 综合av在线 | 久久婷婷开心 | 亚洲精品黄网站 | 亚洲在线激情 | 亚洲国产精品日韩 | 成人午夜黄色 | 黄色毛片电影 | 中文字幕首页 | 91在线视频免费播放 | 亚洲毛片一区二区三区 | 亚洲精色 | 在线免费观看欧美日韩 | 粉嫩av一区二区三区四区五区 | 五月激情片 | 久久一区二区免费视频 | 久久国产亚洲精品 | 久久涩视频| 国产精品高清在线 | 国产香蕉久久 | 人人爽人人爽人人爽人人爽 | 香蕉网在线播放 | 香蕉久久久久久av成人 | 精品爱爱 | 欧美超碰在线 | 亚洲一区欧美激情 | 亚洲成av人片在线观看香蕉 | 日韩欧美aaa | 国产二区视频在线 | 精品视频一区在线观看 | 一级一级一片免费 | 天天综合日日夜夜 | 久久精品一二三区 | 久久高清av | 91九色porny在线 | 成人黄色片在线播放 | 五月婷婷天堂 | 欧美成人黄色片 | 国产精品免费久久久久影院仙踪林 | 久久96国产精品久久99软件 | 国产美腿白丝袜足在线av | 在线观看黄色的网站 | 91黄色在线观看 | 日韩在线国产 | 中文字幕电影网 | 亚洲欧洲精品一区二区精品久久久 | 亚洲激情视频 | 亚洲专区视频在线观看 | 99精品国产一区二区三区麻豆 | 国产91aaa| 深夜男人影院 | av三区在线 | 日韩字幕在线观看 | 亚洲最新av在线网址 | 国产精品日韩久久久久 | 天堂在线视频中文网 | 久久久精品国产免费观看同学 | 69精品| 五月激情丁香婷婷 | 亚洲精品国偷自产在线91正片 | 狠狠操影视 | 九色琪琪久久综合网天天 | 久久久久一区 | 激情综合亚洲 | 四虎成人免费影院 | 免费观看完整版无人区 | 国产精品久久伊人 | 日韩精品国产一区 | www.av中文字幕.com | 午夜体验区| 久久精品成人欧美大片古装 | 色久av| 亚洲欧洲一区二区在线观看 | 视频在线观看99 | 中文字幕av专区 | 日本不卡久久 | 98涩涩国产露脸精品国产网 | 免费一级片在线观看 | 亚洲精品乱码久久久一二三 | 成人黄色短片 | 99在线精品观看 | 日韩成人中文字幕 | 精品国产伦一区二区三区观看说明 | 麻豆视频在线观看 | 精品一区二区在线免费观看 | 日韩一级理论片 | 国产成人精品综合久久久 | 亚洲最新合集 | 成年人在线看片 | 日韩资源在线观看 | 中文字幕国语官网在线视频 | 99免费精品视频 | 精品九九九九 | 欧美aaa级片 | 欧美另类色图 | 香蕉97视频观看在线观看 | 麻豆91小视频 | 免费人做人爱www的视 | 狠狠色婷婷丁香六月 | 久久综合色天天久久综合图片 | 天堂在线一区二区三区 | 福利一区视频 | 亚洲传媒在线 | 午夜精品一区二区三区在线播放 | 黄色小说免费观看 | 久久歪歪 | 国产午夜在线观看视频 | 日韩中文字幕第一页 | 成人欧美日韩国产 | 天天综合色天天综合 | 视频一区视频二区在线观看 | 天天爱天天操天天干 | 欧美精品v国产精品v日韩精品 | 日韩免费大片 | 国产专区一 | 免费亚洲一区二区 | 国产精品久久久久永久免费观看 | 欧美精品在线观看 | 国内精品久久影院 | 日本视频久久久 | 狠狠躁夜夜躁人人爽超碰91 | 中文字幕在线久一本久 | 天天操天天干天天爱 | 免费视频91 | 成人免费观看网址 | 在线观看视频在线观看 | 在线免费三级 | 美女黄频在线观看 | 国产精久久久久久久 | 日韩在线观看视频在线 | 中文十次啦| 久草在线视频中文 | 四虎成人精品永久免费av | 最近日韩中文字幕中文 | av日韩在线网站 | 99热国内精品 | 成人夜晚看av | 91免费版在线观看 | 国产精品区一区 | 九色91在线 | 天天草天天草 | 免费在线观看午夜视频 |