午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > golang常用庫之操作數(shù)據(jù)庫的orm框架-gorm基本使用詳解

golang常用庫之操作數(shù)據(jù)庫的orm框架-gorm基本使用詳解

熱門標(biāo)簽:智能電銷機器人營銷 濮陽自動外呼系統(tǒng)代理 廣東語音外呼系統(tǒng)供應(yīng)商 地圖標(biāo)注測試 賺地圖標(biāo)注的錢犯法嗎 烏魯木齊人工電銷機器人系統(tǒng) 長沙ai機器人電銷 福州鐵通自動外呼系統(tǒng) 澳門防封電銷卡

golang常用庫:gorilla/mux-http路由庫使用
golang常用庫:配置文件解析庫-viper使用
golang常用庫:操作數(shù)據(jù)庫的orm框架-gorm基本使用

一:字段映射-模型定義

gorm中通常用struct來映射字段. gorm教程中叫模型定義

比如我們定義一個模型Model:

type User struct {
	gorm.Model
	UserId int64 `gorm:"index"` //設(shè)置一個普通的索引,沒有設(shè)置索引名,gorm會自動命名
	Birtheday time.Time
 Age  int  `gorm:"column:age"`//column:一個tag,可以設(shè)置列名稱
 Name string `gorm:"size:255;index:idx_name_add_id"`//size:設(shè)置長度大小,index:設(shè)置索引,這個就取了一個索引名
	Num  int  `gorm:"AUTO_INCREMENT"`
 Email string `gorm:"type:varchar(100);unique_index"`//type:定義字段類型和大小
	AddressID sql.NullInt64 `gorm:"index:idx_name_add_id"`
	IgnoreMe int  `gorm:"_"`
	Description string `gorm:"size:2019;comment:'用戶描述字段'"`//comment:字段注釋
	Status string `gorm:"type:enum('published', 'pending', 'deleted');default:'pending'"`
}

上面的gorm.Model 定義如下:

type Model struct {
 ID uint `gorm:"primary_key"`//primary_key:設(shè)置主鍵
 CreatedAt time.Time
 UpdatedAt time.Time
 DeletedAt *time.Time
}

當(dāng)然我們也可以不用gorm.Model,自己定義一個差不多的類型

如果你用ID,系統(tǒng)會自動設(shè)為表的主鍵,當(dāng)然我們可以自己定義主鍵:
比如:

// 使用`AnimalID`作為主鍵
type Animal struct {
 AnimalID int64 `gorm:"primary_key"`
 Name string
 Age int64
}

參考:https://gorm.io/zh_CN/docs/conventions.html

二:創(chuàng)建表

直接看下面的例子:createtable.go

package main

import (
	"database/sql"
	"fmt"
	"github.com/jinzhu/gorm"
	_ "github.com/jinzhu/gorm/dialects/mysql"
	"time"
)

type User struct {
	gorm.Model
	UserId int64 `gorm:"index"`
	Birtheday time.Time
	Age  int  `gorm:"column:age"`
	Name string `gorm:"size:255;index:idx_name_add_id"`
	Num  int  `gorm:"AUTO_INCREMENT"`
	Email string `gorm:"type:varchar(100);unique_index"`
	AddressID sql.NullInt64 `gorm:"index:idx_name_add_id"`
	IgnoreMe int  `gorm:"_"`
	Description string `gorm:"size:2019;comment:'用戶描述字段'"`
	Status string `gorm:"type:enum('published', 'pending', 'deleted');default:'pending'"`
}

//設(shè)置表名,默認(rèn)是結(jié)構(gòu)體的名的復(fù)數(shù)形式
func (User) TableName() string {
	return "VIP_USER"
}

func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=Trueloc=Local")
	if err != nil {
		fmt.Println("connect db err: ", err)
	}
	defer db.Close()

	if db.HasTable(User{}) { //判斷表是否存在
		db.AutoMigrate(User{}) //存在就自動適配表,也就說原先沒字段的就增加字段
	} else {
		db.CreateTable(User{}) //不存在就創(chuàng)建新表
	}
}

上面的gorm.Open()操作,如果想指定主機話,就需要加上括號 ()
例如:

user:password@(localhost)/dbname?charset=utf8parseTime=Trueloc=Local

上面的程序中,先新建了一個數(shù)據(jù)庫名叫gormdemo,然后運行:go run createtable.go , 成功運行后,數(shù)據(jù)庫就會出現(xiàn)一張名為 vip_user 的表。

三:增刪改查

新建一個gormdemo的數(shù)據(jù)庫,然后執(zhí)行下面的sql語句,就會建立一個animals的表,里面還有一些測試數(shù)據(jù)

CREATE TABLE `animals` (
 `id` bigint(20) NOT NULL AUTO_INCREMENT,
 `name` varchar(255) DEFAULT 'galeone',
 `age` int(10) unsigned DEFAULT '0',
 PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=8 DEFAULT CHARSET=utf8;

-- ----------------------------
-- Records of animals
-- ----------------------------
INSERT INTO `animals` VALUES ('1', 'demo-test', '20');
INSERT INTO `animals` VALUES ('2', 'galeone', '30');
INSERT INTO `animals` VALUES ('3', 'demotest', '30');
INSERT INTO `animals` VALUES ('4', 'jim', '90');
INSERT INTO `animals` VALUES ('5', 'jimmy', '10');
INSERT INTO `animals` VALUES ('6', 'jim', '23');
INSERT INTO `animals` VALUES ('7', 'test3', '27');

增加

例子:create.go

package main

import (
	"fmt"

	"github.com/jinzhu/gorm"
	_ "github.com/jinzhu/gorm/dialects/mysql"
)

type Animal struct {
	ID int64
	Name string
	Age int64
}

func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=trueloc=Local")
	if err != nil {
		fmt.Println("connect db error: ", err)
	}
	defer db.Close()

	animal := Animal{Name: "demo-test", Age: 20}
	db.Create(animal)
}

說明:上面的這個例子,自己在mysql中創(chuàng)建一個animals的數(shù)據(jù)表,字段為id,name,age

查找

select.go

package main

import (
	"fmt"

	"github.com/jinzhu/gorm"

	_ "github.com/jinzhu/gorm/dialects/mysql"
)

type Animal struct {
	ID int64
	Name string
	Age int64
}

//https://gorm.io/zh_CN/docs/query.html
func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=trueloc=Local")
	if err != nil {
		fmt.Println("connect db error: ", err)
	}
	defer db.Close()

	//根據(jù)逐漸查詢第一條記錄
	var animal Animal
	db.First(animal)
	fmt.Println(animal)

	//根據(jù)逐漸查詢最后一條記錄
	var animal2 Animal
	db.Last(animal2)
	fmt.Println(animal2)

	//指定某條記錄(僅當(dāng)主鍵為整型時可用)
	var animal3 Animal
	db.First(animal3, 2)
	fmt.Println(animal3)

	//where條件

	//符合條件的第一條記錄
	var animal4 Animal
	db.Where("name = ?", "demotest2").First(animal4)
	fmt.Println("where : ", animal4, animal4.ID, animal4.Name, animal4.Age)

	//符合條件的所有記錄
	var animals5 []Animal
	db.Where("name = ?", "galeone").Find(animals5)
	fmt.Println(animals5)
	for k, v := range animals5 {
		fmt.Println("k:", k, "ID:", v.ID, "Name:", v.Name, "Age:", v.Age)
	}

	//IN
	var animals6 []Animal
	db.Where("name IN (?)", []string{"demo-test", "demotest2"}).Find(animals6)
	fmt.Println(animals6)

	//LIKE
	var animals7 []Animal
	db.Where("name like ?", "%jim%").Find(animals7)
	fmt.Println(animals7)

	//AND
	var animals8 []Animal
	db.Where("name = ? AND age >= ?", "jim", "24").Find(animals8)
	fmt.Println(animals8)

	//總數(shù)
	var count int
	var animals9 []Animal
	db.Where("name = ?", "galeone").Or("name = ?", "jim").Find(animals9).Count(count)
	fmt.Println(animals9)
	fmt.Println(count)

	//Scan, 原生查詢
	var animals10 []Animal
	db.Raw("SELECT id, name, age From Animals WHERE name = ? AND age = ? ", "galeone", "30").Scan(animals10)
	fmt.Println("Scan: ", animals10)

	//原生查詢,select all
	var animals11 []Animal
	rows, _ := db.Raw("SELECT id,name FROM Animals").Rows()
	//注意:上面的 select id,name 后面不能寫成 * 代替,不然出來的結(jié)果都是默認(rèn)0值
	//像這樣結(jié)果: ALL: [{0 0} {0 0} {0 0} {0 0} {0 0} {0 0} {0 0}]
	//Scan 后面是什么字段,select 后面就緊跟什么字段
	for rows.Next() {
		var result Animal
		rows.Scan(result.ID, result.Name)
		animals11 = append(animals11, result)
	}
	fmt.Println("ALL: ", animals11)
	//output:ALL: [{1 demo-test 0} {2 galeone 0} {3 demotest2 0} {4 galeone 0} {5 galeone 0} {6 jim 0} {7 jimmy 0}]

	//select 查詢
	var animal12 Animal
	db.Select("name,age").Find(animal12) //只查詢name,age字段,相當(dāng)于select name,age from user
	fmt.Println("select: ", animal12)
	// db.Select([]string{"name", "age"}).Find(animal12)
	// fmt.Println("select2: ", animal12)
}

更新

update.go

package main

import (
	"fmt"

	"github.com/jinzhu/gorm"
	_ "github.com/jinzhu/gorm/dialects/mysql"
)

type Animal struct {
	ID int64
	Name string
	Age int64
}

func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=trueloc=Local")
	if err != nil {
		fmt.Println("connect db error: ", err)
	}
	defer db.Close()

	///根據(jù)一個條件更新
	//根據(jù)條件更新字段值,
	//后面加Debug(),運行時,可以打印出sql
	db.Debug().Model(Animal{}).Where("id = ? ", 4).Update("name", "jimupdate")
	//UPDATE `animals` SET `name` = 'jimupdate' WHERE (id = 4)

	//另外一種寫法: 根據(jù)條件更新
	var animal Animal
	animal = Animal{ID: 3}
	db.Debug().Model(animal).Update("name", "demotest2update")
	// db.Debug().Model(animal).Update("name", "demotest2update") // 這種寫法也可以
	//UPDATE `animals` SET `name` = 'demotest2update' WHERE `animals`.`id` = 3

	/// 多個條件更新
	db.Model(Animal{}).Where("id = ? AND age = ?", 4, 45).Update("name", "jimupdate3")
	//UPDATE `animals` SET `name` = 'jimupdate2' WHERE (id = 4 AND age = 45)

	/// 更新多個值
	db.Debug().Model(Animal{}).Where("id = ?", 4).Update(Animal{Name: "jim", Age: 90})
	// UPDATE `animals` SET `age` = 90, `name` = 'jim' WHERE (id = 4)

	animal2 := Animal{ID: 5}
	db.Debug().Model(animal2).Update(map[string]interface{}{"name": "jimm", "age": 100})
	//UPDATE `animals` SET `age` = 100, `name` = 'jimm' WHERE `animals`.`id` = 5
}

刪除

delete.go

package main

import (
	"fmt"

	"github.com/jinzhu/gorm"
	_ "github.com/jinzhu/gorm/dialects/mysql"
)

type Animal struct {
	ID int64
	Name string
	Age int64
}

func main() {
	db, err := gorm.Open("mysql", "root:root@/gormdemo?charset=utf8parseTime=trueloc=Local")
	if err != nil {
		fmt.Println("connect db error: ", err)
	}
	defer db.Close()

	db.Debug().Where("id = ?", 13).Delete(Animal{})
	// DELETE FROM `animals` WHERE (id = 13)

	db.Debug().Delete(Animal{}, "id = ? AND age = ?", 14, 10)
	//DELETE FROM `animals` WHERE (id = 14 AND age = 10)

}

四:Debug

在db后面直接加上 Debug(), 比如delete.go 里面的例子

五:參考

https://gorm.io/zh_CN/

到此這篇關(guān)于golang常用庫之操作數(shù)據(jù)庫的orm框架-gorm基本使用詳解的文章就介紹到這了,更多相關(guān)golang gorm使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • golang Gorm與數(shù)據(jù)庫完整性約束詳解
  • golang gorm 結(jié)構(gòu)體的表字段缺省值設(shè)置方式
  • golang gorm 計算字段和獲取sum()值的實現(xiàn)
  • golang gorm多條件篩選查詢操作
  • gorm golang 并發(fā)連接數(shù)據(jù)庫報錯的解決方法
  • golang gorm中格式化時間問題詳解
  • Golang 使用gorm添加數(shù)據(jù)庫排他鎖,for update

標(biāo)簽:西雙版納 調(diào)研邀請 廣西 慶陽 阿克蘇 德州 貴陽 太原

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang常用庫之操作數(shù)據(jù)庫的orm框架-gorm基本使用詳解》,本文關(guān)鍵詞  golang,常用,庫之,操作,數(shù)據(jù)庫,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《golang常用庫之操作數(shù)據(jù)庫的orm框架-gorm基本使用詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于golang常用庫之操作數(shù)據(jù)庫的orm框架-gorm基本使用詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    亚洲国产岛国毛片在线| 欧美激情一区二区三区| 亚洲桃花岛网站| 欧美牲交a欧美牲交aⅴ免费真| 肉丝袜脚交视频一区二区| 日本韩国欧美一区二区三区| 久久天天狠狠| 成人免费公开视频| 高清av免费一区中文字幕| 香蕉视频一区二区| 综合国产在线观看| 91精品又粗又猛又爽| 亚洲制服欧美中文字幕中文字幕| 日本黄xxxxxxxxx100| 四虎永久在线观看| 欧美丰满少妇xxxxx| 欧美爱爱免费视频| 亚洲高清不卡av| 人妻换人妻a片爽麻豆| 国产欧美一区二区三区网站| 999国产在线| 9i精品福利一区二区三区| 精品国内自产拍在线观看| 色综合色综合色综合色综合| 精品国产91久久久| 无码国产精品久久一区免费| 中文字幕在线观看一区| 国产日韩精品久久| 成人综合婷婷国产精品久久蜜臀 | 国产aⅴ一区二区三区| 亚洲一区二区三区毛片| 91亚洲国产成人精品一区二区三 | 国产精品第五页| 国产精品99久久久久久久| 免费看污视频的网站| 日韩精品亚洲视频| 免费看91的网站| 日韩欧美在线影院| 日韩亚洲欧美中文字幕| 亚洲成人a级网| 貂蝉被到爽流白浆在线观看| 亚洲人成网站999久久久综合| 2018天天弄| 精品国产一区二区三区忘忧草| 成人性生交大免费看| 亚洲精品网站在线观看| 日韩免费高清在线| 欧美日韩国内自拍| 国产a级一级片| 色婷婷精品久久二区二区蜜臀av| 国产精品视频黄色| 疯狂蹂躏欧美一区二区精品| 老牛影视av老牛影视av| 亚洲黄色有码视频| 欧美一区二区三区激情| 国产aⅴ精品一区二区三区黄| 国产成人精品网址| 国产精品一区二区小说| 91精品国产一区二区| 日本成人精品视频| 欧美大片在线免费观看| 人妻中文字幕一区| 国产精品视频1区| 精品国产九九九| 国产精品27p| 久久久99精品久久| 日韩a在线播放| 欧美黑人狂野猛交老妇| 制服.丝袜.亚洲.另类.中文| 99re成人在线| 国产又大又长又粗| 91在线第一页| 日韩国产激情在线| 少妇又紧又色又爽又刺激视频 | 成人欧美一区二区三区黑人孕妇 | 国内久久精品视频| 中文字幕网av| 欧美日韩在线免费| www.激情五月.com| 亚洲丰满在线| 色综合天天综合网国产成人综合天| 在线观看免费黄色网址| 456国产精品| 欧美激情一区在线| 五月天中文字幕在线| 亚洲韩国日本中文字幕| 日韩一区二区三区四区在线| 欧美一级片久久久久久久| 偷拍一区二区三区四区| 伊人久久久久久久久久久久| 久久精品国产美女| 亚洲一区二区三区中文字幕在线| 少妇高潮av久久久久久| 久久精品综合一区| 色综合天天天天做夜夜夜夜做| 国产极品在线播放| 国产精品免费一区豆花| 依依成人综合视频| 中国一级特黄毛片| 日本在线视频www色| 亚洲精品91美女久久久久久久| 六月丁香综合网| 成人国产精品av| 亚洲九九爱视频| 在线观看成人毛片| 日韩wuma| 亚洲国产日韩欧美在线图片| 国产一区福利在线| av小说在线观看| 日本视频久久久| 樱花影视一区二区| 刘亦菲国产毛片bd| 宅男一区二区三区| 亚洲国产免费av| 蜜桃久久精品一区二区| 日韩不卡的av| 国产在线精品日韩| 亚洲偷熟乱区亚洲香蕉av| av女名字大全列表| 欧美成人短视频| 国产尤物91| 日韩精品中文字幕在线不卡尤物| 极品少妇xxxx精品少妇| 男人的天堂日韩| 国产成人女人毛片视频在线| 欧美日韩一区二区三区四区| 视频一区二区国产| av男人的天堂av| 亚洲一区二区三区涩| 91精品国产综合久久福利| 波多野结衣在线一区| 激情四射综合网| 无码人妻丰满熟妇区96| 97超级碰在线看视频免费在线看| 性久久久久久久久久久久| 蜜桃视频久久一区免费观看入口| 99久久精品免费视频| 国内少妇毛片视频| 国产精品久久久久久久久久久新郎 | 欧美精品aⅴ在线视频| 三级久久三级久久| 日韩精品在线观看免费| 日本一区二区三区在线免费观看| 久久亚裔精品欧美| 精品国产欧美一区二区五十路| 久久只精品国产| 国产强伦人妻毛片| 午夜激情视频在线播放| 免费 成 人 黄 色| 国产区二精品视| 在线看国产精品| 欧美性videosxxxxx| 国产成人午夜视频| 蜜桃视频第一区免费观看| 污污的视频在线免费观看| 免费国产黄色网址| 宅男在线精品国产免费观看| 91在线播放视频| 久久黄色av网站| 欧美午夜精品伦理| 黑人精品欧美一区二区蜜桃| 色网站免费观看| 爱爱视频免费在线观看| 日本午夜激情视频| 水蜜桃在线免费观看| 精品在线视频一区二区| 欧美成人一区二区三区电影| 日韩精品中文字幕在线| 91精品麻豆日日躁夜夜躁| 午夜天堂影视香蕉久久| 国产日产亚洲精品系列| 另类欧美日韩国产在线| 五十路在线视频| 国产黄色免费视频| av资源免费看| 曰批又黄又爽免费视频| av中文在线播放| 久久久精品国产sm调教网站| 日本在线观看网址| 可以免费看av的网址| 黄色在线免费播放| 一卡二卡三卡四卡五卡| 亚洲成人网上| 精品乱子伦一区二区三区| 国产在线精品播放| 欧美巨猛xxxx猛交黑人97人| 中文字幕亚洲专区| 在线精品视频视频中文字幕| 亚洲国产一区二区三区在线观看| 亚洲国产成人porn| 国产精品久久久久久久久久免费看| 亚洲欧美中文字幕| 成人av网站在线| 欧美成人官网二区| 亚洲精品一区二区三区樱花| 国产性猛交xx乱| 2021久久国产精品不只是精品 | 2020国产精品视频| 99亚洲精品视频| 国产精品成人免费一区二区视频| 成人午夜在线视频| 欧美系列日韩一区| 国产在线一区二区三区欧美| 18国产免费视频| 亚洲娇小xxxx欧美娇小| 黄色网络在线观看| 欧美成人一区二区在线观看| 天天躁日日躁狠狠躁伊人| 久久国产视频网| 欧美做受高潮电影o| 成人乱码一区二区三区av| 97精品国产露脸对白| 欧美在线精品免播放器视频| 51调教丨国产调教视频| 丰满人妻一区二区三区四区53| 欧美丝袜美女中出在线| 欧美精品在线一区| 看黄色一级大片| 91香蕉视频污| 亚洲第一二三四五区| 亚洲欧美精品在线观看| 91蜜桃在线观看| 婷婷精品国产一区二区三区日韩 | 久久成人免费网| 亚洲成人综合视频| 91精品国产高清久久久久久91裸体 | 亚洲视频在线观看网站| 日本欧美www| 欧美老少配视频| 一区二区三区在线免费观看视频| 亚洲美女久久久| 日本精品一区二区三区四区| 亚洲精品一区二区三区区别| 午夜精品三级视频福利| 91视频在线免费| 亚洲乱码国产乱码精品精可以看 | 极品校花啪啪激情久久| 亚洲综合精品国产一区二区三区 | 久一区二区三区| 色综合一区二区| 欧美日韩在线免费播放| 黄色片一区二区三区| 色婷婷久久久亚洲一区二区三区 | 高清av免费一区中文字幕| 美女性感视频久久| 亚洲色图五月天| 男人天堂2024| 国产欧美精品日韩| 精品一区二区三区免费毛片爱| 国产91对白在线播放| 在线中文字日产幕| 亚洲美女屁股眼交3| 天天干天天色天天爽| 日本麻豆一区二区三区视频| 日韩免费看网站| av免费看网址| 成人美女视频在线看| 日本午夜精品一区二区| 2020日本不卡一区二区视频| 日本久久久久久久| 四虎成人永久免费视频| 精品一区二区三区四区| 免费国产羞羞网站美图| 免费美女久久99| 国产日韩欧美综合精品 | 成人免费毛片东京热| 日韩av毛片网| 99久久精品国产毛片| 91亚洲精品久久久蜜桃借种| 亚洲欧美第一页| 国产高清免费在线观看| 国精产品一区一区三区有限在线| a级黄色免费视频| 亚洲成人网在线| 亚洲熟女一区二区| 欧美日韩精品欧美日韩精品一综合| 污视频在线观看免费网站| 精品久久久在线观看| 欧美h视频在线观看| 欧美一区二区黄片| 91在线免费看片| 中文字幕一区二区在线播放| 北条麻妃在线一区| 成人免费观看av| 妞干网这里只有精品| 亚洲精品成人精品456| 国产欧美日韩小视频| 久久精品人人| 国产欧美精品aaaaaa片| 亚洲一区二区三区视频在线| 成年女人免费视频| 日韩免费观看视频| 一区二区三区在线视频免费| 三级av在线免费观看| 91在线观看免费网站| 日本一区二区三区免费乱视频 | 青娱乐国产在线视频| 欧美videos中文字幕| 亚洲一区二区三区精品视频| 成人午夜碰碰视频| 日韩在线一区视频| 日韩三级在线观看| 伊人网在线视频观看| 欧美特级www| 国产精品欧美激情在线观看| 亚洲国产精品激情在线观看| 日日噜噜夜夜狠狠久久丁香五月| 99在线精品视频| 免费看日本毛片| 欧美视频精品在线观看| 日韩黄色三级视频| 国模精品视频一区二区三区| 国产福利视频导航| 精品国产一区二区三| 亚洲欧美日韩中文播放| 自拍视频第一页| 国产精品自产拍在线观看| 欧美亚洲综合久久| 天堂在线观看视频| www.超碰97.com| 国产成一区二区| 久久久不卡影院| 91超薄肉色丝袜交足高跟凉鞋| 国模极品一区二区三区| 香蕉av在线播放| 中文字幕人成一区| 性做久久久久久久免费看| 午夜视频在线观| 日韩精品在线免费播放| www.黄色av| 亚洲综合第一页| 粉嫩欧美一区二区三区高清影视| 免费cad大片在线观看| 午夜精品爽啪视频| 善良的小姨在线| 亚洲一区av在线播放| 国产原创一区二区三区| 一起草最新网址| 欧美激情精品久久久久久久变态 | 超碰精品一区二区三区乱码| 裸体在线国模精品偷拍| 国产视频手机在线播放| 992tv在线成人免费观看| 人妻无码中文字幕免费视频蜜桃| 亚洲v国产v在线观看| 亚洲男人都懂的| 国内精品卡一卡二卡三| 午夜精品视频网站| 91影院在线观看| 亚洲精品视频网址| 69久久夜色精品国产69乱青草| 五月婷婷六月丁香综合| 亚洲最大免费| 欧美午夜在线观看| 亚洲第一在线播放| 99视频网站| 午夜在线电影亚洲一区| 日韩av大片在线观看| 国产日韩第一页| 俺去了亚洲欧美日韩| 水蜜桃久久夜色精品一区的特点 | 91免费国产精品| 国产精品成人久久久久| 欧美久久久久久蜜桃| 91视频免费看| 国内精品第一页| 国产免费一区二区三区四区五区| 污污视频在线免费| 免费观看国产成人| 欧美大片顶级少妇| 久久成人免费网| 九九九在线视频| 日韩精品欧美在线| 亚洲午夜精品久久久久久性色 | www.久久com| 国产精品一区二区三区四区五区 | 久久久噜噜噜久久中文字免| 91视频www| 18岁成人毛片| 97干在线视频| 国产成人精品久久二区二区91| 欧美伊人久久久久久久久影院| 中文字幕手机在线视频| 一级黄色特级片| 亚洲伊人久久综合| 久久人人爽人人爽人人片亚洲| 亚洲精品一线二线三线无人区| 午夜av电影一区| 国产精品系列在线| 久久五月婷婷丁香社区| 不卡在线视频中文字幕| 久久蜜桃资源一区二区老牛| 久久久久精彩视频| 国产成人愉拍精品久久| 少妇一晚三次一区二区三区| 91精品国产99| 欧美亚洲一区二区在线| 99久久综合精品| 中文人妻av久久人妻18| 午夜一级免费视频| 精品国产一区二区三| 欧美精品video| 亚洲色图校园春色| 久久综合久久综合九色| 日本五十熟hd丰满| 少妇性l交大片| www日韩av| 一区二区欧美亚洲| 亚洲国产激情av| 午夜视频在线免费播放|