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

ORM鏈?zhǔn)讲僮鞯淖侄芜^濾&為什么GoFrame不支持migrate功能?

開發(fā) 后端
goframe是一款用于企業(yè)生產(chǎn)級(jí)別的框架,各個(gè)模塊設(shè)計(jì)嚴(yán)謹(jǐn),工程實(shí)踐的細(xì)節(jié)處理得比較好。為安全性保證、防止誤操作,Update及Delete方法必須帶有Where條件才能提交執(zhí)行,否則將會(huì)錯(cuò)誤返回,錯(cuò)誤信息如:there should be WHERE condition statement for XXX operation。

初學(xué)者必須搞懂:

在 Go 中,沒有null、none、NULL、None

任何類型在未初始化時(shí)都對(duì)應(yīng)一個(gè)零值:布爾類型是 false ,整型是 0 ,字符串是 ""

而指針,函數(shù),interface,slice,channel和map的零值都是 nil

結(jié)合場(chǎng)景,平衡利弊,做出取舍

下圖是一位讀者問我的問題,我翻遍了文檔也沒找到相關(guān)的資料,猜測(cè)應(yīng)該是不支持的。

圖片

于是問了goframe作者,被明確告知:goframe不支持,并且以后也不會(huì)支持。

作者也詳細(xì)解答了不支持的原因,goframe作者團(tuán)隊(duì)的考慮是這樣的:

圖片

因?yàn)槲易龅捻?xiàng)目比較多,在數(shù)據(jù)庫(kù)表結(jié)構(gòu)管理方面踩過坑。還是比較能接受goframe作者觀點(diǎn)的。

migrate這種功能確實(shí)能方便開發(fā)者,但是在企業(yè)級(jí)項(xiàng)目中,尤其是TOB的業(yè)務(wù),穩(wěn)定是第一要?jiǎng)?wù)。migrate功能雖然方便,但是不夠嚴(yán)謹(jǐn),如果沒有很強(qiáng)的規(guī)范去約束團(tuán)隊(duì)成員的使用,很容易出問題,出了問題就不是小問題,所以不敢用。

這也讓我想起了另外一件事情:

前段時(shí)間在review代碼時(shí),發(fā)現(xiàn)了一個(gè)“無條件”的刪除腳本在運(yùn)行,心頭一驚啊!這要是把數(shù)據(jù)刪了可麻煩了。但是查詢DB發(fā)現(xiàn)沒有刪除數(shù)據(jù)。

我詳細(xì)查了官方文檔,沒有被刪數(shù)據(jù)的原因是這樣的:

goframe是一款用于企業(yè)生產(chǎn)級(jí)別的框架,各個(gè)模塊設(shè)計(jì)嚴(yán)謹(jǐn),工程實(shí)踐的細(xì)節(jié)處理得比較好。為安全性保證、防止誤操作,Update及Delete方法必須帶有Where條件才能提交執(zhí)行,否則將會(huì)錯(cuò)誤返回,錯(cuò)誤信息如:there should be WHERE condition statement for XXX operation。

好吧,感謝,真是救我狗命了,哈哈。

也正是因?yàn)樽约鹤隽撕芏囗?xiàng)目,踩了很多坑,碰到了不少這種細(xì)節(jié)問題。

目前才有了“從追求開發(fā)效率”到“追求項(xiàng)目穩(wěn)定性”的轉(zhuǎn)變。

在這里也回答一下最近大家私信我的問題吧:“為什么我使用goframe框架做這個(gè)電商實(shí)戰(zhàn)項(xiàng)目?”

原因很簡(jiǎn)單,我結(jié)合自己的經(jīng)歷,覺得GoFrame是一個(gè)適合企業(yè)級(jí)項(xiàng)目比較嚴(yán)謹(jǐn)?shù)目蚣埽苌俨瓤樱苊庖恍┞闊km然入門門檻是有的,但是在“工程化開發(fā)設(shè)計(jì)”的規(guī)范下,后續(xù)的維護(hù)成本還是比較低的。所以才帶大家使用這個(gè)框架做電商項(xiàng)目的。

好了,不同的場(chǎng)景,不同的項(xiàng)目有不同的解決方案,不同的優(yōu)選框架。這個(gè)問題沒有標(biāo)準(zhǔn)答案,結(jié)合自己的需求去選擇合適的解決方案吧。

歡迎大家找我交流,多提像這位讀者一樣有價(jià)值的問題,一起進(jìn)步!

Fields/FieldsEx字段過濾

Fields  用于指定需要操作的表字段,包括查詢字段、寫入字段、更新字段等過濾;

FieldsEx  用于例外的字段指定,可用于查詢字段、寫入字段、更新字段等過濾;

?Fields??示例

假如user?表有4個(gè)字段uid?,  nickname?,  passport?,  password。

查詢字段過濾

 // SELECT `uid`,`nickname` FROM `user` ORDER BY `uid` asc
g.Model("user").Fields("uid, nickname").Order("uid asc").All()

寫入字段過濾

m := g.Map{
"uid" : 10000,
"nickname" : "John Guo",
"passport" : "john",
"password" : "123456",
}
g.Model(table).Fields("nickname,passport,password").Data(m).Insert()
// INSERT INTO `user`(`nickname`,`passport`,`password`) VALUES('John Guo','john','123456')

?FieldsEx??示例

1.假如user?表有4個(gè)字段uid?,  nickname?,  passport?,  password。

2.查詢字段排除

 // SELECT `uid`,`nickname` FROM `user`
g.Model("user").FieldsEx("passport, password").All()

3.寫入字段排除

 m := g.Map{
"uid" : 10000,
"nickname" : "John Guo",
"passport" : "john",
"password" : "123456",
}
g.Model(table).FieldsEx("uid").Data(m).Insert()
// INSERT INTO `user`(`nickname`,`passport`,`password`) VALUES('John Guo','john','123456')

OmitEmpty空值過濾

當(dāng)  map/struct?  中存在空值如  nil,"",0?  時(shí),默認(rèn)情況下,gdb?將會(huì)將其當(dāng)做正常的輸入?yún)?shù),因此這些參數(shù)也會(huì)被更新到數(shù)據(jù)表。OmitEmpty特性可以在將數(shù)據(jù)寫入到數(shù)據(jù)庫(kù)之前過濾空值數(shù)據(jù)的字段。

相關(guān)方法:

func (m *Model) OmitEmpty() *Model
func (m *Model) OmitEmptyWhere() *Model
func (m *Model) OmitEmptyData() *Model

OmitEmpty?方法會(huì)同時(shí)過濾Where及Data?中的空值數(shù)據(jù),而通過OmitEmptyWhere/OmitEmptyData方法可以執(zhí)行特定的字段過濾。

寫入/更新操作

空值會(huì)影響于寫入/更新操作方法,如Insert?,  Replace?,  Update?,  Save?操作。如以下操作(以map?為例,struct同理):

// UPDATE `user` SET `name`='john',update_time=null WHERE `id`=1
g.Model("user").Data(g.Map{
"name" : "john",
"update_time" : nil,
}).Where("id", 1).Update()

針對(duì)空值情況,我們可以通過OmitEmpty方法來過濾掉這些空值。例如,以上示例可以修改為:

// UPDATE `user` SET `name`='john' WHERE `id`=1
g.Model("user").OmitEmpty().Data(g.Map{
"name" : "john",
"update_time" : nil,
}).Where("id", 1).Update()

對(duì)于struct數(shù)據(jù)參數(shù),我們也可以進(jìn)行空值過濾。操作示例:

type User struct {
Id int `orm:"id"`
Passport string `orm:"passport"`
Password string `orm:"password"`
NickName string `orm:"nickname"`
CreateTime string `orm:"create_time"`
UpdateTime string `orm:"update_time"`
}
user := User{
Id : 1,
NickName : "john",
UpdateTime: gtime.Now().String(),
}
g.Model("user").OmitEmpty().Data(user).Insert()
// INSERT INTO `user`(`id`,`nickname`,`update_time`) VALUES(1,'john','2019-10-01 12:00:00')

注意喲,批量寫入/更新操作中OmitEmpty方法將會(huì)失效,因?yàn)樵谂坎僮髦校仨毐WC每個(gè)寫入記錄的字段是統(tǒng)一的。

關(guān)于omitempty?標(biāo)簽與OmitEmpty方法:

針對(duì)于struct?的空值過濾大家會(huì)想到omitempty?的標(biāo)簽。該標(biāo)簽常用于json?轉(zhuǎn)換的空值過濾,也在某一些第三方的ORM?庫(kù)中用作struct到數(shù)據(jù)表字段的空值過濾,即當(dāng)屬性為空值時(shí)不做轉(zhuǎn)換。

omitempty?標(biāo)簽與OmitEmpty?方法所達(dá)到的效果是一樣的。在ORM?操作中,我們不建議對(duì)struct?使用omitempty?的標(biāo)簽來控制字段的空值過濾,而建議使用OmitEmpty?方法來做控制。因?yàn)樵摌?biāo)簽一旦加上之后便綁定到了struct?上,沒有辦法做靈活控制;而通過OmitEmpty?方法使得開發(fā)者可以選擇性地、根據(jù)業(yè)務(wù)場(chǎng)景對(duì)struct做空值過濾,操作更加靈活。

數(shù)據(jù)查詢操作

空值也會(huì)影響數(shù)據(jù)查詢操作,主要是影響where?條件參數(shù)。我們可以通過OmitEmpty方法過濾條件參數(shù)中的空值。

使用示例:

// SELECT * FROM `user` WHERE `passport`='john' LIMIT 1
r, err := g.Model("user").Where(g.Map{
"nickname" : "",
"passport" : "john",
}).OmitEmpty().One()
type User struct {
Id int `orm:"id"`
Passport string `orm:"passport"`
Password string `orm:"password"`
NickName string `orm:"nickname"`
CreateTime string `orm:"create_time"`
UpdateTime string `orm:"update_time"`
}
user := User{
Passport : "john",
}
r, err := g.Model("user").OmitEmpty().Where(user).One()
// SELECT * FROM `user` WHERE `passport`='john' LIMIT 1

OmitNil空值過濾

當(dāng)  map/struct?  中存在空值如  nil?時(shí),默認(rèn)情況下,gdb?將會(huì)將其當(dāng)做正常的輸入?yún)?shù),因此這些參數(shù)也會(huì)被更新到數(shù)據(jù)表。OmitNil?特性可以在將數(shù)據(jù)寫入到數(shù)據(jù)庫(kù)之前過濾空值數(shù)據(jù)的字段。與OmitEmpty?特性的區(qū)別在于,OmitNil?只會(huì)過濾值為nil?的空值字段,其他空值如"",0并不會(huì)被過濾。

相關(guān)方法:

func (m *Model) OmitNil() *Model
func (m *Model) OmitNilWhere() *Model
func (m *Model) OmitNilData() *Model

OmitNil?方法會(huì)同時(shí)過濾Where及Data?中的空值數(shù)據(jù),而通過OmitNilWhere/OmitNilData方法可以執(zhí)行特定的字段過濾。

Filter字段過濾(已內(nèi)置)

gdb?可以自動(dòng)同步數(shù)據(jù)表結(jié)構(gòu)到程序緩存中(緩存不過期,直至程序重啟/重新部署),并且可以過濾提交參數(shù)中不符合表結(jié)構(gòu)的數(shù)據(jù)項(xiàng),該特性可以使用Filter?方法實(shí)現(xiàn)。常用于新增/刪除操作中輸入map/struct/[]map/[]string參數(shù)類型的場(chǎng)景。

使用示例,假如user?表有4個(gè)字段uid?,  nickname?,  passport?,  password:

r, err := g.Model("user").Filter().Data(g.Map{
"id" : 1,
"uid" : 1,
"passport" : "john",
"password" : "123456",
}).Insert()
// INSERT INTO user(uid,passport,password) VALUES(1, "john", "123456")

其中id為不存在的字段,在寫入數(shù)據(jù)時(shí)將會(huì)被過濾掉,不至于被構(gòu)造成寫入SQL中產(chǎn)生執(zhí)行錯(cuò)誤。

數(shù)據(jù)庫(kù)沒有設(shè)計(jì)為Data?方法做自動(dòng)過濾,而是需要開發(fā)者調(diào)用Filter方法來手動(dòng)指定過濾,目的是友好地提醒開發(fā)者可能誤寫/傳遞錯(cuò)誤了字段名稱。如果強(qiáng)制性的自動(dòng)過濾可能會(huì)引起難以預(yù)料的業(yè)務(wù)邏輯異常,例如,由于字段名稱拼寫錯(cuò)誤導(dǎo)致自動(dòng)過濾了本來需要輸入的字段,導(dǎo)致寫入數(shù)據(jù)庫(kù)的數(shù)據(jù)不完整。

從GoFrame v1.15.7?版本開始,根據(jù)社區(qū)整體反饋,為提高組件易用性,filter?特性被設(shè)置為默認(rèn)開啟,不再需要顯示調(diào)用,F(xiàn)ilter方法已被標(biāo)記廢棄。

本文轉(zhuǎn)載自微信公眾號(hào)「 程序員升級(jí)打怪之旅」,作者「王中陽(yáng)Go」,可以通過以下二維碼關(guān)注。

轉(zhuǎn)載本文請(qǐng)聯(lián)系「 程序員升級(jí)打怪之旅」公眾號(hào)。

責(zé)任編輯:武曉燕 來源: 程序員升級(jí)打怪之旅
相關(guān)推薦

2021-08-02 09:31:20

Python工具代碼

2021-10-27 07:15:36

Go 循環(huán)引用

2020-07-22 08:01:41

Python開發(fā)運(yùn)算符

2020-10-09 06:48:19

Pythonswitch語句

2021-12-09 10:51:47

Go繼承

2021-12-15 07:49:22

Go語言設(shè)計(jì)

2021-02-01 13:53:53

StringlongJava

2023-01-28 08:05:32

轉(zhuǎn)換Go泛型

2024-05-28 08:55:52

2024-01-01 08:10:40

Go語言map

2024-01-05 08:45:35

Go語言map

2009-03-12 08:42:38

AndroidWMMTK

2021-11-08 11:02:01

Go函數(shù)重載

2021-06-11 00:03:31

鴻蒙智能手機(jī)

2021-01-22 15:31:47

JavaSwitchString

2021-07-13 08:09:34

微博推特評(píng)論

2009-03-11 17:32:22

聯(lián)發(fā)科WMAndroid

2014-06-05 15:16:49

Linux開源Flash

2024-03-08 08:51:59

Gomain函數(shù)

2020-07-09 09:56:48

Python語言開發(fā)
點(diǎn)贊
收藏

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

不卡av在线播放| 国产精品免费视频观看| 欧美另类高清videos| 污污污www精品国产网站| 欧美gay视频| 亚洲欧美国产高清| 久久精品人成| 91美女精品网站| 在线欧美三区| 日韩天堂在线视频| 亚洲欧美日韩偷拍| 久久婷婷五月综合色丁香| 亚洲午夜私人影院| 亚洲欧美日韩在线综合| 人妻无码中文字幕| 久久成人av少妇免费| 97碰在线观看| 国产a免费视频| 欧美在线电影| 亚洲精品自在久久| 国产老头和老头xxxx×| 日韩精选视频| 亚洲第一精品在线| 中文字幕剧情在线观看一区| 国产成人a人亚洲精品无码| 久久精品电影| 欧美激情亚洲激情| 美国一级黄色录像| 18禁一区二区三区| 中文字幕在线观看网站| 国产亚洲综合在线| 国产亚洲精品久久飘花| 国产三级视频在线播放| 日韩av中文字幕一区二区| 国产最新精品视频| 欧美日韩激情在线观看| 99热国内精品永久免费观看| 亚洲人av在线影院| 国产精品一级黄片| 国产欧美啪啪| 欧美成人欧美edvon| 国产三级精品三级在线| 成人精品国产亚洲| 91九色02白丝porn| 黄色片久久久久| 美女搞黄视频在线观看| 亚洲国产人成综合网站| h无码动漫在线观看| 亚洲婷婷噜噜| 一区二区三区欧美视频| 美国av在线播放| 暖暖日本在线观看| 中文字幕亚洲不卡| 免费看av软件| а天堂中文在线官网| 亚洲欧洲日产国码二区| 正在播放亚洲| а√天堂资源地址在线下载| 18成人在线视频| 日韩 欧美 自拍| 国产成人午夜| 亚洲综合偷拍欧美一区色| 国产精品av免费观看| 黄页在线观看免费| 亚洲国产毛片aaaaa无费看| 亚洲熟妇无码一区二区三区| 国产夫妻在线播放| 欧美性生交xxxxxdddd| 成人在线观看a| 日本欧美一区| 欧美疯狂性受xxxxx喷水图片| 在线观看视频欧美| 国产高清精品软男同| 黄色在线视频网站| 亚洲欧美日韩综合aⅴ视频| 午夜久久久久久久久久久| 一二三四区在线观看| 亚洲成人一区在线| 精品人妻一区二区三区四区在线 | 波多野结衣综合网| 三妻四妾的电影电视剧在线观看| 欧美性色19p| 亚洲精品久久久久久宅男| 日韩视频一区二区三区四区| 亚洲国产高清高潮精品美女| 中国毛片在线观看| 久久久久亚洲| 韩国国内大量揄拍精品视频| 日韩精品成人免费观看视频| 另类综合日韩欧美亚洲| 99中文字幕| 国产资源在线观看| 亚洲女厕所小便bbb| 老太脱裤让老头玩ⅹxxxx| 欧美亚洲大片| 日韩精品一区二区三区视频| 中文精品在线观看| 99精品美女| 97av在线视频| 国产又大又粗又硬| 成人免费毛片高清视频| 色女孩综合网| sqte在线播放| 欧美日韩一级黄| av黄色一级片| 女人香蕉久久**毛片精品| 欧洲亚洲在线视频| av中文字幕免费在线观看| 91麻豆文化传媒在线观看| 日韩电影在线播放| а_天堂中文在线| 欧美日韩国产首页在线观看| 中文乱码人妻一区二区三区视频| 囯产精品一品二区三区| 香蕉久久99| 欧美成aaa人片免费看| 激情网站在线观看| 成人永久免费视频| 一区二区三区四区| 伊人网在线播放| 日韩精品一区二区三区蜜臀| 亚洲av毛片基地| 99精品热6080yy久久| 亚洲综合日韩在线| 尤物视频在线免费观看| 色综合久久久久| 催眠调教后宫乱淫校园| 亚洲最大黄网| 国产日韩在线免费| 国产永久免费高清在线观看视频| 午夜日韩在线电影| 欧美人与性动交α欧美精品| 久久社区一区| 国产精品一香蕉国产线看观看| 日本福利片高清在线观看| 亚洲一区欧美一区| 在线观看视频你懂得| 水蜜桃精品av一区二区| 国产精品国产亚洲伊人久久 | 久久精品欧美视频| 中文字幕天堂在线| 久久综合九色欧美综合狠狠| 男女视频网站在线观看| 久久悠悠精品综合网| 欧美精品xxx| 少妇喷水在线观看| 同产精品九九九| 五月开心播播网| 99国产精品| 久久久久无码国产精品一区| 久草在线资源福利站| 亚洲第一网站免费视频| 日本三级午夜理伦三级三| 成人网在线播放| 久艹视频在线免费观看| 精品久久对白| 欧美孕妇性xx| jizzjizz在线观看| 欧美福利电影网| 亚洲男人天堂视频| 男人的天堂av网| 免费成人在线网站| 一区二区三区四区免费视频| 国产香蕉久久| 久久国产精品久久久久久久久久| 国产成人av免费看| 亚洲国产三级在线| 国产肉体xxxx裸体784大胆| 亚洲一级在线| 亚洲一区二区三区精品动漫| 精品国产三区在线| 国模吧一区二区| 国产三区四区在线观看| 欧美日韩成人综合在线一区二区| 欧美日韩偷拍视频| eeuss鲁片一区二区三区在线观看| 男人揉女人奶房视频60分| 欧美亚洲在线日韩| 亚洲free性xxxx护士hd| ririsao久久精品一区| 亚洲欧美国产精品| 一区二区三区精| 亚洲国产成人av| 蜜桃av免费看| 国产中文一区二区三区| 国产主播自拍av| 不卡在线一区二区| aa日韩免费精品视频一| 在线观看爽视频| 播播国产欧美激情| 亚洲国产中文字幕在线| 色视频成人在线观看免| 99热精品免费| 国产午夜精品福利| 欧美体内she精高潮| 亚洲一区视频| 中文字幕一区二区三区四区五区人| ady日本映画久久精品一区二区| 日韩av观看网址| 日本在线观看高清完整版| 亚洲视频在线看| 成人福利小视频| 精品视频免费在线| 日韩欧美亚洲视频| 亚洲视频一区二区在线| 中文字幕人妻一区二区| 国产黑丝在线一区二区三区| 男人女人黄一级| 日韩视频二区| 国产亚洲福利一区| 日韩成人av一区二区| 久久91精品国产91久久小草| 国产97在线 | 亚洲| 亚洲一区 二区 三区| 日韩免费三级| 台湾佬综合网| 国产不卡一区二区三区在线观看 | 国产又爽又黄的激情精品视频| 麻豆mv在线看| 九色91av视频| 求av网址在线观看| 亚洲人成网站色ww在线| 日本xxxxwww| 欧美xxx久久| 国产绿帽刺激高潮对白| 精品视频1区2区3区| 国产又大又粗又爽| 精品国产成人在线| 久久精品欧美一区二区| 亚洲欧美视频一区| 久久一级免费视频| 久久九九99视频| 一本加勒比北条麻妃| 91丨porny丨中文| 亚洲激情 欧美| 不卡av在线免费观看| 岛国大片在线免费观看| 国产在线播放一区二区三区| 99热一区二区| 久久国产综合精品| wwwwwxxxx日本| 久久国产夜色精品鲁鲁99| 色www免费视频| 激情综合五月天| 在线观看的毛片| 国产精品chinese| 亚洲国产精品无码av| 精品二区视频| heyzo亚洲| 亚洲欧美日韩专区| 韩国日本在线视频| av成人天堂| 男人天堂手机在线视频| 日韩精品免费| 免费观看中文字幕| 欧美成人有码| 国产精品一区在线免费观看| 国产精品一区二区av交换| 日韩免费三级| 婷婷另类小说| 黄色a级片免费看| 亚洲欧洲一区| 日本成人在线免费视频| 欧美成人视屏| 亚洲欧美一区二区三区国产精品| 国产av无码专区亚洲av毛网站| 亚洲精品伦理在线| 日本亚洲色大成网站www久久| 精品成人在线视频| 国产成人精品777777| 欧美日韩一级二级| 国产高清免费av| 日韩电影免费观看中文字幕| 国产在线自天天| 久久久精品电影| av中文字幕在线观看第一页| 日本精品久久久久影院| 欧美三级电影网址| 亚洲av无码一区二区三区观看 | 日韩精品欧美一区二区三区| 成人免费av| 中文字幕在线亚洲三区| 精品成人在线| 污版视频在线观看| 国产91精品一区二区麻豆网站 | 国产精品美女一区二区| 91久久国产综合| 亚洲欧洲色图综合| 国产精品免费av一区二区| 在线观看亚洲a| 国产黄色av片| 国产一区二区美女视频| 羞羞的网站在线观看| 欧美一区二区三区免费观看| 欧美极品在线| 久久国产一区| 伊人久久大香线蕉综合四虎小说 | av在线不卡免费看| 国产黄色录像视频| 亚洲成人免费影院| 亚洲字幕av一区二区三区四区| 婷婷综合激情| 国产精自产拍久久久久久蜜| 97人人澡人人爽91综合色| 欧美午夜欧美| 欧美孕妇孕交| 91麻豆精品国产自产在线| 人人妻人人澡人人爽人人欧美一区| 亚洲欧美日韩在线高清直播| www在线观看播放免费视频日本| 欧美伊久线香蕉线新在线| 久久国产精品美女| 亚洲va久久久噜噜噜久久狠狠| 亚洲福利精品| 亚洲国产综合av| 国产精品国产三级国产aⅴ中文 | 国产精品18久久久久久麻辣| 91精品国产乱码久久久竹菊| 亚洲视频小说| 久久久久久黄| 亚洲乱码国产乱码精品精大量| 亚洲综合丝袜美腿| 国产男男gay体育生白袜| 一区三区二区视频| 手机在线观看av| 国产精品日韩欧美一区二区三区 | 久久大胆人体视频| 精品国产一区二区三区在线| 麻豆精品精品国产自在97香蕉| 亚洲最大成人网站| 天天亚洲美女在线视频| 六月婷婷综合网| 九九热精品视频| 精品一区二区三区中文字幕| 在线不卡视频一区二区| 手机毛片在线观看| 亚洲大片免费看| 性欧美一区二区三区| 久久成人18免费网站| 伊人久久一区| 在线视频欧美一区| 看电视剧不卡顿的网站| 91导航在线观看| 欧美日韩一区二区三区高清| 国产二区在线播放| 国产成人精品av在线| 国产麻豆精品久久| 国产一级不卡毛片| 国产三级一区二区三区| 糖心vlog精品一区二区| 中文国产成人精品| 国产一区高清| 欧美日韩在线免费观看视频| 激情六月婷婷久久| 国产少妇在线观看| 欧美大片免费久久精品三p| 久久五月精品中文字幕| 国产亚洲欧美一区二区| 亚洲制服av| 国产高清一区二区三区四区| 在线观看免费一区| 日韩成人影视| 91一区二区三区| 在线欧美福利| 丁香花五月婷婷| 欧美一区二区三区免费在线看| 欧美xxxx黑人又粗又长| 国产一区福利视频| 久久一区亚洲| 欧美激情精品久久久久久免费| 日韩欧美国产综合在线一区二区三区| 日本一级理论片在线大全| 国产欧美日韩视频一区二区三区| 久久动漫亚洲| 婷婷久久综合网| 亚洲精品一区二区三区四区高清| 欧美大胆成人| 在线免费观看一区二区三区| 国产福利精品一区| 91高清国产视频| 日韩久久电影| 日本一本在线视频| 欧美视频在线免费看| 91视频在线观看| 成人午夜电影在线播放| 久久久999| 中国一级片在线观看| 日韩成人中文字幕| 玖玖精品在线| 精品无码一区二区三区在线| 国产精品欧美精品| 丰满人妻av一区二区三区| 国产精品久久久久久超碰| 影音先锋中文字幕一区| 日韩免费成人av| 亚洲国产精久久久久久| 成人全视频在线观看在线播放高清 | 永久免费黄色片| 日韩欧美亚洲一二三区| 手机av免费在线|