成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

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

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

熱門標簽:智能電銷機器人營銷 濮陽自動外呼系統(tǒng)代理 廣東語音外呼系統(tǒng)供應商 地圖標注測試 賺地圖標注的錢犯法嗎 烏魯木齊人工電銷機器人系統(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
}

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

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

// 使用`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è)置表名,默認是結(jié)構(gòu)體的名的復數(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)

	//指定某條記錄(僅當主鍵為整型時可用)
	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é)果都是默認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字段,相當于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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標題《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)民參考!
  • 推薦文章
    亚洲一区精品视频在线观看| 精品国产二区在线| 九九99久久| ww久久中文字幕| 国产porny蝌蚪视频| www亚洲国产| 911精品国产一区二区在线| 色姑娘综合天天| 欧美视频第一| 麻豆91小视频| 日本一区二区三区免费看| 亚洲自拍偷拍色片视频| 激情综合色综合啪啪开心| 韩国精品一区二区| 久久99国产精品视频| 中文字幕在线观看你懂的| jizzjizz日本护士视频| 亚洲天堂网在线观看视频| 91午夜精品亚洲一区二区三区| 久久中文字幕在线观看| www在线免费观看| 182在线观看视频| 亚洲中文字幕一区| 亚洲精品一区二区三区在线播放| 高清国语自产拍免费视频国产| 久久国产精品无码一级毛片| 日韩欧美精品电影| 国产美女高潮久久白浆| 91精品电影| 精品国产一区二区三区久久久狼| 成人在线免费公开观看视频| 在线观看日韩一区二区| 国产日韩精品入口| 成人av片在线观看| y111111国产精品久久婷婷| 捆绑裸体绳奴bdsm亚洲| 亚洲男人天堂影院| 国产又黄又粗又猛又爽的| 182在线观看视频| 韩国一区二区电影| 免费av一区二区三区四区| 午夜激情在线观看| 中文字幕日韩av电影| 久久久美女视频| 日韩欧美一区二区不卡| 看黄的a网站| 国内久久视频| 极品一区美女高清| 大美女一区二区三区| 欧美国产精品中文字幕| 三上悠亚一区二区三区| 污污网站免费看| 成人性生交大片免费观看嘿嘿视频| 色婷婷综合网站| 亚洲天堂一区在线| 亚洲国产另类久久精品| 香蕉久久夜色精品| 美女视频一区二区三区| 成人午夜伦理影院| 老司机免费视频一区二区| 免费高清在线视频一区·| 国产精品久免费的黄网站| 性xx十八spa按摩| 欧美成人影院在线播放| 免费观看亚洲天堂| 天堂网在线观看国产精品| 免费污片软件| 午夜在线网站| 麻豆网站在线免费观看| 国产精品二区不卡| 你懂的在线看| 久久久久久九九九| 美女福利一区二区三区| 国产欧美一区二区三区另类精品| 99麻豆久久久国产精品免费优播| 欧洲伦理片一区 二区 三区| 一本大道伊人av久久综合| 国产精品黄页网站在线播放免费| 亚洲天堂男人网| 捆绑裸体绳奴bdsm亚洲| 中文字幕国产传媒| 影音先锋导航| 91成人高清| 欧洲日本亚洲国产区| 丰满女人性猛交| 精品在线播放| 欧美性生活一级片| 欧美精品人人做人人爱视频| 91精品久久| 欧美xxxxhdvideosex| 黄色激情小视频| 91亚洲精品久久久蜜桃借种| 成人av毛片在线观看| 国产成人精品一区二区在线小狼| 国产无套内射久久久国产| 97在线日本国产| 91久久久久久久一区二区| 小泽玛利亚视频在线观看| 日韩欧美视频在线免费观看| 国产精品视频一区二区三区综合| 国产精品视频一区二区三区不卡| 国产又黄又猛又粗又爽的视频| 韩漫成人漫画| 国产在线久久久| 91av资源在线| 国产麻豆成人精品| 亚洲国产欧美日韩精品| 久草热8精品视频在线观看| 蜜桃传媒视频第一区入口在线看| 99精品在免费线偷拍| 66精品视频在线观看| 视频一区日韩| 曰本一区二区三区视频| 青青伊人久久| 亚洲国产精品尤物yw在线观看| 国产欧美日韩网站| 色综合久久av| 成人性a激情免费视频| 色欲AV无码精品一区二区久久| 国产黄色小视频在线| 亚洲日本电影在线| 日韩风俗一区 二区| 播放灌醉水嫩大学生国内精品| 欧美黑人xxxx猛牲大交| 99久久一区三区四区免费| 一区二区精品在线观看| 国产毛片精品国产一区二区三区| 亚洲国产成人一区二区三区| 欧美午夜精品伦理| 欧美性生活大片视频| 亚洲一二三四在线| 黄色软件在线| 一级片一级片一级片| 在线综合亚洲| 啊啊啊射了视频网站| 久久久国产影院| 天天天天天天天干| 欧美一级淫片aaaaaaa视频| 国产美女视频一区二区| 麻豆国产在线视频| 欧美著名女优| 亚洲成av人片在线观看无| 日韩经典在线视频| 性欧美xxx极品另类| 成人黄网大全在线观看| 最近最新mv在线观看免费高清| 国产少妇在线观看| 97超碰人人模人人人爽人人爱| 五月开心六月丁香综合色啪| 黑人巨大精品欧美一区二区免费| 国产精品色哟哟| 日韩一区欧美一区| 少妇荡乳情欲办公室456视频| 99亚洲精品视频| 国产精品一区二区男女羞羞无遮挡| 亚洲午夜av在线| av一区二区三区在线| 欧美一区 二区| 久久亚洲av午夜福利精品一区| 二区在线观看| 亚洲色大成网站www久久九九| 九九这里只精品视在线99| 19j韩国主播韩宝贝在线| 国产日韩亚洲欧美综合| 97视频在线观看免费高清完整版在线观看| 国产精品三区在线观看| 精品一区二区三区毛片| 成人免费观看cn| 国产精品igao激情视频| 亚洲专区在线视频| 日本欧美电影在线观看| 国产蜜臀97一区二区三区| 欧美风情在线视频| 懂色aⅴ精品一区二区三区蜜月| 色视频www在线播放国产人成| 美女视频黄免费的久久| 日本一区高清在线视频| 日本a√在线观看| 在线播放成人| 师生出轨h灌满了1v1| 婷婷视频在线播放| av免费在线观看网址| 欧美日韩亚洲91| 福利在线一区二区三区| 日韩五码电影| 国产精品福利网站| 奇米精品一区二区三区四区| 一区二区国产日产| 成年网站在线视频网站| 亚洲一区二区三区不卡国产欧美| 91精品国产综合久久久久久丝袜| 中文字幕欧美视频| 97久久精品人人澡人人爽缅北| 中文官网资源新版中文第二页在线观看| 国产aⅴ激情无码久久久无码| 欧美在线亚洲综合一区| 日本成人在线视频网站| 国产精品素人一区二区| 日韩影片在线播放| 日韩福利一区二区| 一本一道久久a久久精品| 日韩一二三在线视频播| 香港三级日本三级a视频| 国产一级视频| 91麻豆国产福利在线观看宅福利| 成人福利一区二区| 亚洲AV无码成人精品区东京热| 秋霞av鲁丝片一区二区| 亚洲一区二区三区在线视频| 国产亚洲精品v| 91丨九色丨黑人外教| 先锋av资源站| 亚洲精品综合久久| 亚洲色图另类小说| 欧美一区二区三区白人| 亚洲欧洲日韩| 成人黄色在线网站| 天堂资源在线视频| 亚洲成在线观看| xfplay每日更新av资源在线| 国产乱码精品一区二三赶尸艳谈| 69日小视频在线观看| 国产亚洲一卡2卡3卡4卡新区| 欧美男同性恋视频网站| 日韩视频在线免费播放| 日韩一区和二区| 福利在线白白| 91亚洲精品一区| 日韩大片免费观看视频播放| 日本精品久久电影| 天天躁日日躁狠狠躁欧美巨大小说| 欧美tk—视频vk| 久久久久久久久久久久久夜| 国产黄色高清视频| 成人一级黄色大片| 少妇精69xxtheporn| 狠狠操狠狠色| av动漫免费观看| 男人猛进猛出女人屁股视频| 国产免费一区二区三区在线能观看| 国产一区二区三区四区五区六区| 国精一区二区| 精品国产乱码久久久久久久软件| 日韩高清三级| 国产精品久久婷婷| 国产又粗又猛又黄又爽| 欧美日韩精品一区二区视频| 综合136福利视频在线| 97久久精品人人做人人爽50路| 国产香蕉视频在线看| 亚洲欧洲国产日本综合| 91探花福利精品国产自产在线| 色综合久久久久无码专区| 欧美日韩国产一区中文午夜| 手机在线成人av| 日本一区二区三区在线视频| 亚洲一区二区色| 日日夜夜一区| 久久精品免视着国产成人| 日本在线观看视频一区| 99在线精品一区二区三区| 菠萝菠萝蜜在线观看| 欧美一级特黄aaaaaa大片在线观看| 久久精品一区二区三区资源网| 在线看国产日韩| 日韩av一区二区三区美女毛片| 99久久99久久精品免费观看| 欧美午夜久久久| 国产传媒免费在线观看| 97影院手机在线观看| 91成人精品视频| 日本亚洲欧美美色| 97人妻天天摸天天爽天天| 色婷婷综合成人av| 久久一区国产| 久草视频中文在线| 国产精品久久久久久av福利| www.男人天堂网| 一区二区成人网| 小泽玛利亚av在线| 国产一区二中文字幕在线看| 久久精品青青大伊人av| 国产大片一区| 韩国一区二区三区| 极品裸体白嫩激情啪啪国产精品| 久久免费黄色网址| 在线综合+亚洲+欧美中文字幕| 色94色欧美sute亚洲线路一久| 国产一区啦啦啦在线观看| 中文字幕不卡三区视频| 给个网站可以在线观看你懂的| 久久精品九色| 亚洲一区二区福利| 天天操天天干天天玩| 国产欧美精品一区二区三区四区| 日本一区二区三区视频免费看| 亚洲精品日产| 丁香花高清视频完整版在线观看| 中文字幕av一区二区三区谷原希美| 国产精品一区二区三区网站| 日本成人网址| 精品成人无码久久久久久| xvideos亚洲人网站| 成人免费网址| 热99re久久精品这里都是免费| 中文字幕在线中文字幕二区| 女人另类性混交zo| 成年人免费网站| 成品网站w灬+源码1688网页| 亚洲一区二区三区精品在线观看| 欧美一区二区三区不卡视频| 亚洲在线播放电影| 国产天堂素人系列在线视频| 中文字幕乱码在线观看| www红色一片_亚洲成a人片在线观看_| 日本亚洲欧美成人| 亚洲综合激情视频| 久久国产夜色精品鲁鲁99| 亚洲影视在线| 欧美xxx网站| 国产综合视频| 日韩国产欧美视频| 亚洲高清成人影院| www.男人的天堂| 欧美色另类天堂2015| 亚洲成人短视频| 欧美一区二区三区在线观看免费| 国产天堂素人系列在线视频|