国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

Go使用database/sql操作數(shù)據(jù)庫的教程指南

 更新時間:2023年06月12日 09:18:56   作者:江湖十年  
Go?語言中,有一個名為database/sql的標準庫,提供了統(tǒng)一的編程接口,使開發(fā)人員能夠以一種通用的方式與各種關(guān)系型數(shù)據(jù)庫進行交互,本文就來和大家講講它的具體操作吧

在現(xiàn)代軟件開發(fā)中,數(shù)據(jù)庫扮演著至關(guān)重要的角色,用于存儲和管理應(yīng)用程序的數(shù)據(jù)。針對不同的數(shù)據(jù)庫系統(tǒng),開發(fā)人員通常需要使用特定的數(shù)據(jù)庫驅(qū)動來操作數(shù)據(jù)庫,這往往需要開發(fā)人員掌握不同的驅(qū)動編程接口。在 Go 語言中,好在有一個名為 database/sql 的標準庫,提供了統(tǒng)一的編程接口,使開發(fā)人員能夠以一種通用的方式與各種關(guān)系型數(shù)據(jù)庫進行交互。

概念

database/sql 包通過提供統(tǒng)一的編程接口,實現(xiàn)了對不同數(shù)據(jù)庫驅(qū)動的抽象。

它的大致原理如下:

  • Driver 接口定義:database/sql/driver 包中定義了一個 Driver 接口,該接口用于表示一個數(shù)據(jù)庫驅(qū)動。驅(qū)動開發(fā)者需要實現(xiàn)該接口來提供與特定數(shù)據(jù)庫的交互能力。
  • Driver 注冊:驅(qū)動開發(fā)者需要在程序初始化階段,通過調(diào)用 database/sql 包提供的 sql.Register() 方法將自己的驅(qū)動注冊到 database/sql 中。這樣,database/sql 就能夠識別和使用該驅(qū)動。
  • 數(shù)據(jù)庫連接池管理:database/sql 維護了一個數(shù)據(jù)庫連接池,用于管理數(shù)據(jù)庫連接。當通過 sql.Open() 打開一個數(shù)據(jù)庫連接時,database/sql 會在合適的時機調(diào)用注冊的驅(qū)動來創(chuàng)建一個具體的連接,并將其添加到連接池中。連接池會負責(zé)連接的復(fù)用、管理和維護工作,并且這是并發(fā)安全的。
  • 統(tǒng)一的編程接口:database/sql 定義了一組統(tǒng)一的編程接口供用戶使用,如 Prepare()、Exec()Query() 等方法,用于準備 SQL 語句、執(zhí)行 SQL 語句和執(zhí)行查詢等操作。這些方法會接收參數(shù)并調(diào)用底層驅(qū)動的相應(yīng)方法來執(zhí)行實際的數(shù)據(jù)庫操作。
  • 接口方法的實現(xiàn):驅(qū)動開發(fā)者需要實現(xiàn) database/sql/driver 中定義的一些接口方法,以此來支持上層 database/sql 包提供的 Prepare()、Exec()Query() 等方法,以提供底層數(shù)據(jù)庫的具體實現(xiàn)。當 database/sql 調(diào)用這些方法時,實際上會調(diào)用注冊的驅(qū)動的相應(yīng)方法來執(zhí)行具體的數(shù)據(jù)庫操作。

通過以上的機制,database/sql 包能夠?qū)崿F(xiàn)對不同數(shù)據(jù)庫驅(qū)動的統(tǒng)一封裝和調(diào)用。用戶可以使用相同的編程接口來進行數(shù)據(jù)庫操作,無需關(guān)心底層驅(qū)動的具體細節(jié)。這種設(shè)計使得代碼更具可移植性和靈活性,方便切換和適配不同的數(shù)據(jù)庫。

特點

database/sql 具有如下特點:

  • 統(tǒng)一的編程接口:database/sql 庫提供了一組統(tǒng)一的接口,使得開發(fā)人員可以使用相同的方式操作不同的數(shù)據(jù)庫,而不需要學(xué)習(xí)特定數(shù)據(jù)庫的 API。
  • 驅(qū)動支持:通過導(dǎo)入第三方數(shù)據(jù)庫驅(qū)動程序,database/sql 可以與多種常見的關(guān)系型數(shù)據(jù)庫系統(tǒng)進行交互,如 MySQL、PostgreSQL、SQLite 等。
  • 預(yù)防 SQL 注入:database/sql 庫通過使用預(yù)編譯語句和參數(shù)化查詢等技術(shù),有效預(yù)防了 SQL 注入攻擊。
  • 支持事務(wù):事務(wù)是一個優(yōu)秀的 SQL 包必備功能。

準備

為了演示 database/sql 用法,我準備了如下 MySQL 數(shù)據(jù)庫表:

DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(50) DEFAULT NULL COMMENT '用戶名',
  `email` varchar(255) NOT NULL DEFAULT '' COMMENT '郵箱',
  `age` tinyint(4) NOT NULL DEFAULT '0' COMMENT '年齡',
  `birthday` datetime DEFAULT NULL COMMENT '生日',
  `salary` varchar(128) DEFAULT NULL COMMENT '薪水',
  `created_at` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP,
  `updated_at` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  PRIMARY KEY (`id`),
  UNIQUE KEY `u_email` (`email`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用戶表';

你可以使用 MySQL 命令行或圖形化工具創(chuàng)建這張表。

連接數(shù)據(jù)庫

要使用 database/sql 操作數(shù)據(jù)庫,首先要建立與數(shù)據(jù)庫的連接:

package main
import (
	"database/sql"
	"log"
	_ "github.com/go-sql-driver/mysql"
)
func main() {
	db, err := sql.Open("mysql",
		"user:password@tcp(127.0.0.1:3306)/demo?charset=utf8mb4&parseTime=true&loc=Local")
	if err != nil {
		log.Fatal(err)
	}
	defer db.Close()
}

因為我們要連接 MySQL 數(shù)據(jù)庫,所以需要導(dǎo)入 MySQL 數(shù)據(jù)庫驅(qū)動 github.com/go-sql-driver/mysql。database/sql 由 Go 語言官方團隊設(shè)計,而數(shù)據(jù)庫驅(qū)動程序則由社區(qū)維護,其他關(guān)系型數(shù)據(jù)庫驅(qū)動列表可在這里查看。

與數(shù)據(jù)庫建立連接的代碼非常簡單,只需調(diào)用 sql.Open() 函數(shù)即可。它接收兩個參數(shù),驅(qū)動名稱和 DSN。

這里驅(qū)動名稱為 mysql,database/sql 之所以能夠識別這個驅(qū)動名稱,是因為在匿名導(dǎo)入 github.com/go-sql-driver/mysql 時,這個庫內(nèi)部調(diào)用了 sql.Register 將其注冊給了 database/sql

func init() {
	sql.Register("mysql", &MySQLDriver{})
}

在 Go 語言中,一個包的 init 方法會在導(dǎo)入時會被自動調(diào)用,這里完成了驅(qū)動程序的注冊。這樣在調(diào)用 sql.Open() 時才能找到 mysql 驅(qū)動。

第二個參數(shù) DSN 全稱 Data Source Name,數(shù)據(jù)庫的源名稱,其格式如下:

username:password@protocol(address)/dbname?param=value

下面是我們提供的 DSN 各部分解釋:

  • user:password:數(shù)據(jù)庫的用戶名和密碼。根據(jù)實際情況,你需要使用你自己的用戶名和密碼。
  • tcp(127.0.0.1:3306):連接數(shù)據(jù)庫服務(wù)器的協(xié)議、數(shù)據(jù)庫服務(wù)器的地址和端口號。在這個例子中,使用的是本地主機 127.0.0.1 和 MySQL 默認端口號 3306。你可以根據(jù)實際情況修改為你自己的數(shù)據(jù)庫服務(wù)器地址和端口號。
  • /demo:數(shù)據(jù)庫的名稱。在這個例子中,數(shù)據(jù)庫名稱是 demo。你可以根據(jù)實際情況修改為你自己的數(shù)據(jù)庫名稱。
  • charset=utf8mb4:指定數(shù)據(jù)庫的字符集為 UTF-8。這里使用的是 UTF-8 的變體 UTF-8mb4,支持更廣泛的字符范圍。
  • parseTime=true:啟用時間解析。這個參數(shù)使得數(shù)據(jù)庫驅(qū)動程序能夠?qū)?shù)據(jù)庫中的時間類型字段(datetime)解析為 Go 語言的 time.Time 類型。
  • loc=Local:設(shè)置時區(qū)為本地時區(qū)。這個參數(shù)指定數(shù)據(jù)庫驅(qū)動程序使用本地的時區(qū)。

sql.Open() 調(diào)用后將返回一個 *sql.DB 類型,可以用來操作數(shù)據(jù)庫。

另外,我們調(diào)用 defer db.Close() 來釋放數(shù)據(jù)庫連接。其實這一步操作也可以不做,database/sql 底層連接池會幫我們處理。一旦關(guān)閉了連接,就不可以再繼續(xù)使用這個 db 對象了。

*sql.DB 的設(shè)計是用來作為長連接使用的,所以不需要頻繁的進行 OpenClose 操作。如果我們需要連接多個數(shù)據(jù)庫,則可以為每個不同的數(shù)據(jù)庫創(chuàng)建一個 *sql.DB 對象,保持這些對象為 Open 狀態(tài),不必頻繁使用 Close 來切換連接。

值得注意的是,其實 sql.Open() 并沒有真正建立數(shù)據(jù)庫連接,它只是準備好了一切,以備后續(xù)使用,連接將在第一次被使用時延遲建立。

這樣的設(shè)計雖然合理,可也有些違反直覺,sql.Open() 甚至不會校驗 DSN 參數(shù)的合法性。不過我們可以使用 db.Ping() 方法來主動檢查連接是否能被正確建立。

if err := db.Ping(); err != nil {
    log.Fatal(err)
}

使用 sql.Open() 并不會建立一個唯一的數(shù)據(jù)庫連接,事實上,database/sql 會維護一個連接池。

我們可以通過如下方法,控制連接池的一些參數(shù):

db.SetMaxOpenConns(25)                 // 設(shè)置最大的并發(fā)連接數(shù)(in-use + idle)
db.SetMaxIdleConns(25)                 // 設(shè)置最大的空閑連接數(shù)(idle)
db.SetConnMaxLifetime(5 * time.Minute) // 設(shè)置連接的最大生命周期

這些參數(shù)設(shè)置可以根據(jù)經(jīng)驗來修改,以上參數(shù)能夠滿足一些中小項目的使用,如果是大型項目,則可以適當調(diào)高參數(shù)。

聲明模型

連接建立好后,理論上我們就可以操作數(shù)據(jù)庫進行 CRUD 了。不過為了寫出的代碼更具可維護性,我們往往需要定義模型來映射數(shù)據(jù)庫表。

user 表映射后的模型如下:

type User struct {
	ID        int
	Name      sql.NullString
	Email     string
	Age       int
	Birthday  *time.Time
	Salary    Salary
	CreatedAt time.Time
	UpdatedAt string
}

模型在 Go 中使用 struct 表示,結(jié)構(gòu)體字段同數(shù)據(jù)庫表中的字段一一對應(yīng)。

其中 Salary 類型定義如下:

type Salary struct {
    Month int `json:"month"`
    Year  int `json:"year"`
}

關(guān)于 Name、Salary 兩個字段的特殊性,我將分別在 處理 NULL 和 自定義字段類型 部分講解。

創(chuàng)建

*sql.DB 提供了 Exec 方法來執(zhí)行一條 SQL 命令,可以用來創(chuàng)建、更新、刪除表數(shù)據(jù)等。

這里使用 Exec 方法來實現(xiàn)創(chuàng)建一個用戶:

func CreateUser(db *sql.DB) (int64, error) {
    birthday := time.Date(2000, 1, 1, 0, 0, 0, 0, time.Local)
    user := User{
        Name:     sql.NullString{String: "jianghushinian007", Valid: true},
        Email:    "jianghushinian007@outlook.com",
        Age:      10,
        Birthday: &birthday,
        Salary: Salary{
            Month: 100000,
            Year:  10000000,
        },
    }
    res, err := db.Exec(`INSERT INTO user(name, email, age, birthday, salary) VALUES(?, ?, ?, ?, ?)`,
        user.Name, user.Email, user.Age, user.Birthday, user.Salary)
    if err != nil {
        return 0, err
    }
    return res.LastInsertId()
}

首先我們實例化了一個 User 對象 user,并對相應(yīng)字段進行賦值。

接著使用 db.Exec 方法來執(zhí)行 SQL 語句:

INSERT INTO user(name, email, age, birthday, salary) VALUES(?, ?, ?, ?, ?)

其中 ? 作為參數(shù)占位符,不同數(shù)據(jù)庫驅(qū)動程序的占位符可能不同,可以參考數(shù)據(jù)庫驅(qū)動的文檔。

我們將這 5 個參數(shù)順序傳遞給 db.Exec 方法,即可完成用戶的創(chuàng)建。

db.Exec 方法調(diào)用后將返回 sql.Result 保存結(jié)果以及一個 error 來標記錯誤。

sql.Result 是一個接口,它包含兩個方法:

  • LastInsertId() (int64, error):返回新插入的用戶 ID。
  • RowsAffected() (int64, error):返回當前操作受影響的行數(shù)。

接口具體實現(xiàn)有數(shù)據(jù)庫驅(qū)動程序來完成。

調(diào)用 CreateUser 函數(shù)即可創(chuàng)建一個新的用戶:

if id, err := CreateUser(db); err != nil {
    log.Fatal(err)
} else {
    log.Println("id:", id)
}

此外,database/sql 還提供了預(yù)處理方法 *sql.DB.Prepare 創(chuàng)建一個準備好的 SQL 語句,在循環(huán)中使用預(yù)處理,則可以減少與數(shù)據(jù)庫的交互次數(shù)。

比如我們需要創(chuàng)建兩個用戶,則可以先使用 db.Prepare 創(chuàng)建一個 *sql.Stmt 對象,然后多次調(diào)用 *sql.Stmt.Exec 方法來插入數(shù)據(jù):

func CreateUsers(db *sql.DB) ([]int64, error) {
	stmt, err := db.Prepare("INSERT INTO user(name, email, age, birthday, salary) VALUES(?, ?, ?, ?, ?)")
	if err != nil {
		panic(err)
	}
	// 注意:預(yù)處理對象是需要關(guān)閉的
	defer stmt.Close()
	birthday := time.Date(2000, 2, 2, 0, 0, 0, 0, time.Local)
	users := []User{
		{
			Name:     sql.NullString{String: "", Valid: true},
			Email:    "jianghushinian007@gmail.com",
			Age:      20,
			Birthday: &birthday,
			Salary: Salary{
				Month: 200000,
				Year:  20000000,
			},
		},
		{
			Name:  sql.NullString{String: "", Valid: false},
			Email: "jianghushinian007@163.com",
			Age:   30,
		},
	}
	var ids []int64
	for _, user := range users {
		res, err := stmt.Exec(user.Name, user.Email, user.Age, user.Birthday, user.Salary)
		if err != nil {
			return nil, err
		}
		id, err := res.LastInsertId()
		if err != nil {
			return nil, err
		}
		ids = append(ids, id)
	}
	return ids, nil
}

db.Prepare 是預(yù)先將一個數(shù)據(jù)庫連接和一個條 SQL 語句綁定并返回 *sql.Stmt 結(jié)構(gòu)體,它代表了這個綁定后的連接對象,是并發(fā)安全的。

通過使用預(yù)處理,可以避免在循環(huán)中執(zhí)行多次完整的 SQL 語句,從而顯著減少了數(shù)據(jù)庫交互次數(shù),這可以提高應(yīng)用程序的性能和效率。

使用預(yù)處理,會在 db.Prepare 時從連接池獲取一個連接,之后循環(huán)執(zhí)行 stmt.Exec,最終釋放連接。

如果使用 db.Exec,則每次循環(huán)時都需要:獲取連接-執(zhí)行 SQL-釋放連接,這幾個步驟,大大增加了與數(shù)據(jù)庫的交互次數(shù)。

不要忘記調(diào)用 stmt.Close() 關(guān)閉連接,這個方法是密等的,可以多次調(diào)用。

查詢

現(xiàn)在數(shù)據(jù)庫里已經(jīng)有了數(shù)據(jù),我們就可以查詢數(shù)據(jù)了。

因為 Exec 方法只會執(zhí)行 SQL,不會返回結(jié)果,所以不適用于查詢數(shù)據(jù)。

*sql.DB 提供了 Query 方法執(zhí)行查詢操作:

func GetUsers(db *sql.DB) ([]User, error) {
	rows, err := db.Query("SELECT * FROM user;")
	if err != nil {
		return nil, err
	}
	defer func() { _ = rows.Close() }()
	var users []User
	for rows.Next() {
		var user User
		if err := rows.Scan(&user.ID, &user.Name, &user.Email, &user.Age,
			&user.Birthday, &user.Salary, &user.CreatedAt, &user.UpdatedAt); err != nil {
			log.Println(err.Error())
			continue
		}
		users = append(users, user)
	}
	// 處理錯誤
	if err := rows.Err(); err != nil {
		return nil, err
	}
	return users, nil
}

db.Query 返回查詢結(jié)果集 *sql.Rows,這是一個結(jié)構(gòu)體。

rows.Next() 方法用來判斷是否還有下一條結(jié)果,可以用于 for 循環(huán)(題外話:這有點像 Python 的迭代器,只不過下一個值不是直接返回,而是通過 Scan 方法獲?。?。

如果存在下一條結(jié)果,rows.Next() 將返回 true。

rows.Scan() 方法可以將結(jié)果掃描到傳遞進來的指針對象。因為我們使用了 SELECT * 來查詢,所以會返回全部字段的數(shù)據(jù),按順序?qū)?user 對象相應(yīng)的字段指針傳遞進來即可。

rows.Scan() 會將一行記錄分別填入指定的變量中,并且會自動根據(jù)目標變量的類型處理類型轉(zhuǎn)換的問題,比如數(shù)據(jù)庫中是 varchar 類型,會映射成 Go 中的 string,但如果與之對應(yīng)的目標變量是 int,那么轉(zhuǎn)換失敗就會返回 error。

CreatedAt 字段是 time.Time 類型,之所以能夠被正確處理,是因為在調(diào)用 sql.Open() 時傳遞的 DSN 包含 parseTime=true 參數(shù)。

rows.Next() 返回為 false 時,即不再有下一條記錄。我們也就將全部查詢出來的用戶都存儲到 users 切片中了。

循環(huán)結(jié)束后,切記一定要調(diào)用 rows.Err() 來處理錯誤。

以上,我們查詢了多條用戶,*sql.DB 還提供了 QueryRow 方法可以查詢單條記錄:

func GetUser(db *sql.DB, id int64) (User, error) {
	var user User
	row := db.QueryRow("SELECT * FROM user WHERE id = ?", id)
	err := row.Scan(&user.ID, &user.Name, &user.Email, &user.Age,
		&user.Birthday, &user.Salary, &user.CreatedAt, &user.UpdatedAt)
	switch {
	case err == sql.ErrNoRows:
		return user, fmt.Errorf("no user with id %d", id)
	case err != nil:
		return user, err
	}
	// 處理錯誤
	if err := row.Err(); err != nil {
		return user, err
	}
	return user, nil
}

查詢單條記錄會返回 *sql.Row 結(jié)構(gòu)體,它實際上是對 *sql.Rows 的一層包裝:

type Row struct {
	// One of these two will be non-nil:
	err  error // deferred error for easy chaining
	rows *Rows
}

我們不再需要調(diào)用 rows.Next() 判斷是否有下一條結(jié)果,調(diào)用 row.Sca()*sql.Row 會自動幫我們處理好,返回查詢結(jié)果集中的第一條數(shù)據(jù)。

如果 row.Sca() 返回的錯誤類型為 sql.ErrNoRows 說明沒有查詢到符合條件的數(shù)據(jù),這對于判斷錯誤類型特別有用。

database/sql 顯然不能枚舉出所有數(shù)據(jù)庫的錯誤類型,有些針對不同數(shù)據(jù)庫的指定錯誤類型,通常由數(shù)據(jù)庫驅(qū)動程序來定義。

可以按照如下方式判斷特定的 MySQL 錯誤類型:

if driverErr, ok := err.(*mysql.MySQLError); ok {
    if driverErr.Number == 1045 {
        // 處理被拒絕的錯誤
    }
}

不過像 1045 這種魔法數(shù)字最好不要出現(xiàn)在代碼中,mysqlerr 包提供了 MySQL 錯誤類型的枚舉。

以上代碼可以改為:

if driverErr, ok := err.(*mysql.MySQLError); ok  {
    if driverErr.Number == mysqlerr.ER_ACCESS_DENIED_ERROR {
        // 處理被拒絕的錯誤
    }
}

最后,同樣不要忘記調(diào)用 row.Err() 處理錯誤。

更新

更新操作同創(chuàng)建一樣可以使用 *sql.DB.Exec 方法來實現(xiàn),不過這里我們將使用 *sql.DB.ExecContext 方法來實現(xiàn)。

ExecContext 方法與 Exec 方法在使用上沒什么兩樣,只不過第一個參數(shù)需要接收一個 context.Context,它允許你控制和取消執(zhí)行 SQL 語句的操作。使用上下文可以在需要的情況下設(shè)置超時時間、處理請求取消等操作。

func UpdateUserName(db *sql.DB, id int64, name string) error {
	ctx := context.Background()
	res, err := db.ExecContext(ctx, "UPDATE user SET name = ? WHERE id = ?", name, id)
	if err != nil {
		return err
	}
	affected, err := res.RowsAffected()
	if err != nil {
		return err
	}
	if affected == 0 {
		// 如果新的 name 等于原 name,也會執(zhí)行到這里
		return fmt.Errorf("no user with id %d", id)
	}
	return nil
}

這里使用 res.RowsAffected() 獲取了當前操作影響的行數(shù)。

注意,如果更新后的字段結(jié)果沒有變化,res.RowsAffected() 返回 0。

刪除

使用 *sql.DB.ExecContext 方法實現(xiàn)刪除用戶:

func DeleteUser(db *sql.DB, id int64) error {
	ctx := context.Background()
	res, err := db.ExecContext(ctx, "DELETE FROM user WHERE id = ?", id)
	if err != nil {
		return err
	}
	affected, err := res.RowsAffected()
	if err != nil {
		return err
	}
	if affected == 0 {
		return fmt.Errorf("no user with id %d", id)
	}
	return nil
}

事務(wù)

事務(wù)基本是開發(fā) Web 項目時比不可少的數(shù)據(jù)庫功能,database/sql 提供了對事務(wù)的支持。

如下示例使用事務(wù)來更新用戶:

func Transaction(db *sql.DB, id int64, name string) error {
	ctx := context.Background()
	tx, err := db.BeginTx(ctx, &sql.TxOptions{Isolation: sql.LevelSerializable})
	if err != nil {
		return err
	}
	_, execErr := tx.ExecContext(ctx, "UPDATE user SET name = ? WHERE id = ?", name, id)
	if execErr != nil {
		if rollbackErr := tx.Rollback(); rollbackErr != nil {
			log.Fatalf("update failed: %v, unable to rollback: %v\n", execErr, rollbackErr)
		}
		log.Fatalf("update failed: %v", execErr)
	}
	return tx.Commit()
}

*sql.DB.BeginTx 用于開啟一個事務(wù),第一個參數(shù)為 context.Context,第二個參數(shù)為 *sql.TxOptions 對象,用來配置事務(wù)選項,Isolation 字段用來設(shè)置數(shù)據(jù)庫隔離級別。

事務(wù)中執(zhí)行的 SQL 語句需要放在 tx 對象的 ExecContext 方法中執(zhí)行,而不是 db.ExecContext。

如果執(zhí)行 SQL 過程中出現(xiàn)錯誤,可以使用 tx.Rollback() 進行事務(wù)回滾。

如果沒有錯誤,則可以使用 tx.Commit() 提交事務(wù)。

tx 同樣支持 Prepare 方法,可以點擊這里查看使用示例。

處理 NULL

在創(chuàng)建 User 模型時,我們定義 Name 字段類型為 sql.NullString,而非普通的 string 類型,這是為了支持數(shù)據(jù)庫中的 NULL 類型。

數(shù)據(jù)庫中 name 字段定義如下:

`name` varchar(50) DEFAULT NULL COMMENT '用戶名'

那么 name 在數(shù)據(jù)庫中可能的值將有三種情況:NULL、空字符串 '' 以及有值的字符串 'n1'。

我們知道,Go 語言中 string 類型的默認值即為空字符串 '',但是 string 無法表示 NULL 值。

這個時候,我們有兩種方法解決此問題:

  • 使用指針類型。
  • 使用 sql.NullString 類型。

因為指針類型可能為 nil,所以可以使用 nil 來對應(yīng) NULL 值。這就是 User 模型中 Birthday 字段類型定義為 *time.Time 的緣故。

sql.NullString 類型定義如下:

type NullString struct {
	String string
	Valid  bool // Valid is true if String is not NULL
}

String 用來記錄值,Valid 用來標記是否為 NULL。

NullString 結(jié)構(gòu)體的值和數(shù)據(jù)庫中實際存儲的值,有如下映射關(guān)系:

valuevalue for MySQL
{String:n1 Valid:true}'n1'
{String: Valid:true}''
{String: Valid:false}NULL

此外,sql.NullString 類型還實現(xiàn)了 sql.Scanner 和 driver.Valuer 兩個接口:

// Scan implements the Scanner interface.
func (ns *NullString) Scan(value any) error {
	if value == nil {
		ns.String, ns.Valid = "", false
		return nil
	}
	ns.Valid = true
	return convertAssign(&ns.String, value)
}
// Value implements the driver Valuer interface.
func (ns NullString) Value() (driver.Value, error) {
	if !ns.Valid {
		return nil, nil
	}
	return ns.String, nil
}

這兩個接口分別用在 *sql.Row.Scan 方法和 *sql.DB.Exec 方法。

即在使用 *sql.DB.Exec 方法執(zhí)行 SQL 時,我們可能需要將 Name 字段的值存入 MySQL,此時 database/sql 會調(diào)用 sql.NullString 類型的 Value() 方法,獲取其將要存儲于數(shù)據(jù)庫中的值。

在使用 *sql.Row.Scan 方法時,我們可能需要將從數(shù)據(jù)庫獲取到的 name 字段值映射到 User 結(jié)構(gòu)體字段 Name 上,此時 database/sql 會調(diào)用 sql.NullString 類型的 Scan() 方法,把從數(shù)據(jù)庫中查詢的值賦值給 Name 字段。

如果你使用的字段不是 string 類型,database/sql 還提供了 sql.NullBool、sql.NullFloat64 等類型供用戶使用。

但是,這并不能枚舉出所有 MySQL 數(shù)據(jù)庫支持的字段類型,所以如果能夠盡量避免,還是不建議數(shù)據(jù)庫字段允許 NULL 值。

自定義字段類型

有些時候,我們保存在數(shù)據(jù)庫中的數(shù)據(jù)有著特定的格式,比如 salary 字段在數(shù)據(jù)庫中存儲的值為 {"month":100000,"year":10000000}。

數(shù)據(jù)庫中 salary 字段定義如下:

`salary` varchar(128) DEFAULT NULL COMMENT '薪水'

如果只是將其映射為 Go 中的 string,則操作時要格外小心,如果忘記寫一個 ", 等,程序?qū)⒖赡軋箦e。

因為 salary 值明顯是一個 JSON 格式,我們可以定義一個 struct 來映射其內(nèi)容:

type Salary struct {
	Month int `json:"month"`
	Year  int `json:"year"`
}

這還不夠,自定義類型無法支持 *sql.Row.Scan 方法和 *sql.DB.Exec 方法。

不過,我想你已經(jīng)猜到了,我們可以參考 sql.NullString 類型讓 Salary 同樣實現(xiàn) sql.Scannerdriver.Valuer 兩個接口:

// Scan implements sql.Scanner
func (s *Salary) Scan(src any) error {
	if src == nil {
		return nil
	}
	var buf []byte
	switch v := src.(type) {
	case []byte:
		buf = v
	case string:
		buf = []byte(v)
	default:
		return fmt.Errorf("invalid type: %T", src)
	}
	err := json.Unmarshal(buf, s)
	return err
}
// Value implements driver.Valuer
func (s Salary) Value() (driver.Value, error) {
	v, err := json.Marshal(s)
	return string(v), err
}

這樣,存儲和查詢數(shù)據(jù)的操作,Salary 類型都能夠支持。

未知列

極端情況下,我們可能不知道使用 *sql.DB.Query 方法查詢的結(jié)果集中數(shù)據(jù)的列名以及字段個數(shù)。

此時,我們可以使用 *sql.Rows.Columns 方法獲取所有列名,這將返回一個切片,這個切片長度,即為字段個數(shù)。

示例代碼如下:

func HandleUnknownColumns(db *sql.DB, id int64) ([]interface{}, error) {
	var res []interface{}
	rows, err := db.Query("SELECT * FROM user WHERE id = ?", id)
	if err != nil {
		return res, err
	}
	defer func() { _ = rows.Close() }()
	// 如果不知道列名稱,可以使用 rows.Columns() 查找列名稱列表
	cols, err := rows.Columns()
	if err != nil {
		return res, err
	}
	fmt.Printf("columns: %v\n", cols) // [id name email age birthday salary created_at updated_at]
	fmt.Printf("columns length: %d\n", len(cols))
	// 獲取列類型信息
	types, err := rows.ColumnTypes()
	if err != nil {
		return nil, err
	}
	for _, typ := range types {
		// id: &{name:id hasNullable:true hasLength:false hasPrecisionScale:false nullable:false length:0 databaseType:INT precision:0 scale:0 scanType:0x1045d68a0}
		fmt.Printf("%s: %+v\n", typ.Name(), typ)
	}
	res = []interface{}{
		new(int),            // id
		new(sql.NullString), // name
		new(string),         // email
		new(int),            // age
		new(time.Time),      // birthday
		new(Salary),         // salary
		new(time.Time),      // created_at
		// 如果不知道列類型,可以使用 sql.RawBytes,它實際上是 []byte 的別名
		new(sql.RawBytes), // updated_at
	}
	for rows.Next() {
		if err := rows.Scan(res...); err != nil {
			return res, err
		}
	}
	return res, rows.Err()
}

除了獲取列名和字段個數(shù),我們還可以使用 *sql.Rows.ColumnTypes 方法獲取每個 column 的詳細信息。

如果我們不知道某個字段在數(shù)據(jù)庫中的類型,則可以將其映射為 sql.RawBytes 類型,它實際上是 []byte 的別名。

總結(jié)

database/sql 包統(tǒng)一了 Go 語言操作數(shù)據(jù)庫的編程接口,避免了操作不同數(shù)據(jù)庫需要學(xué)習(xí)多套 API 的窘境。

使用 sql.Open() 建立數(shù)據(jù)庫連接并不會立刻生效,連接會在合適的時候延遲建立。

我們可以使用 *sql.DB.Exec / *sql.DB.ExecContext 來執(zhí)行 SQL 命令。其實除了 Exec 有方法對應(yīng)的 ExecContext 版本,文中提到的 *sql.DB.Ping、*sql.DB.Query、*sql.DB.QueryRow、*sql.DB.Prepare 方法也都有對應(yīng)的 XxxContext 版本,你可以自行測試。

如果被執(zhí)行的 SQL 語句中包含 MySQL 關(guān)鍵字,則需要使用反引號(`)將關(guān)鍵字進行包裹,否則你將得到 Error 1064 (42000): You have an error in your SQL syntax; 錯誤。

*sql.DB.BeginTx 可以開啟一個事務(wù),事務(wù)需要顯式的 CommitRollback,MySQL 驅(qū)動還支持使用 *sql.TxOptions 設(shè)置事務(wù)隔離級別。

對于 NULL 類型,database/sql 提供了 sql.NullString 等類型的支持。我們也可以為自定義類型實現(xiàn) sql.Scannerdriver.Valuer 兩個接口,來實現(xiàn)特定邏輯。

對于未知列和字段類型,我們可以使用 *sql.Rows.Columns、sql.RawBytes 等來解決,雖然這極大的增加了靈活性,不過不到萬不得已不建議使用,使用更加明確的代碼可以減少 BUG 的數(shù)量和提高可維護性。

以上就是Go使用database/sql操作數(shù)據(jù)庫的教程指南的詳細內(nèi)容,更多關(guān)于Go database/sql的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • GO中Json解析的幾種方式

    GO中Json解析的幾種方式

    本文主要介紹了GO中Json解析的幾種方式,詳細的介紹了幾種方法,?文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • Go json omitempty如何實現(xiàn)可選屬性

    Go json omitempty如何實現(xiàn)可選屬性

    在Go語言中,使用`omitempty`可以幫助我們在進行JSON序列化和反序列化時,忽略結(jié)構(gòu)體中的零值或空值,本文介紹了如何通過將字段類型改為指針類型,并在結(jié)構(gòu)體的JSON標簽中添加`omitempty`來實現(xiàn)這一功能,例如,將float32修改為*float32
    2024-09-09
  • 詳解Go中指針的原理與引用

    詳解Go中指針的原理與引用

    在?Go?中,指針是強大而重要的功能,它允許開發(fā)人員直接處理內(nèi)存地址并實現(xiàn)高效的數(shù)據(jù)操作,本文主要帶大家了解下指針在?Go?中的工作原理以及對于編寫高效、高性能代碼的重要性,希望對大家有所幫助
    2023-09-09
  • Golang并發(fā)編程中Context包的使用與并發(fā)控制

    Golang并發(fā)編程中Context包的使用與并發(fā)控制

    Golang的context包提供了在并發(fā)編程中傳遞取消信號、超時控制和元數(shù)據(jù)的功能,本文就來介紹一下Golang并發(fā)編程中Context包的使用與并發(fā)控制,感興趣的可以了解一下
    2024-11-11
  • Golang根據(jù)job數(shù)量動態(tài)控制每秒?yún)f(xié)程的最大創(chuàng)建數(shù)量方法詳解

    Golang根據(jù)job數(shù)量動態(tài)控制每秒?yún)f(xié)程的最大創(chuàng)建數(shù)量方法詳解

    這篇文章主要介紹了Golang根據(jù)job數(shù)量動態(tài)控制每秒?yún)f(xié)程的最大創(chuàng)建數(shù)量方法
    2024-01-01
  • 從生成CRD到編寫自定義控制器教程示例

    從生成CRD到編寫自定義控制器教程示例

    這篇文章主要為大家介紹了從生成CRD到編寫自定義控制器的教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • Golang中HTTP路由設(shè)計的使用與實現(xiàn)

    Golang中HTTP路由設(shè)計的使用與實現(xiàn)

    這篇文章主要介紹了Golang中HTTP路由設(shè)計的使用與實現(xiàn),為什么要設(shè)計路由規(guī)則,因為路由規(guī)則是HTTP的請求按照一定的規(guī)則 ,匹配查找到對應(yīng)的控制器并傳遞執(zhí)行的邏輯,需要的朋友可以參考下
    2023-05-05
  • go語言?http模型reactor示例詳解

    go語言?http模型reactor示例詳解

    這篇文章主要介紹了go語言?http模型reactor,接下來看一段基于reactor的示例,這里運行通過?go?run?main.go,本文結(jié)合示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • 使用go gin來操作cookie的講解

    使用go gin來操作cookie的講解

    今天小編就為大家分享一篇關(guān)于使用go gin來操作cookie的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-04-04
  • 基于Golang編寫一個聊天工具

    基于Golang編寫一個聊天工具

    這篇文章主要為大家詳細介紹了如何使用?Golang?構(gòu)建一個簡單但功能完善的聊天工具,利用?WebSocket?技術(shù)實現(xiàn)即時通訊的功能,需要的小伙伴可以參考下
    2023-11-11

最新評論

偷拍自拍亚洲美腿丝袜| 婷婷久久久综合中文字幕| av在线shipin| 在线成人日韩av电影| 亚洲免费av在线视频| 天天日天天爽天天干| 亚洲精品久久综合久| 成人免费做爰高潮视频| 国产精品sm调教视频| 黄色视频在线观看高清无码| av完全免费在线观看av| 国产高清在线观看1区2区| 日本午夜久久女同精女女| 漂亮 人妻被中出中文| 黄色片一级美女黄色片| 成年人的在线免费视频| 精内国产乱码久久久久久| 中文字幕一区二区三区蜜月| 成年人中文字幕在线观看| 一区二区三区av高清免费| 午夜激情久久不卡一区二区| 午夜毛片不卡免费观看视频 | 成人区人妻精品一区二视频| 中文字幕一区二 区二三区四区| 欧美一区二区中文字幕电影 | 中国无遮挡白丝袜二区精品| 91国内视频在线观看| 欧美xxx成人在线| 午夜精品久久久久麻豆影视| 视频一区 二区 三区 综合| av天堂中文字幕最新| 天堂av在线播放免费| 天天操天天干天天艹| 91精品国产综合久久久蜜| 国产精品久久久久久久久福交| 国产白袜脚足J棉袜在线观看| 国产一区二区火爆视频| 骚逼被大屌狂草视频免费看| 日韩美av高清在线| 精品91自产拍在线观看一区| 久久精品国产亚洲精品166m| 亚洲av自拍偷拍综合| avjpm亚洲伊人久久| 欧美成人精品欧美一级黄色| 人妻少妇av在线观看 | 欧美老妇精品另类不卡片| 国产综合视频在线看片| 亚洲国产欧美一区二区丝袜黑人| 欧美交性又色又爽又黄麻豆| 老司机深夜免费福利视频在线观看| 国产三级片久久久久久久| 国产亚洲精品欧洲在线观看| 中文字幕亚洲中文字幕| 亚洲国产精品久久久久久6| 久久精品亚洲国产av香蕉| 午夜在线一区二区免费| 免费人成黄页网站在线观看国产| 日日摸夜夜添夜夜添毛片性色av| 中文字幕视频一区二区在线观看| 青青青青青青草国产| 日本韩国在线观看一区二区| 夜女神免费福利视频| 欧美熟妇一区二区三区仙踪林| 边摸边做超爽毛片18禁色戒 | 日韩欧美一级aa大片| 人妻丝袜榨强中文字幕| 人妻久久无码中文成人| 成人区人妻精品一区二视频| 最新97国产在线视频| 欧美日韩亚洲国产无线码| 亚洲专区激情在线观看视频| 欧美韩国日本国产亚洲| 中文字幕日韩精品就在这里| 18禁免费av网站| 97年大学生大白天操逼| 大香蕉大香蕉在线有码 av| 88成人免费av网站| 爱爱免费在线观看视频| 白嫩白嫩美女极品国产在线观看| 久久久久久国产精品| 中文字幕综合一区二区| 天天躁日日躁狠狠躁av麻豆| 亚洲精品国产在线电影| 日比视频老公慢点好舒服啊| av在线播放国产不卡| 蜜桃色婷婷久久久福利在线| 在线免费观看国产精品黄色| 午夜国产福利在线观看| 国产福利小视频免费观看| 国产精品一区二区av国| 亚洲欧美久久久久久久久| 亚洲在线免费h观看网站| jiuse91九色视频| 精品美女久久久久久| 成人精品视频99第一页| 在线网站你懂得老司机| 国产三级片久久久久久久| 欧美一级视频一区二区| 新婚人妻聚会被中出| av在线免费观看亚洲天堂| 一区二区三区四区中文| 日本a级视频老女人| av完全免费在线观看av| 日韩欧美亚洲熟女人妻| 清纯美女在线观看国产| 国产一区二区在线欧美| 亚洲成人精品女人久久久| 99国产精品窥熟女精品| 青青青青青手机视频| 欧美成人一二三在线网| 国产亚洲视频在线观看| 男人的天堂av日韩亚洲| 久久久极品久久蜜桃| 国产精品黄大片在线播放| 宅男噜噜噜666免费观看| 亚洲在线观看中文字幕av| 亚洲视频在线视频看视频在线| 国产日韩av一区二区在线| 不戴胸罩引我诱的隔壁的人妻| 免费费一级特黄真人片 | 在线视频精品你懂的| 伊人成人综合开心网| 啊慢点鸡巴太大了啊舒服视频| 韩国AV无码不卡在线播放| 在线国产精品一区二区三区| 国产成人小视频在线观看无遮挡 | 免费看国产又粗又猛又爽又黄视频| 青青草原色片网站在线观看| 特一级特级黄色网片| 经典亚洲伊人第一页| 亚洲中文精品人人免费| 91在线视频在线精品3| 人妻无码中文字幕专区| 少妇ww搡性bbb91| 久久久精品精品视频视频| 人妻无码中文字幕专区| 2022天天干天天操| 青青青aaaa免费| 天天日天天爽天天干| 精品av久久久久久久| 久久久久91精品推荐99| 黄色中文字幕在线播放| 在线可以看的视频你懂的| 亚洲蜜臀av一区二区三区九色 | 日韩美女搞黄视频免费| 狠狠鲁狠狠操天天晚上干干| 亚洲国产40页第21页| 成人性黑人一级av| 2022国产综合在线干| 久久久久久性虐视频| 大黑人性xxxxbbbb| 都市激情校园春色狠狠| 天天日天天做天天日天天做| 韩国黄色一级二级三级| 国产成人自拍视频播放| 激情国产小视频在线| 国产高清在线在线视频| 日本少妇在线视频大香蕉在线观看| 精内国产乱码久久久久久| 91免费放福利在线观看| 在线播放国产黄色av| 成人色综合中文字幕| 91精品国产黑色丝袜| 亚洲一区二区三区偷拍女厕91 | 午夜免费观看精品视频| 精品高潮呻吟久久av| 动色av一区二区三区| 国产亚洲四十路五十路| 毛片av在线免费看| 午夜蜜桃一区二区三区| 亚洲欧美成人综合视频| 熟女人妻在线观看视频| 色伦色伦777国产精品| 男人天堂色男人av| mm131美女午夜爽爽爽| 亚洲男人在线天堂网| 日曰摸日日碰夜夜爽歪歪| 久久精品视频一区二区三区四区| 日本午夜久久女同精女女| 91麻豆精品秘密入口在线观看| 亚洲熟女久久久36d| 新97超碰在线观看| 亚洲护士一区二区三区| 精品亚洲在线免费观看| 宅男噜噜噜666免费观看| 亚洲欧美久久久久久久久| 日本成人一区二区不卡免费在线| 国产精品久久久久国产三级试频| 在线国产中文字幕视频| 97年大学生大白天操逼| 2025年人妻中文字幕乱码在线| 中文字幕在线视频一区二区三区| 婷婷久久一区二区字幕网址你懂得| 亚洲 中文字幕在线 日韩| 少妇与子乱在线观看| 大鸡吧插入女阴道黄色片 | 99热久久这里只有精品| 亚洲av琪琪男人的天堂| 香蕉aⅴ一区二区三区| 黄色资源视频网站日韩| 久久午夜夜伦痒痒想咳嗽P| 日韩成人综艺在线播放| 国产午夜男女爽爽爽爽爽视频 | 在线视频这里只有精品自拍| 日本xx片在线观看| 日日操综合成人av| 老有所依在线观看完整版| 欧美另类z0z变态| 91桃色成人网络在线观看| 人妻激情图片视频小说| 中文字幕人妻一区二区视频| 男生舔女生逼逼视频| 欧美亚洲中文字幕一区二区三区| 日本一区精品视频在线观看| wwwxxx一级黄色片| 亚洲成a人片777777| 天天射夜夜操狠狠干| 精品视频国产在线观看| 三上悠亚和黑人665番号| 国产在线观看免费人成短视频| 2020国产在线不卡视频| 国产av自拍偷拍盛宴| 19一区二区三区在线播放| 久久久极品久久蜜桃| 夜色撩人久久7777| 精品老妇女久久9g国产| 青娱乐在线免费视频盛宴| 99精品免费久久久久久久久a| 亚洲欧美综合另类13p| 成人综合亚洲欧美一区| 黄片三级三级三级在线观看| 国产在线一区二区三区麻酥酥 | 欧美黑人巨大性xxxxx猛交| 91综合久久亚洲综合| 午夜精品久久久久麻豆影视| 亚洲av第国产精品| 日本中文字幕一二区视频| 亚洲精品国产久久久久久| 老司机福利精品视频在线| 2020av天堂网在线观看| 日本韩国免费福利精品| 九九视频在线精品播放| 欧美中国日韩久久精品| 成年人免费看在线视频| 爱爱免费在线观看视频| 亚洲的电影一区二区三区| 大鸡吧插入女阴道黄色片| 99国内小视频在现欢看| 国产性色生活片毛片春晓精品 | 国产亚洲国产av网站在线| 性色蜜臀av一区二区三区| 日韩二区视频一线天婷婷五| 夜女神免费福利视频| 一色桃子久久精品亚洲| 97香蕉碰碰人妻国产樱花| 亚欧在线视频你懂的| 欧美日韩精品永久免费网址 | 自拍偷拍亚洲欧美在线视频| 中文字幕午夜免费福利视频| 成人18禁网站在线播放| 在线免费观看亚洲精品电影| 在线不卡成人黄色精品| 国产精彩对白一区二区三区| 亚洲综合在线视频可播放| 岛国一区二区三区视频在线| 日韩熟女av天堂系列| 国产1区,2区,3区| 人人妻人人澡欧美91精品| 亚洲麻豆一区二区三区| 成人影片高清在线观看| 国产91嫩草久久成人在线视频| okirakuhuhu在线观看| av日韩在线免费播放| 岛国毛片视频免费在线观看| 精品美女福利在线观看| 国产美女精品福利在线| 国产亚洲视频在线观看| 国产欧美精品一区二区高清| 男人操女人逼逼视频网站| 亚洲国产最大av综合| 天天日天天天天天天天天天天 | 欧美在线精品一区二区三区视频| 国内精品在线播放第一页| 在线亚洲天堂色播av电影| 男女啪啪视频免费在线观看| 天天射夜夜操狠狠干| 久碰精品少妇中文字幕av| 人妻最新视频在线免费观看| 18禁网站一区二区三区四区| av中文在线天堂精品| 黑人巨大的吊bdsm| 精品一区二区三区欧美| 国产chinesehd精品麻豆| 午夜精品一区二区三区更新| 天天通天天透天天插| 绯色av蜜臀vs少妇| 国产精品久久久久久美女校花| 一区二区三区四区中文| 欧美日韩在线精品一区二区三| 99热久久这里只有精品| 成人av免费不卡在线观看| 中文字幕人妻被公上司喝醉在线 | 欧美黑人与人妻精品| 啪啪啪啪啪啪啪免费视频| 懂色av蜜桃a v| 偷偷玩弄新婚人妻h视频| 91免费福利网91麻豆国产精品 | 97国产福利小视频合集| 中文字幕人妻av在线观看| 黄色片一级美女黄色片| 99精品免费久久久久久久久a| 国产精品视频男人的天堂| 午夜在线精品偷拍一区二| 中文字幕人妻一区二区视频| 亚洲成人情色电影在线观看| 免费黄色成人午夜在线网站| 国产美女精品福利在线| 欧美精品激情在线最新观看视频| 91免费黄片可看视频| 伊人综合免费在线视频| 97精品视频在线观看| 亚洲va国产va欧美精品88| 动漫美女的小穴视频| 亚洲美女自偷自拍11页| 视频二区在线视频观看| 哥哥姐姐综合激情小说| 狠狠的往里顶撞h百合| 欧美成人综合视频一区二区| 男人天堂最新地址av| 极品性荡少妇一区二区色欲| 538精品在线观看视频| 欧美日韩熟女一区二区三区| 亚洲免费va在线播放| 91人妻人人做人人爽在线| 亚洲一区二区久久久人妻| 精品国产亚洲av一淫| 亚洲老熟妇日本老妇| 欧美一区二区三区高清不卡tv| 80电影天堂网官网| 91国产在线免费播放| 亚洲天堂成人在线观看视频网站| 超碰中文字幕免费观看| 亚洲熟色妇av日韩熟色妇在线 | 晚上一个人看操B片| 97人妻总资源视频| 人妻丝袜诱惑我操她视频| 中文字幕日本人妻中出| 夜色福利视频在线观看| 一个色综合男人天堂| 亚洲福利精品视频在线免费观看| 日本人妻少妇18—xx| 91社福利《在线观看| 精品一区二区三四区| 99热久久极品热亚洲| 日韩特级黄片高清在线看| 中文乱理伦片在线观看| 中英文字幕av一区| 日韩无码国产精品强奸乱伦| 不卡一不卡二不卡三| 天天综合天天综合天天网| 日韩美女搞黄视频免费| 亚洲国产最大av综合| 97小视频人妻一区二区| 人妻少妇精品久久久久久| 伊人综合aⅴ在线网| 亚洲国产在人线放午夜| 国产清纯美女al在线| 国产日韩一区二区在线看| 欧美在线精品一区二区三区视频 | 视频久久久久久久人妻| 国产使劲操在线播放| 天天日天天摸天天爱| 快点插进来操我逼啊视频| 国产成人精品一区在线观看| 日本三极片中文字幕| huangse网站在线观看| 久草视频在线看免费| 国产精彩福利精品视频| 亚洲一级美女啪啪啪| av在线shipin| 欧美乱妇无乱码一区二区| 中文字幕人妻被公上司喝醉在线| 天天插天天狠天天操| 91久久精品色伊人6882| 91精品国产观看免费| 91久久人澡人人添人人爽乱| 成人av天堂丝袜在线观看| 欧美一区二区三区高清不卡tv| 亚洲欧美在线视频第一页| 非洲黑人一级特黄片| 欧美爆乳肉感大码在线观看| 黑人巨大的吊bdsm| 毛片av在线免费看| 精彩视频99免费在线| 日本一区精品视频在线观看| 久草电影免费在线观看| 中文字幕一区二区人妻电影冢本 | 中文字幕AV在线免费看 | 国产熟妇乱妇熟色T区| 久久精品亚洲成在人线a| 国产精品视频欧美一区二区| 日本中文字幕一二区视频| 日本韩国在线观看一区二区| 国产熟妇一区二区三区av| 青青青青青青青在线播放视频| 欧美激情精品在线观看| 亚洲男人在线天堂网| 99re国产在线精品| 成人av中文字幕一区| 操人妻嗷嗷叫视频一区二区| 久久久久久久一区二区三| 三级等保密码要求条款| 人妻无码中文字幕专区| 亚洲公开视频在线观看| 91老师蜜桃臀大屁股| 天天日天天干天天插舔舔| 粉嫩欧美美人妻小视频| 黄色的网站在线免费看| 香蕉片在线观看av| 黄色大片男人操女人逼| 日韩人妻丝袜中文字幕| 在线观看视频 你懂的| 日本精品一区二区三区在线视频。| 成人午夜电影在线观看 久久| 80电影天堂网官网| 青青草原网站在线观看| 九色精品视频在线播放| av网址国产在线观看| 狠狠躁狠狠爱网站视频| 中文字幕在线免费第一页| 青青草精品在线视频观看| 欧美美女人体视频一区| 国产高清精品一区二区三区| 成人影片高清在线观看| 久久99久久99精品影院| 999久久久久999| 哥哥姐姐综合激情小说| 人妻丝袜榨强中文字幕| 天天干天天爱天天色| 国产成人精品av网站| 精品av久久久久久久| av中文字幕福利网| 亚洲天堂第一页中文字幕| 日韩av中文在线免费观看| 国产实拍勾搭女技师av在线| 最新中文字幕乱码在线| 五十路息与子猛烈交尾视频| 国产精彩对白一区二区三区| av高潮迭起在线观看| 视频一区 二区 三区 综合| 五十路在线观看完整版| 国产 在线 免费 精品| 日韩午夜福利精品试看| 亚洲免费福利一区二区三区| 国产一区二区神马久久| 亚洲欧美一卡二卡三卡| 五月婷婷在线观看视频免费| 91在线视频在线精品3| 美女福利写真在线观看视频| 青青色国产视频在线| 91在线免费观看成人| 亚洲av日韩高清hd| 日本少妇人妻xxxxxhd| 久草视频在线一区二区三区资源站 | 999九九久久久精品| 97青青青手机在线视频| 美女张开腿让男生操在线看| 大胆亚洲av日韩av| 自拍偷拍,中文字幕| 91国产在线免费播放| 成人综合亚洲欧美一区| 免费黄页网站4188| 夜夜骑夜夜操夜夜奸| 亚洲av成人免费网站| 最新中文字幕免费视频| 漂亮 人妻被中出中文| 国产亚州色婷婷久久99精品| 欧美黄色录像免费看的| 天天日天天玩天天摸| 亚欧在线视频你懂的| 黄色在线观看免费观看在线| 超碰公开大香蕉97| 中文字幕AV在线免费看 | 久久久久只精品国产三级| 天天干狠狠干天天操| asmr福利视频在线观看| 色秀欧美视频第一页| 日本18禁久久久久久| 毛片一级完整版免费| 大黑人性xxxxbbbb| 午夜精品福利一区二区三区p| 亚洲福利天堂久久久久久| 538精品在线观看视频| 国产精品黄大片在线播放| 午夜精品久久久久久99热| 日本人竟这样玩学生妹| 最近中文字幕国产在线| 久草视频 久草视频2| 国产乱弄免费视频观看| 亚洲一区二区三区久久午夜| 老师让我插进去69AV| 家庭女教师中文字幕在线播放| h国产小视频福利在线观看| 欧美日韩亚洲国产无线码| 成人伊人精品色xxxx视频| 97青青青手机在线视频| 美女福利视频导航网站| 亚洲国产40页第21页| 天天射夜夜操综合网| 视频一区 视频二区 视频| 大肉大捧一进一出好爽在线视频| 最近中文字幕国产在线| 国产精品一区二区久久久av| 亚洲精品福利网站图片| 日韩不卡中文在线视频网站| 国产综合高清在线观看| 孕妇奶水仑乱A级毛片免费看| 国产丰满熟女成人视频| 视频二区在线视频观看| 天天夜天天日天天日| 久碰精品少妇中文字幕av| 亚洲国产精品美女在线观看 | 日本脱亚入欧是指什么| av在线观看网址av| 毛片一级完整版免费| 香蕉91一区二区三区| 国产实拍勾搭女技师av在线| 99av国产精品欲麻豆| 黑人3p华裔熟女普通话| 国产91久久精品一区二区字幕| 日韩一个色综合导航| 天天摸天天干天天操科普| 国产老熟女伦老熟妇ⅹ| 青青青青草手机在线视频免费看| 一区二区三区美女毛片| 夜色福利视频在线观看| 青青草精品在线视频观看| 无码中文字幕波多野不卡| 国产熟妇乱妇熟色T区| 日本福利午夜电影在线观看| 天天想要天天操天天干| 欧美国品一二三产区区别| 97超碰免费在线视频| 天天日天天日天天射天天干| 天天色天天操天天舔| 精品久久婷婷免费视频| 久久久91蜜桃精品ad| 激情小视频国产在线| 偷拍美女一区二区三区| 亚洲国产欧美一区二区三区久久| 日韩人妻xxxxx| 青青草亚洲国产精品视频| 全国亚洲男人的天堂| 午夜福利资源综合激情午夜福利资| 国产成人自拍视频在线免费观看| 国产欧美日韩在线观看不卡| 岳太深了紧紧的中文字幕| 精品国产亚洲av一淫| 一区二区三区四区五区性感视频| 四虎永久在线精品免费区二区| 亚洲人成精品久久久久久久| 免费岛国喷水视频在线观看 | 美女福利视频导航网站| 中文字幕一区二 区二三区四区 | 91精品高清一区二区三区| 一区二区免费高清黄色视频| 日视频免费在线观看| 熟妇一区二区三区高清版| 一级黄色片夫妻性生活| 亚洲国产最大av综合| 久久人人做人人妻人人玩精品vr| 免费无码人妻日韩精品一区二区| 中文字幕亚洲久久久| 中文字幕高清在线免费播放 | 亚洲成人av在线一区二区| 日本女人一级免费片| av手机在线免费观看日韩av| 丰满熟女午夜福利视频| 懂色av之国产精品| 久久久久久久精品老熟妇| 人妻熟女中文字幕aⅴ在线| 午夜福利资源综合激情午夜福利资| 久久三久久三久久三久久| 欧美黑人性暴力猛交喷水| 亚洲福利午夜久久久精品电影网 | 日本黄色特一级视频| 国产乱子伦一二三区| 亚洲男人的天堂a在线| 好男人视频在线免费观看网站| 天天摸天天日天天操| 四川五十路熟女av| 欧洲亚洲欧美日韩综合| 国产av福利网址大全| 精品国产高潮中文字幕| 天天操天天污天天射| 欧美少妇性一区二区三区| 国产福利小视频免费观看| 中文乱理伦片在线观看| 偷拍自拍国产在线视频| 色97视频在线播放| 中文字幕日本人妻中出| 可以免费看的www视频你懂的| 黄页网视频在线免费观看| 黄片色呦呦视频免费看| 最新黄色av网站在线观看| 亚洲精品一线二线在线观看| 91香蕉成人app下载| 九色精品视频在线播放| 色偷偷伊人大杳蕉综合网| 99精品国产自在现线观看| 夜女神免费福利视频| 特级欧美插插插插插bbbbb| 精品高跟鞋丝袜一区二区| 成人av中文字幕一区| 亚洲中文字字幕乱码| 欧美va亚洲va天堂va| 国产日韩精品一二三区久久久| 免费国产性生活视频| 99国内小视频在现欢看| 91免费观看在线网站| 日本熟妇喷水xxx| 黄色片黄色片wyaa| 国产欧美日韩在线观看不卡| 首之国产AV医生和护士小芳| 视频久久久久久久人妻| 国产精品自偷自拍啪啪啪| 亚洲丝袜老师诱惑在线观看| 日韩亚国产欧美三级涩爱| 97国产福利小视频合集| av在线观看网址av| 懂色av蜜桃a v| 91福利视频免费在线观看| 清纯美女在线观看国产| 91高清成人在线视频| yellow在线播放av啊啊啊| av黄色成人在线观看| 日本裸体熟妇区二区欧美| 91久久人澡人人添人人爽乱| av中文字幕在线观看第三页| 日韩美av高清在线| 亚洲精品乱码久久久本| 曰本无码人妻丰满熟妇啪啪| 精品视频一区二区三区四区五区| 综合页自拍视频在线播放| 亚洲精品精品国产综合| 91麻豆精品传媒国产黄色片| 亚洲av日韩av网站| 在线观看视频污一区| 欧美日韩一区二区电影在线观看| 亚洲欧美人精品高清| 传媒在线播放国产精品一区| 涩爱综合久久五月蜜臀| 美女小视频网站在线| AV无码一区二区三区不卡| 97青青青手机在线视频| 免费在线黄色观看网站| 亚洲国产成人最新资源| 中文字幕1卡1区2区3区| 日本又色又爽又黄又粗| 人妻丝袜精品中文字幕| av无限看熟女人妻另类av| aⅴ精产国品一二三产品| 日韩人妻在线视频免费| 国产午夜无码福利在线看| 国产精品久久久黄网站| 久久精品在线观看一区二区| 天天日天天日天天擦| 亚洲日本一区二区久久久精品| 亚洲国产在人线放午夜| 国产女人露脸高潮对白视频| 日日夜夜狠狠干视频| 一区二区三区精品日本| 青青青青青手机视频| 国产精品久久久黄网站| 一区二区麻豆传媒黄片| 中文字幕一区二区三区蜜月| 99久久久无码国产精品性出奶水| 国产女人露脸高潮对白视频| 精品亚洲中文字幕av| 免费无毒热热热热热热久| 熟女91pooyn熟女| 国产综合高清在线观看| 久久久久只精品国产三级| 1000部国产精品成人观看视频| 999九九久久久精品| 成人在线欧美日韩国产| 欧美在线精品一区二区三区视频| 黄片色呦呦视频免费看| 人妻熟女在线一区二区| 高潮喷水在线视频观看| 国产精品人妻熟女毛片av久| 超级av免费观看一区二区三区| 深夜男人福利在线观看| 成人高潮aa毛片免费| 国产精品自拍在线视频| 91大神福利视频网| 男人的网址你懂的亚洲欧洲av| 小泽玛利亚视频在线观看| 天天射,天天操,天天说| 99精品国产aⅴ在线观看| av中文字幕电影在线看| 青草青永久在线视频18| www,久久久,com| 最新97国产在线视频| 亚洲 国产 成人 在线| 福利在线视频网址导航| 漂亮 人妻被中出中文| 亚洲av自拍天堂网| 最近中文2019年在线看| 美女小视频网站在线| 亚洲精品一线二线在线观看 | 亚洲男人的天堂a在线| 亚洲精品国品乱码久久久久| 亚洲成人情色电影在线观看| 啊啊好大好爽啊啊操我啊啊视频| 亚洲精品麻豆免费在线观看| 少妇人妻二三区视频| 国内自拍第一页在线观看| 扒开腿挺进肉嫩小18禁视频| 国产成人一区二区三区电影网站| 爆乳骚货内射骚货内射在线| 日韩欧美一级黄片亚洲| 在线观看黄色成年人网站| 亚洲卡1卡2卡三卡四老狼| 美女日逼视频免费观看| 日本真人性生活视频免费看| 啊啊啊视频试看人妻| 欧美成人黄片一区二区三区 | 欧美伊人久久大香线蕉综合| 免费在线观看视频啪啪| 亚洲综合一区成人在线| 中文字幕av熟女人妻| 91老熟女连续高潮对白| 日本熟女精品一区二区三区| 国产一线二线三线的区别在哪| 精品一区二区三区三区88| 日本女大学生的黄色小视频| 国产午夜亚洲精品不卡在线观看 | 亚洲中文精品人人免费| 在线观看免费视频色97| 999热精品视频在线| 天天日天天做天天日天天做| 2022国产综合在线干| 99久久99久国产黄毛片| 久久农村老妇乱69系列| 黑人巨大精品欧美视频| 欧美少妇性一区二区三区| 美女张开两腿让男人桶av| 一色桃子久久精品亚洲| 狍和女人的王色毛片| 丰满熟女午夜福利视频| 夜色福利视频在线观看| 99久久99久国产黄毛片| 老司机免费视频网站在线看| 小穴多水久久精品免费看| 欧美va亚洲va天堂va| 天天日天天鲁天天操| 97人人模人人爽人人喊| 五十路息与子猛烈交尾视频| 99久久超碰人妻国产| 污污小视频91在线观看| 亚洲国产精品中文字幕网站| 五十路熟女av天堂| 一区二区三区 自拍偷拍| 免费在线播放a级片| 亚洲熟妇久久无码精品| 亚洲午夜电影在线观看| 国产精品人久久久久久| 91色九色porny| 亚洲综合自拍视频一区| 国产精品视频欧美一区二区| 大白屁股精品视频国产| av在线免费观看亚洲天堂| 久久一区二区三区人妻欧美| 亚洲卡1卡2卡三卡四老狼| 把腿张开让我插进去视频| 亚洲av男人的天堂你懂的| 欧美成一区二区三区四区| 老有所依在线观看完整版| 91免费黄片可看视频| 超碰中文字幕免费观看| 国产精品污污污久久| 不卡一区一区三区在线| nagger可以指黑人吗| 免费高清自慰一区二区三区网站| 久久香蕉国产免费天天| 日韩欧美一级aa大片| 亚洲熟妇无码一区二区三区| 大白屁股精品视频国产| 国产福利小视频大全| 午夜精品一区二区三区4| 国产高潮无码喷水AV片在线观看| 日韩少妇人妻精品无码专区| 亚洲精品高清自拍av| 亚洲国产成人最新资源| 久久综合老鸭窝色综合久久| 美女操逼免费短视频下载链接| 亚洲成人线上免费视频观看| 青青青青视频在线播放| 婷婷综合亚洲爱久久| 一二三中文乱码亚洲乱码one| 人妻在线精品录音叫床| 又粗又硬又猛又黄免费30| 欧美视频一区免费在线| 国产伦精品一区二区三区竹菊| 青青在线视频性感少妇和隔壁黑丝| av中文字幕电影在线看| av乱码一区二区三区| 成人免费公开视频无毒| 国产一级精品综合av| 亚洲伊人久久精品影院一美女洗澡| 免费成人av中文字幕| 热思思国产99re| 又粗又硬又猛又黄免费30| 久久久91蜜桃精品ad| 91国内视频在线观看| 久草视频 久草视频2| 91福利视频免费在线观看| 传媒在线播放国产精品一区| 人妻丝袜榨强中文字幕| 国产精选一区在线播放| 中文字幕欧美日韩射射一| 黑人解禁人妻叶爱071| 免费av岛国天堂网站| 亚洲图片欧美校园春色| 日本午夜爽爽爽爽爽视频在线观看| 亚洲午夜伦理视频在线| 成年午夜免费无码区| 美女福利写真在线观看视频| 老司机免费视频网站在线看| 亚洲成人三级在线播放| 日本人妻精品久久久久久| 女同久久精品秋霞网| 任你操任你干精品在线视频| 国产精品人妻一区二区三区网站| 一个色综合男人天堂| 亚洲一区二区三区五区| 综合一区二区三区蜜臀| 亚洲一区二区三区偷拍女厕91| 免费在线看的黄片视频| 青青草在观免费国产精品| 国产日韩欧美视频在线导航| 日韩亚国产欧美三级涩爱| 国产精品入口麻豆啊啊啊| 国产精彩福利精品视频| av日韩在线观看大全| 97黄网站在线观看| 中国黄色av一级片| 美女视频福利免费看| 午夜在线观看一区视频| 高潮喷水在线视频观看| 亚洲av无乱一区二区三区性色| 一区二区三区日本伦理| 国产午夜亚洲精品麻豆| 男生舔女生逼逼的视频| rct470中文字幕在线| 国产九色91在线观看精品| 亚洲综合图片20p| 亚洲1卡2卡三卡4卡在线观看 | 2020国产在线不卡视频| 天天躁日日躁狠狠躁av麻豆| 天天操天天插天天色| 午夜在线观看岛国av,com| xxx日本hd高清| 成年人午夜黄片视频资源| 都市激情校园春色狠狠| 狠狠鲁狠狠操天天晚上干干| 中文字幕免费在线免费| 久久丁香花五月天色婷婷| 91p0rny九色露脸熟女| 一区二区三区日本伦理| 亚洲1区2区3区精华液| 精品美女在线观看视频在线观看| 2021国产一区二区| 一本一本久久a久久精品综合不卡| 超碰97人人澡人人| 国产亚洲精品品视频在线| 亚洲天堂av最新网址| 亚洲欧洲一区二区在线观看| 欧美成一区二区三区四区| 揄拍成人国产精品免费看视频 | 年轻的人妻被夫上司侵犯| 国产精品久久久久久久女人18| 精品久久久久久久久久中文蒉| 性感美女诱惑福利视频| 91中文字幕最新合集| 日本熟妇丰满厨房55| 新婚人妻聚会被中出| 午夜极品美女福利视频| 黄色资源视频网站日韩| 天天日天天操天天摸天天舔 | jiuse91九色视频| 亚洲欧美日韩视频免费观看| 国产又粗又硬又猛的毛片视频| 大屁股肉感人妻中文字幕在线| 蜜臀av久久久久久久| 97人妻夜夜爽二区欧美极品| 制服丝袜在线人妻中文字幕| 成人av天堂丝袜在线观看| 区一区二区三国产中文字幕| 色av色婷婷人妻久久久精品高清 | 日本精品一区二区三区在线视频。| 青娱乐最新视频在线| 超碰97免费人妻麻豆| 黄色av网站免费在线| 亚洲中文精品人人免费| 99久久99一区二区三区| 91国偷自产一区二区三区精品| 在线 中文字幕 一区| 人妻素人精油按摩中出| 欧美色呦呦最新网址| 91天堂精品一区二区| 91九色国产porny蝌蚪| 亚洲在线观看中文字幕av| 精品高潮呻吟久久av| 亚洲一区自拍高清免费视频| 亚洲一区制服丝袜美腿| 高潮视频在线快速观看国家快速| 久草电影免费在线观看| 亚洲久久午夜av一区二区| 国产亚洲天堂天天一区| 又粗又硬又猛又爽又黄的| 特一级特级黄色网片| 午夜激情高清在线观看| 国产精品自拍视频大全| 国产福利小视频二区| 中国视频一区二区三区| 熟女人妻在线观看视频| 91www一区二区三区| 欧美在线一二三视频| 绝顶痉挛大潮喷高潮无码| 色婷婷六月亚洲综合香蕉| 国内自拍第一页在线观看| 亚洲 清纯 国产com| 精品一线二线三线日本| 日韩北条麻妃一区在线| 老有所依在线观看完整版| 国产精品久久久久网| 人妻最新视频在线免费观看| 人人妻人人澡欧美91精品| 青青青激情在线观看视频| 国产在线免费观看成人| 97青青青手机在线视频| 亚洲一级美女啪啪啪| 国产综合视频在线看片| 插小穴高清无码中文字幕| 久久麻豆亚洲精品av| 国产欧美精品一区二区高清 | 中文字幕在线免费第一页| 国产视频一区二区午夜| 自拍偷拍,中文字幕| 亚洲成人线上免费视频观看| 四川五十路熟女av| 视频在线亚洲一区二区| 99精品国自产在线人| 欧美激情精品在线观看| 黑人乱偷人妻中文字幕| 嫩草aⅴ一区二区三区| 成人激情文学网人妻| 2018最新中文字幕在线观看| 免费人成黄页网站在线观看国产| 亚洲国产免费av一区二区三区| 国产精品国产三级国产精东| 美女骚逼日出水来了| 精品91高清在线观看| 91极品新人『兔兔』精品新作| 中文字幕一区二区三区人妻大片| 日比视频老公慢点好舒服啊| 在线观看成人国产电影| 五色婷婷综合狠狠爱| 一区二区久久成人网| 直接能看的国产av| 欧美专区第八页一区在线播放| 久草视频福利在线首页| 在线观看视频 你懂的| 欧美日韩在线精品一区二区三| 国产成人精品av网站| 欧美麻豆av在线播放| 国产成人精品久久二区91| 精产国品久久一二三产区区别| 日本午夜久久女同精女女| 蜜桃专区一区二区在线观看| 一级a看免费观看网站| 熟女俱乐部一二三区| 亚洲 国产 成人 在线| 久久久久久99国产精品| 亚洲高清免费在线观看视频| 亚洲一级 片内射视正片| 沈阳熟妇28厘米大战黑人| 国产精品自拍视频大全| 午夜美女福利小视频| 久久久91蜜桃精品ad| 欧美日本aⅴ免费视频| 天天干天天爱天天色| 91色老99久久九九爱精品| 大骚逼91抽插出水视频| 超级av免费观看一区二区三区| 亚洲精品三级av在线免费观看| 这里只有精品双飞在线播放| 人妻少妇一区二区三区蜜桃| 9色精品视频在线观看| 欧美黑人性猛交xxxxⅹooo| 精品久久婷婷免费视频| 伊人综合免费在线视频| 亚洲精品 欧美日韩| 国产精品成久久久久三级蜜臀av| 久久农村老妇乱69系列| 在线观看免费岛国av| 国产乱弄免费视频观看| 大鸡巴操娇小玲珑的女孩逼| 国产午夜无码福利在线看| 欧美一区二区三区激情啪啪啪 | av线天堂在线观看| 国产三级片久久久久久久| 亚洲成人三级在线播放| 一区二区熟女人妻视频| 阿v天堂2014 一区亚洲| brazzers欧熟精品系列| 日韩精品中文字幕福利| av在线资源中文字幕| 免费黄页网站4188| 999久久久久999| 亚洲在线一区二区欧美| 11久久久久久久久久久| 午夜在线精品偷拍一区二| 超级碰碰在线视频免费观看| 黑人进入丰满少妇视频| 日韩欧美制服诱惑一区在线| 黄色资源视频网站日韩| 40道精品招牌菜特色| av森泽佳奈在线观看| 啪啪啪18禁一区二区三区| 少妇高潮无套内谢麻豆| 亚洲精品一区二区三区老狼| 国产午夜亚洲精品不卡在线观看| 亚洲精品在线资源站| 黄色视频成年人免费观看| 91久久综合男人天堂| 青青色国产视频在线| 激情伦理欧美日韩中文字幕| 91国内视频在线观看| 中出中文字幕在线观看| 人人超碰国字幕观看97| 国产精品久久久久久美女校花| 午夜dv内射一区区| 国产乱子伦精品视频潮优女| 色花堂在线av中文字幕九九| 国产亚洲视频在线二区| 精品人妻伦一二三区久| 中文字幕在线观看极品视频| 国产午夜无码福利在线看| 亚洲国产精品中文字幕网站| 国产亚洲欧美45p| 黄色大片免费观看网站| 2021最新热播中文字幕| 亚洲 欧美 自拍 偷拍 在线| 大骚逼91抽插出水视频| 精品一区二区三区欧美| 国产精品人妻熟女毛片av久| 大香蕉日本伊人中文在线| 国产又色又刺激在线视频| 男女之间激情网午夜在线| 亚洲av无码成人精品区辽| 国产密臀av一区二区三| 午夜精品一区二区三区福利视频| 久草电影免费在线观看| 最新91九色国产在线观看| 亚洲在线免费h观看网站| 绯色av蜜臀vs少妇| 欧美亚洲免费视频观看| 免费av岛国天堂网站| 成人av免费不卡在线观看| 国产精品国产三级国产精东| 一区二区三区久久中文字幕| 亚洲熟女久久久36d| 偷拍美女一区二区三区| 超黄超污网站在线观看| 91免费观看国产免费| 一区二区久久成人网| 亚洲在线一区二区欧美| 国产亚洲视频在线观看| 国产男女视频在线播放| 99精品久久久久久久91蜜桃| 精品av国产一区二区三区四区| 社区自拍揄拍尻屁你懂的| 在线免费观看靠比视频的网站| 中国视频一区二区三区| 国产又色又刺激在线视频| 91欧美在线免费观看| 91人妻人人做人人爽在线| 日韩av中文在线免费观看| 中文字幕网站你懂的| 国产欧美精品不卡在线| 精品人妻一二三区久久| 国产使劲操在线播放| 人人妻人人澡人人爽人人dvl| 真实国产乱子伦一区二区| av中文字幕福利网| av男人天堂狠狠干| 午夜美女福利小视频| 欧美精品国产综合久久| 超级福利视频在线观看| 久久免看30视频口爆视频| 成人伊人精品色xxxx视频| 国产白袜脚足J棉袜在线观看| 欧美日本在线视频一区| 亚洲熟女综合色一区二区三区四区| 成人H精品动漫在线无码播放| 亚洲va国产va欧美精品88| 亚洲天堂有码中文字幕视频| 成人高潮aa毛片免费| 久久久久久久精品老熟妇| 中文字幕在线视频一区二区三区| 色秀欧美视频第一页| av日韩在线免费播放| 91老师蜜桃臀大屁股| 中文字幕在线第一页成人| 中文字幕一区二区三区人妻大片 | 888亚洲欧美国产va在线播放| 日韩av大胆在线观看| 少妇系列一区二区三区视频| 可以免费看的www视频你懂的| 大鸡吧插逼逼视频免费看| 日韩中文字幕福利av| 天天色天天操天天舔| 免费高清自慰一区二区三区网站 | 人妻少妇一区二区三区蜜桃| 狠狠操狠狠操免费视频| 午夜青青草原网在线观看| www久久久久久久久久久| 欧美视频中文一区二区三区| 亚洲伊人av天堂有码在线| 精品国产污污免费网站入口自| 人妻丝袜榨强中文字幕| 亚洲国产精品中文字幕网站| 欧美另类z0z变态| 日本少妇高清视频xxxxx| 2022天天干天天操| 天天做天天爽夜夜做少妇| 狠狠的往里顶撞h百合| 国产乱子伦精品视频潮优女| 欧美亚洲国产成人免费在线| 色综合天天综合网国产成人| 视频 国产 精品 熟女 | 成人av久久精品一区二区| 和邻居少妇愉情中文字幕| 亚洲熟女女同志女同| 国产日本精品久久久久久久| 日韩精品中文字幕福利| 亚洲综合图片20p| 99热久久极品热亚洲| 日本av高清免费网站| 91色秘乱一区二区三区| 91久久人澡人人添人人爽乱| 只有精品亚洲视频在线观看| 亚洲 中文 自拍 另类 欧美| 国产精品大陆在线2019不卡| 久久久久久9999久久久久| 另类av十亚洲av| 五十路息与子猛烈交尾视频| 午夜影院在线观看视频羞羞羞| 免费无码人妻日韩精品一区二区 | 久草视频首页在线观看| 噜噜色噜噜噜久色超碰| 91国内精品久久久久精品一| 在线成人日韩av电影| 亚洲高清免费在线观看视频| 日本熟妇喷水xxx| 看一级特黄a大片日本片黑人| gav成人免费播放| 天堂资源网av中文字幕| 硬鸡巴动态操女人逼视频| 天天日天天干天天插舔舔| 自拍偷区二区三区麻豆| 人妻在线精品录音叫床| 操日韩美女视频在线免费看| 99久久激情婷婷综合五月天| 日本黄在免费看视频| 瑟瑟视频在线观看免费视频| 2020韩国午夜女主播在线| 亚洲熟女久久久36d| 久久久久久九九99精品| 亚洲的电影一区二区三区| 青草久久视频在线观看| 欧美黄色录像免费看的| 欧美日韩人妻久久精品高清国产| 亚洲欧美成人综合视频| 免费看高清av的网站| 青青青视频自偷自拍38碰| 日本三极片视频网站观看| 啊啊好大好爽啊啊操我啊啊视频| 高潮视频在线快速观看国家快速 | 家庭女教师中文字幕在线播放| 精品黑人一区二区三区久久国产| 夜鲁夜鲁狠鲁天天在线| 天天通天天透天天插| 国产精品国色综合久久| 91在线视频在线精品3| 亚洲国产精品久久久久久6| 揄拍成人国产精品免费看视频| 亚洲午夜精品小视频| av亚洲中文天堂字幕网| 岛国免费大片在线观看| 高清一区二区欧美系列| 巨乳人妻日下部加奈被邻居中出| 欧美偷拍亚洲一区二区| av天堂加勒比在线| 欧美xxx成人在线| 亚洲成高清a人片在线观看| 成年人午夜黄片视频资源| 欧美成人一二三在线网| 不卡精品视频在线观看| 少妇人妻久久久久视频黄片| 青青尤物在线观看视频网站| 国产精品一区二区av国| 大陆胖女人与丈夫操b国语高清 | 亚洲精品乱码久久久本| 国产精品视频一区在线播放| 夜色17s精品人妻熟女| 精品成人午夜免费看| 青娱乐最新视频在线| 国产精品精品精品999| 一个人免费在线观看ww视频| 精品国产成人亚洲午夜| av手机在线观播放网站| 亚洲av成人网在线观看| 曰本无码人妻丰满熟妇啪啪| 日本黄色三级高清视频| 亚洲一级美女啪啪啪| 75国产综合在线视频| 91香蕉成人app下载| 人妻少妇亚洲一区二区| 国产精品久久久黄网站| 91国产资源在线视频| 狠狠操操操操操操操操操| 国产精品久久久久久美女校花| 国产在线观看免费人成短视频| 红杏久久av人妻一区| 黄色黄色黄片78在线| 天天日天天干天天插舔舔| 青娱乐蜜桃臀av色| 午夜毛片不卡在线看| 97超碰人人搞人人| 最新黄色av网站在线观看| 国产精品人妻66p| 人妻av无码专区久久绿巨人 | 五十路在线观看完整版| 天堂av在线最新版在线| 女生被男生插的视频网站| 自拍偷拍亚洲欧美在线视频| 农村胖女人操逼视频| 中文字幕+中文字幕| 新97超碰在线观看| av天堂加勒比在线| 免费成人va在线观看| 成人免费公开视频无毒| aaa久久久久久久久| 久久精品久久精品亚洲人| 亚洲中文精品人人免费| 亚洲无线观看国产高清在线| 激情人妻校园春色亚洲欧美| 一区二区三区久久久91| 中文字幕视频一区二区在线观看| 国产亚洲精品欧洲在线观看| 蜜桃久久久久久久人妻| 中文字幕在线视频一区二区三区| 老司机免费视频网站在线看| 亚洲高清国产自产av| 中国视频一区二区三区| 免费观看污视频网站| 久久久久久9999久久久久| 亚洲精品亚洲人成在线导航| 视频 一区二区在线观看| 91精品视频在线观看免费| 青春草视频在线免费播放| 天天日天天日天天射天天干| 青青草国内在线视频精选| 91亚洲国产成人精品性色| 久久这里有免费精品| 91国产在线免费播放| 亚洲激情偷拍一区二区| 欧美一区二区三区四区性视频| 国产亚洲成人免费在线观看| 欧美日韩中文字幕欧美| 亚洲第一伊人天堂网| 中文字幕一区二 区二三区四区 | 福利视频网久久91| 女同久久精品秋霞网| av在线免费观看亚洲天堂| 欧美爆乳肉感大码在线观看| 亚洲中文字幕人妻一区| 亚洲av男人天堂久久| 国产综合精品久久久久蜜臀| 青青青青青操视频在线观看| 国产欧美精品不卡在线| 91麻豆精品秘密入口在线观看| 动漫美女的小穴视频| 人妻3p真实偷拍一二区| 最新国产精品网址在线观看| www日韩毛片av| 国产精品伦理片一区二区| 2021久久免费视频| 日本一本午夜在线播放| 国产使劲操在线播放| 亚洲一区二区三区偷拍女厕91| wwwxxx一级黄色片| 国产成人精品一区在线观看| 91社福利《在线观看| 2018在线福利视频| 大陆胖女人与丈夫操b国语高清| 国产熟妇一区二区三区av| 久久久久久9999久久久久| 亚洲av自拍偷拍综合| 青青草原色片网站在线观看| 国产精品日韩欧美一区二区| 91久久人澡人人添人人爽乱| 97人妻总资源视频| 狠狠鲁狠狠操天天晚上干干| 韩国男女黄色在线观看| 午夜精品九一唐人麻豆嫩草成人| 一区二区三区美女毛片| 亚洲欧美激情国产综合久久久| 999九九久久久精品| 一二三区在线观看视频| 亚洲欧美一区二区三区爱爱动图 | 久久精品美女免费视频| 欧美特级特黄a大片免费| 99精品视频之69精品视频| 免费观看丰满少妇做受| 久久久久久cao我的性感人妻| 五月婷婷在线观看视频免费 | 97a片免费在线观看| 黄色片黄色片wyaa| 沙月文乃人妻侵犯中文字幕在线| 不戴胸罩引我诱的隔壁的人妻| 午夜在线观看一区视频| 一区二区三区国产精选在线播放| 国产日韩一区二区在线看 | 97人人妻人人澡人人爽人人精品| 亚洲欧美成人综合在线观看| 欧亚日韩一区二区三区观看视频 | 日本xx片在线观看| 日本在线不卡免费视频| 亚洲精品一线二线在线观看| 大香蕉大香蕉在线看| 亚洲欧美日韩视频免费观看| 日韩中文字幕福利av| 天天日天天玩天天摸| 亚洲一区二区三区五区| 亚洲精品精品国产综合| 日本精品一区二区三区在线视频。 | 亚洲综合一区二区精品久久| 性欧美日本大妈母与子| 中字幕人妻熟女人妻a62v网 | 国产亚州色婷婷久久99精品| 欧美乱妇无乱码一区二区| 欧美日本在线观看一区二区| 日韩精品激情在线观看| 日韩欧美国产一区ab| 搡老熟女一区二区在线观看| av欧美网站在线观看| brazzers欧熟精品系列| 人妻熟女中文字幕aⅴ在线| 日韩欧美一级精品在线观看| 1000部国产精品成人观看视频| 国产在线拍揄自揄视频网站| 久久一区二区三区人妻欧美| 欧美亚洲偷拍自拍色图| 好了av中文字幕在线| 天天日天天做天天日天天做| 大香蕉福利在线观看| 天天日天天干天天爱| 国产精品黄色的av| 久久久久久国产精品| 视频一区 视频二区 视频| 97黄网站在线观看| 国产精品中文av在线播放| 视频二区在线视频观看| 亚洲图库另类图片区| 国产熟妇一区二区三区av| 777奇米久久精品一区| 中文人妻AV久久人妻水| 国产精品视频男人的天堂| 国产精品大陆在线2019不卡| 日韩午夜福利精品试看| 天天色天天操天天透| 91在线视频在线精品3| 青青青青青手机视频| 日本少妇的秘密免费视频| 日日夜夜精品一二三| 啪啪啪啪啪啪啪啪啪啪黄色| 亚洲少妇人妻无码精品| 又大又湿又爽又紧A视频| 少妇人妻100系列| 精品一区二区亚洲欧美| 亚洲av日韩av网站| 亚洲精品中文字幕下载| 日本www中文字幕| 综合精品久久久久97| 日本精品视频不卡一二三| 久久人人做人人妻人人玩精品vr| 九色porny九色9l自拍视频| 亚洲人妻av毛片在线| 午夜91一区二区三区| 丝袜美腿欧美另类 中文字幕| 91啪国自产中文字幕在线| 亚洲另类综合一区小说| 国产亚洲精品欧洲在线观看| 天天艹天天干天天操| 最新国产精品拍在线观看| 国产精品熟女久久久久浪潮| 欧美一区二区三区在线资源| 97香蕉碰碰人妻国产樱花| 久久久精品欧洲亚洲av| 高潮视频在线快速观看国家快速 | 91啪国自产中文字幕在线| 欧美国品一二三产区区别| 五十路熟女av天堂| 青青草人人妻人人妻| 中文字日产幕乱六区蜜桃| 亚洲激情偷拍一区二区| 青青草原色片网站在线观看| 国产精品一区二区三区蜜臀av| 亚洲1069综合男同| 人妻熟女在线一区二区| 性感美女福利视频网站| 首之国产AV医生和护士小芳| 黄色av网站免费在线| 午夜美女福利小视频| 经典亚洲伊人第一页| 日本黄色特一级视频| 中国黄片视频一区91| 久久人人做人人妻人人玩精品vr | 欧美国产亚洲中英文字幕| 精品成人啪啪18免费蜜臀| 偷拍自拍 中文字幕| 欧美日韩人妻久久精品高清国产| 超碰97人人做人人爱| 午夜激情高清在线观看| 午夜在线精品偷拍一区二| 亚洲激情唯美亚洲激情图片| 国产精品久久久久久久久福交 | 美女日逼视频免费观看| 欧美视频一区免费在线| 亚洲熟女久久久36d| 亚洲天堂精品久久久| 色哟哟在线网站入口| 免费观看理论片完整版| 免费十精品十国产网站| 国产精品亚洲在线观看| 可以免费看的www视频你懂的| 免费观看国产综合视频| 2021久久免费视频| 无码中文字幕波多野不卡| 欧美专区第八页一区在线播放 | 2022国产综合在线干| 国产大学生援交正在播放| 久久久久久久99精品| wwwxxx一级黄色片| 91麻豆精品传媒国产黄色片| 福利视频网久久91| 色伦色伦777国产精品| 欧美在线精品一区二区三区视频| 婷婷色国产黑丝少妇勾搭AV| 搞黄色在线免费观看| 欧美在线偷拍视频免费看| 一区二区三区 自拍偷拍| 久久午夜夜伦痒痒想咳嗽P| 中文字幕奴隷色的舞台50| 久久人人做人人妻人人玩精品vr| 91精品啪在线免费| 精彩视频99免费在线| 国产精品自偷自拍啪啪啪| 天堂av中文在线最新版| 大尺度激情四射网站| 青娱乐极品视频青青草| 国产一线二线三线的区别在哪| 97少妇精品在线观看| 狠狠地躁夜夜躁日日躁| 国内自拍第一页在线观看| 粉嫩小穴流水视频在线观看| 自拍偷拍亚洲另类色图| 欧美成人精品欧美一级黄色| 男人操女人的逼免费视频| 成熟丰满熟妇高潮xx×xx| 国产精品国产三级麻豆| 激情国产小视频在线| 亚洲蜜臀av一区二区三区九色| 亚洲成人线上免费视频观看| 亚洲丝袜老师诱惑在线观看| 精品美女在线观看视频在线观看| 日本www中文字幕| 国产精品一二三不卡带免费视频| 任你操视频免费在线观看| 成人蜜臀午夜久久一区| 国产揄拍高清国内精品对白| 男生舔女生逼逼的视频| 国产丰满熟女成人视频| 女生被男生插的视频网站| 亚洲成av人无码不卡影片一| 日本性感美女三级视频| 色综合色综合色综合色| 国产熟妇一区二区三区av| 久久久精品999精品日本| 丝袜长腿第一页在线| 一区二区三区美女毛片| 涩涩的视频在线观看视频| 在线观看免费视频网| 天美传媒mv视频在线观看| 任我爽精品视频在线播放| 蜜桃视频在线欧美一区| 福利视频一区二区三区筱慧| 午夜在线观看一区视频| 亚洲午夜伦理视频在线| 男人在床上插女人视频| 端庄人妻堕落挣扎沉沦| 成人H精品动漫在线无码播放| 男人靠女人的逼视频| 色呦呦视频在线观看视频| 9久在线视频只有精品| 青青擦在线视频国产在线| 男生舔女生逼逼的视频| 黄色录像鸡巴插进去| 三级黄色亚洲成人av| 亚洲乱码中文字幕在线| 我想看操逼黄色大片| 亚洲精品在线资源站| 99久久99一区二区三区| 色偷偷伊人大杳蕉综合网| 换爱交换乱高清大片| 亚洲免费福利一区二区三区| AV天堂一区二区免费试看| 亚洲激情,偷拍视频| 九色视频在线观看免费| 91国偷自产一区二区三区精品| 久久亚洲天堂中文对白| 国产女孩喷水在线观看| 亚洲精品无码色午夜福利理论片| 啊慢点鸡巴太大了啊舒服视频| 天天射夜夜操狠狠干| 国产在线拍揄自揄视频网站| 国产精品国产三级国产午| 久久这里有免费精品| 熟妇一区二区三区高清版| 丝袜长腿第一页在线| 欧美viboss性丰满| 日本五十路熟新垣里子| 中文字幕一区二 区二三区四区| 丝袜美腿视频诱惑亚洲无| 欧美精产国品一二三产品价格| 亚洲在线免费h观看网站| 亚洲 中文字幕在线 日韩| 久久99久久99精品影院| 91精品国产观看免费| 日本高清在线不卡一区二区| 欧美精品欧美极品欧美视频| 国产变态另类在线观看| 2022精品久久久久久中文字幕| 一个人免费在线观看ww视频| 日韩三级黄色片网站| 国产妇女自拍区在线观看| 中文字幕在线视频一区二区三区| 9久在线视频只有精品| 久久美欧人妻少妇一区二区三区| 最新91精品视频在线| 亚洲欧美成人综合在线观看| 最近的中文字幕在线mv视频| 免费无码人妻日韩精品一区二区| 欧美另类一区二区视频| 国产福利小视频二区| 欧美日韩精品永久免费网址| 亚洲人妻30pwc| 红杏久久av人妻一区| 国产极品美女久久久久久| 一区二区三区日韩久久| 操人妻嗷嗷叫视频一区二区| 午夜频道成人在线91| 国产麻豆剧传媒精品国产av蜜桃 | 免费福利av在线一区二区三区| 免费成人av中文字幕| 3344免费偷拍视频| 偷拍美女一区二区三区| 一区二区免费高清黄色视频| 国产精品久久综合久久| 晚上一个人看操B片| 国产亚洲成人免费在线观看| 天天操天天干天天日狠狠插| 自拍偷拍,中文字幕| 国产精品一二三不卡带免费视频| 国产亚洲视频在线二区| av在线观看网址av| 人人妻人人爱人人草| 国产一区二区三免费视频| 超碰在线观看免费在线观看| 欧美久久一区二区伊人| 久久久极品久久蜜桃| 人妻少妇亚洲精品中文字幕| 第一福利视频在线观看| 成人免费公开视频无毒| 亚洲另类在线免费观看| 久久久精品999精品日本 | 水蜜桃一区二区三区在线观看视频| 国产一区二区久久久裸臀| 91社福利《在线观看| 欧美va不卡视频在线观看| 4个黑人操素人视频网站精品91 | 经典国语激情内射视频| 日本丰满熟妇大屁股久久| 制丝袜业一区二区三区| 亚洲精品无码久久久久不卡| 懂色av蜜桃a v| 欧美成人综合色在线噜噜| 成熟丰满熟妇高潮xx×xx | 国产精品人妻66p| 亚洲精品国品乱码久久久久| 19一区二区三区在线播放| 日本一本午夜在线播放| 91自产国产精品视频| 都市激情校园春色狠狠| 亚洲乱码中文字幕在线| 欧美视频一区免费在线| 日本后入视频在线观看| 亚洲变态另类色图天堂网| 美女av色播在线播放| 日本一本午夜在线播放| 91九色porny国产在线| 91国产资源在线视频| 日本高清撒尿pissing| 社区自拍揄拍尻屁你懂的| 亚洲一区二区三区久久受| 青草久久视频在线观看| 亚洲 清纯 国产com| 91欧美在线免费观看| 伊人成人综合开心网| 国产精品久久久久久美女校花| 91九色porny蝌蚪国产成人| 久久久精品欧洲亚洲av| asmr福利视频在线观看| 夜女神免费福利视频| 亚洲成人黄色一区二区三区| 宅男噜噜噜666国产| 国产一级精品综合av| 熟女91pooyn熟女| 91中文字幕最新合集| 日韩a级精品一区二区| 国产a级毛久久久久精品| 国产熟妇人妻ⅹxxxx麻豆| 国产麻豆国语对白露脸剧情| 97人妻色免费视频| 91she九色精品国产| 国产亚洲精品视频合集| 狠狠鲁狠狠操天天晚上干干| 精品久久婷婷免费视频| 早川濑里奈av黑人番号| 秋霞午夜av福利经典影视| 国产视频网站国产视频| 黄色三级网站免费下载| 亚洲人妻30pwc| 2017亚洲男人天堂| 久草免费人妻视频在线| 57pao国产一区二区| 换爱交换乱高清大片| 岛国免费大片在线观看| 久久精品36亚洲精品束缚| 日本真人性生活视频免费看| 超级碰碰在线视频免费观看| 国产普通话插插视频| 国产高清精品极品美女| 男人操女人逼逼视频网站| 国产精品人妻一区二区三区网站| 欧美亚洲一二三区蜜臀| 在线观看成人国产电影| 久久麻豆亚洲精品av| 婷婷午夜国产精品久久久| 欧美精品免费aaaaaa| 91香蕉成人app下载| 亚洲欧美人精品高清| 韩国女主播精品视频网站| 韩国爱爱视频中文字幕| 精品国产在线手机在线| 少妇人妻二三区视频| 国产精品自拍在线视频| 天天躁日日躁狠狠躁av麻豆| 天天爽夜夜爽人人爽QC| 欧美精品亚洲精品日韩在线| 熟女视频一区,二区,三区| 97成人免费在线观看网站| 三级av中文字幕在线观看| 成人18禁网站在线播放| 中文字幕亚洲中文字幕| 久久国产精品精品美女| 免费在线观看污污视频网站| 老师啊太大了啊啊啊尻视频| 99精品视频之69精品视频| 黄网十四区丁香社区激情五月天| 久草视频首页在线观看| 婷婷激情四射在线观看视频| 大学生A级毛片免费视频| 精品国产乱码一区二区三区乱| 久久久精品999精品日本| 大鸡吧插逼逼视频免费看| 青青青青青操视频在线观看| 在线国产精品一区二区三区| 日日摸夜夜添夜夜添毛片性色av| 亚洲国产欧美一区二区三区久久| 91色秘乱一区二区三区| 亚洲熟妇无码一区二区三区| asmr福利视频在线观看| 久久精品36亚洲精品束缚| 100%美女蜜桃视频| 最近的中文字幕在线mv视频| 五月天久久激情视频| 午夜精品久久久久久99热| 国产麻豆乱子伦午夜视频观看| 北条麻妃av在线免费观看| 青青青激情在线观看视频| 九一传媒制片厂视频在线免费观看 | 国产在线免费观看成人| 国产黄色片蝌蚪九色91| 三级黄色亚洲成人av| 国产黄色a级三级三级三级| 蜜桃视频在线欧美一区| 偷拍自拍福利视频在线观看| 91人妻精品久久久久久久网站| 天天干天天啪天天舔| 三级黄色亚洲成人av| 日本午夜福利免费视频| 亚洲Av无码国产综合色区| 欧美激情电影免费在线| 国产高清在线在线视频| 中文字幕中文字幕 亚洲国产| 性欧美激情久久久久久久| 绝色少妇高潮3在线观看| 2018在线福利视频| h国产小视频福利在线观看| 成人福利视频免费在线| 国产伊人免费在线播放| 日韩欧美高清免费在线| 懂色av蜜桃a v| 51精品视频免费在线观看| 日韩成人性色生活片| 亚洲欧美一区二区三区爱爱动图 | 18禁美女无遮挡免费| 一区二区三区另类在线 | 亚洲中文字幕乱码区| 91人妻人人做人人爽在线| 国产午夜激情福利小视频在线| 国产日韩欧美美利坚蜜臀懂色| 日日日日日日日日夜夜夜夜夜夜| 国产成人小视频在线观看无遮挡 | 国产丰满熟女成人视频| 香蕉aⅴ一区二区三区| 欧美精品黑人性xxxx| 超黄超污网站在线观看| 初美沙希中文字幕在线| 亚洲专区激情在线观看视频| 青青热久免费精品视频在线观看| 色综合色综合色综合色| 日韩精品二区一区久久| 欧美日本国产自视大全| 欧美性感尤物人妻在线免费看| 欧美色呦呦最新网址| 好吊视频—区二区三区| 黑人巨大的吊bdsm| 亚洲成人精品女人久久久| 亚洲欧美色一区二区| 国产精品久久久久网| 日韩中文字幕精品淫| 中国无遮挡白丝袜二区精品| 国产精品成久久久久三级蜜臀av| 直接观看免费黄网站| jiujiure精品视频在线| 亚洲精品成人网久久久久久小说| 国内自拍第一页在线观看| 天天干夜夜操天天舔| 天天通天天透天天插| 亚洲精品乱码久久久本| 五十路熟女人妻一区二| 国产美女精品福利在线| 欧美偷拍自拍色图片| 国产成人精品久久二区91| 曰本无码人妻丰满熟妇啪啪| nagger可以指黑人吗| 最新97国产在线视频| 婷婷激情四射在线观看视频| 免费在线黄色观看网站| 不卡一不卡二不卡三| 中文字幕一区二区亚洲一区| asmr福利视频在线观看| 97人妻总资源视频| 国产综合高清在线观看| 国产日韩精品电影7777| 精品黑人一区二区三区久久国产| 黄色资源视频网站日韩| 日本中文字幕一二区视频| 国产乱子伦精品视频潮优女| 欧美另类z0z变态| 唐人色亚洲av嫩草| 亚洲国产中文字幕啊啊啊不行了| 中字幕人妻熟女人妻a62v网| 最新97国产在线视频| 天天干天天操天天摸天天射| 高潮喷水在线视频观看| 久久精品视频一区二区三区四区| 经典av尤物一区二区| 久久久精品国产亚洲AV一| 免费十精品十国产网站| 蜜桃久久久久久久人妻| 国产精品久久久久久久久福交| 91在线免费观看成人| 亚洲精品ww久久久久久| 亚洲熟色妇av日韩熟色妇在线| av天堂加勒比在线| 国产不卡av在线免费| 亚洲欧美激情人妻偷拍| 天天干夜夜操啊啊啊| 超碰公开大香蕉97| 欧美中文字幕一区最新网址| 超污视频在线观看污污污| 92福利视频午夜1000看| 精品黑人一区二区三区久久国产 | 亚洲色偷偷综合亚洲AV伊人| 大香蕉日本伊人中文在线| 人妻无码色噜噜狠狠狠狠色| 91亚洲手机在线视频播放| 中文字幕奴隷色的舞台50| av网址国产在线观看| 亚洲成人av一区在线| 亚洲一区二区三区在线高清 | 青青草原色片网站在线观看| 日本免费午夜视频网站| 中文字幕免费福利视频6| 大黑人性xxxxbbbb| 中文字幕在线观看国产片| 888欧美视频在线| 亚洲免费国产在线日韩| 亚洲一区二区三区久久午夜| mm131美女午夜爽爽爽| 老有所依在线观看完整版| 日本韩国免费一区二区三区视频| 国产乱子伦一二三区| 国产chinesehd精品麻豆| 欧美亚洲国产成人免费在线| 日本欧美视频在线观看三区| 精品视频中文字幕在线播放| gay gay男男瑟瑟在线网站| 扒开腿挺进肉嫩小18禁视频| 精品一线二线三线日本| 亚洲精品 欧美日韩| 蜜臀av久久久久蜜臀av麻豆| 夜夜操,天天操,狠狠操| 激情五月婷婷免费视频| 白嫩白嫩美女极品国产在线观看| 国产污污污污网站在线| 91综合久久亚洲综合| 大鸡吧插逼逼视频免费看 | 97精品综合久久在线| 国产之丝袜脚在线一区二区三区| av在线观看网址av| 一级a看免费观看网站| 无忧传媒在线观看视频| 中文字幕免费在线免费| 天天操天天干天天日狠狠插| 97a片免费在线观看| 亚洲专区激情在线观看视频| 91av中文视频在线| 日韩美女福利视频网| 日日操综合成人av| 欧美日韩亚洲国产无线码| 国产第一美女一区二区三区四区| 成人乱码一区二区三区av| 精品国产乱码一区二区三区乱| 唐人色亚洲av嫩草| 大白屁股精品视频国产| 亚洲图片偷拍自拍区| 熟女国产一区亚洲中文字幕| 天天操,天天干,天天射| 特大黑人巨大xxxx| 91老师蜜桃臀大屁股| 91色秘乱一区二区三区| 精品高潮呻吟久久av| 天天艹天天干天天操| 日本一区二区三区免费小视频| 99国产精品窥熟女精品| 粉嫩av蜜乳av蜜臀| 自拍偷拍 国产资源| 久久久91蜜桃精品ad| 成年人中文字幕在线观看| 欧美成一区二区三区四区| 看一级特黄a大片日本片黑人| 亚洲综合在线视频可播放| 日韩欧美国产一区ab| 中文字幕在线一区精品| 日本熟女50视频免费| 久久久久国产成人精品亚洲午夜| 51精品视频免费在线观看| 老熟妇xxxhd老熟女| 日本中文字幕一二区视频| 欧美成人小视频在线免费看| 爆乳骚货内射骚货内射在线| 在线制服丝袜中文字幕| 亚洲va国产va欧美精品88| 国产+亚洲+欧美+另类| 11久久久久久久久久久| 精品美女在线观看视频在线观看| 福利片区一区二体验区| av成人在线观看一区| 538精品在线观看视频| 成人在线欧美日韩国产| 青青青视频自偷自拍38碰| 国产av国片精品一区二区| 最新中文字幕免费视频| 夏目彩春在线中文字幕| 天堂av在线最新版在线| 亚洲精品ww久久久久久| 国产一区二区久久久裸臀| 亚洲国产欧美一区二区三区久久| 欧美黄色录像免费看的| 欧美亚洲中文字幕一区二区三区 | 亚洲天天干 夜夜操| 久久久久久cao我的性感人妻 | 亚洲 中文 自拍 另类 欧美| 黄色无码鸡吧操逼视频| 亚洲国产最大av综合| 欧美日本在线视频一区| 日本免费午夜视频网站| 国产成人小视频在线观看无遮挡| 国产亚洲国产av网站在线| 天天做天天干天天操天天射| 日韩欧美国产一区ab| 精品91自产拍在线观看一区| 综合国产成人在线观看| 免费无码人妻日韩精品一区二区 | 久草视频 久草视频2| 中文字幕人妻三级在线观看| 国产精品亚洲在线观看| 激情啪啪啪啪一区二区三区 | 成人乱码一区二区三区av| 国产女人露脸高潮对白视频| 人妻激情图片视频小说| 人妻爱爱 中文字幕| 亚洲免费视频欧洲免费视频| 亚洲av自拍偷拍综合| 1024久久国产精品| 天天操夜夜操天天操天天操| 色综合久久久久久久久中文| 肏插流水妹子在线乐播下载| 大香蕉伊人国产在线| 亚洲av日韩精品久久久| 亚洲免费在线视频网站| 国产第一美女一区二区三区四区| gay gay男男瑟瑟在线网站| 久草福利电影在线观看| 无码精品一区二区三区人| 沈阳熟妇28厘米大战黑人| 亚洲欧美另类自拍偷拍色图| 11久久久久久久久久久| 国产日韩精品一二三区久久久| 中文字幕日韩人妻在线三区| 一级黄片大鸡巴插入美女| 大鸡巴插入美女黑黑的阴毛| 亚洲综合图片20p| 欧洲亚洲欧美日韩综合| 色av色婷婷人妻久久久精品高清| 日韩欧美一级aa大片| 日本免费一级黄色录像 | 国产日韩一区二区在线看| 九色porny九色9l自拍视频| 喷水视频在线观看这里只有精品| 亚洲精品精品国产综合| 亚洲高清国产拍青青草原| 国产精品一二三不卡带免费视频| 亚洲激情唯美亚洲激情图片| 最近的中文字幕在线mv视频| 美味人妻2在线播放| 成人福利视频免费在线| 大胸性感美女羞爽操逼毛片| 国产精品视频欧美一区二区| 白嫩白嫩美女极品国产在线观看| 亚洲乱码中文字幕在线| 国产性色生活片毛片春晓精品| 日韩av有码一区二区三区4| 天天干天天日天天谢综合156| 精品美女在线观看视频在线观看| 在线可以看的视频你懂的| 亚洲 国产 成人 在线| av森泽佳奈在线观看| 91国内视频在线观看| 国产麻豆国语对白露脸剧情 | 午夜在线精品偷拍一区二| 五十路人妻熟女av一区二区| 57pao国产一区二区| 亚洲午夜高清在线观看| 福利视频一区二区三区筱慧| 88成人免费av网站| 专门看国产熟妇的网站| 亚洲中文字幕乱码区| 亚洲一级特黄特黄黄色录像片| 亚洲av香蕉一区区二区三区犇| av在线shipin| 黑人解禁人妻叶爱071| 成人av久久精品一区二区| 97人妻无码AV碰碰视频| 亚洲成人av一区在线| 99的爱精品免费视频| 色呦呦视频在线观看视频| 欧美日韩国产一区二区三区三州| 91精品国产观看免费| 91国产资源在线视频| 亚洲图片欧美校园春色| sspd152中文字幕在线| 国产午夜亚洲精品麻豆| 天天日天天玩天天摸| 性感美女福利视频网站| 97人妻无码AV碰碰视频| 日本熟女精品一区二区三区| 日韩精品一区二区三区在线播放| 白嫩白嫩美女极品国产在线观看| 人妻久久无码中文成人| 国产免费高清视频视频| 女生被男生插的视频网站| 高清一区二区欧美系列| 18禁美女黄网站色大片下载| 国产真实灌醉下药美女av福利| 亚洲一级特黄特黄黄色录像片| 深夜男人福利在线观看| 亚洲av香蕉一区区二区三区犇| 国产亚洲视频在线二区| 国产aⅴ一线在线观看| 亚洲免费成人a v| 中文字幕av一区在线观看| 亚洲成人免费看电影| 亚洲精品无码色午夜福利理论片| 成人30分钟免费视频| 亚洲精品福利网站图片| 日本人妻欲求不满中文字幕| 播放日本一区二区三区电影| 亚洲av成人免费网站| 青青青青草手机在线视频免费看| 99热久久极品热亚洲| 亚洲天天干 夜夜操| tube69日本少妇| 一区二区三区激情在线| 亚洲高清国产自产av| 国产日韩一区二区在线看| 亚洲 中文 自拍 无码| 欧美中国日韩久久精品| 91‖亚洲‖国产熟女| 色婷婷久久久久swag精品| 国产a级毛久久久久精品| 在线亚洲天堂色播av电影| av天堂中文免费在线| 天堂中文字幕翔田av| 婷婷五月亚洲综合在线| 三级av中文字幕在线观看| 97超碰最新免费在线观看| 天天操天天爽天天干| 国产精品国色综合久久| 中英文字幕av一区| 日韩三级电影华丽的外出| 午夜久久香蕉电影网| 成人资源在线观看免费官网| 国产av福利网址大全| 白白操白白色在线免费视频| 中文字幕日韩人妻在线三区| 欧美香蕉人妻精品一区二区| 日韩欧美制服诱惑一区在线| 欧美一区二区三区高清不卡tv| 亚洲高清视频在线不卡| 黑人巨大的吊bdsm| 啊啊好大好爽啊啊操我啊啊视频| 亚洲国产欧美一区二区三区…| 啊用力插好舒服视频| 日韩美女精品视频在线观看网站| 国产va精品免费观看| 少妇高潮一区二区三区| 3337p日本欧洲大胆色噜噜| 一个人免费在线观看ww视频| 搡老熟女一区二区在线观看| 亚洲日产av一区二区在线| 亚洲天堂有码中文字幕视频| 天天日天天玩天天摸| 自拍偷拍亚洲精品第2页| 五十路av熟女松本翔子| 午夜美女少妇福利视频| 久久精品国产999| 欧美区一区二区三视频| 亚洲人成精品久久久久久久| 99国产精品窥熟女精品| 免费无码人妻日韩精品一区二区| 91九色porny国产在线| 一区二区久久成人网| 中文字幕日韩91人妻在线| 天天日天天添天天爽| 精品老妇女久久9g国产| 91亚洲精品干熟女蜜桃频道 | 午夜精品一区二区三区城中村| 一色桃子久久精品亚洲| 丝袜国产专区在线观看| 国产精品自拍视频大全| 亚洲精品国产久久久久久| 久久精品久久精品亚洲人| 亚洲一区二区三区久久午夜 | 成人高清在线观看视频| 超碰公开大香蕉97| 国产日本欧美亚洲精品视| 黄色的网站在线免费看| 国产视频网站一区二区三区| 亚洲综合自拍视频一区| 午夜精品一区二区三区4| 日韩在线视频观看有码在线| 欧美黑人与人妻精品| 亚洲2021av天堂| 夜夜躁狠狠躁日日躁麻豆内射 | 99精品视频之69精品视频| av亚洲中文天堂字幕网| 狍和女人的王色毛片| 亚洲欧美日韩视频免费观看| 国产亚洲视频在线二区| 亚洲国产成人无码麻豆艾秋| 亚洲在线观看中文字幕av| 国产97在线视频观看| 亚洲青青操骚货在线视频| 五十路熟女av天堂| 免费黄页网站4188| 美女骚逼日出水来了| 亚洲欧美日韩视频免费观看| 国产久久久精品毛片| 国产三级片久久久久久久| 日本少妇高清视频xxxxx | 免费在线观看污污视频网站| 好了av中文字幕在线| 久久久久91精品推荐99| 青青擦在线视频国产在线| 白嫩白嫩美女极品国产在线观看| 视频一区 二区 三区 综合| 国产又色又刺激在线视频| 国产午夜男女爽爽爽爽爽视频| 最新国产精品网址在线观看| 亚洲午夜精品小视频| 国内精品在线播放第一页| 欧洲日韩亚洲一区二区三区| 91久久人澡人人添人人爽乱| 日本熟妇一区二区x x| 中文字幕在线免费第一页| 91精品免费久久久久久| 亚洲人一区二区中文字幕| 揄拍成人国产精品免费看视频| 夜夜嗨av蜜臀av| 春色激情网欧美成人| 天天日天天鲁天天操| 亚洲va国产va欧美va在线| 亚洲va国产va欧美va在线| 国产不卡av在线免费| 日本韩国免费一区二区三区视频| 都市激情校园春色狠狠| 亚洲av成人网在线观看| 97人妻色免费视频| 国产夫妻视频在线观看免费| 中文字幕一区二区三区蜜月 | 国产视频网站国产视频| tube69日本少妇| 人人爱人人妻人人澡39| 亚洲国产成人最新资源| 熟女少妇激情五十路| 91快播视频在线观看| 大黑人性xxxxbbbb| 日韩三级黄色片网站| 老司机午夜精品视频资源| 精品一区二区三区欧美| 国产视频精品资源网站| 亚洲av极品精品在线观看| 亚洲国产40页第21页| 天天日夜夜干天天操| 玖玖一区二区在线观看| 91大神福利视频网| 2018最新中文字幕在线观看| 同居了嫂子在线播高清中文| 国产实拍勾搭女技师av在线| 天干天天天色天天日天天射| 亚洲日产av一区二区在线| 美味人妻2在线播放| 亚洲欧美一区二区三区爱爱动图| 国产在线拍揄自揄视频网站| 久久久久五月天丁香社区| 韩国三级aaaaa高清视频| 精品国产污污免费网站入口自| 久久久久久99国产精品| 中文字幕高清在线免费播放| 制丝袜业一区二区三区| 国产精彩福利精品视频| 97人妻色免费视频| 一区二区麻豆传媒黄片| 国产精品人妻熟女毛片av久| 日本特级片中文字幕| 国产91嫩草久久成人在线视频| 中文字幕奴隷色的舞台50| 国产黄色高清资源在线免费观看| 日本www中文字幕| 综合精品久久久久97| 搡老妇人老女人老熟女| 亚洲高清视频在线不卡| 国产97在线视频观看| 91中文字幕最新合集| 成人免费毛片aaaa| 国产在线免费观看成人| 亚洲熟色妇av日韩熟色妇在线| 亚洲av成人免费网站| 护士特殊服务久久久久久久| 一区二区三区精品日本| 色狠狠av线不卡香蕉一区二区| 国产又粗又猛又爽又黄的视频在线| jiujiure精品视频在线| 久草视频首页在线观看| 中国老熟女偷拍第一页| 久久久精品欧洲亚洲av| 精品一区二区三区在线观看| 黄色男人的天堂视频| 97国产精品97久久| av一本二本在线观看| 国产美女午夜福利久久| 蜜桃视频17c在线一区二区| 青青草成人福利电影| 中出中文字幕在线观看| 国产一区成人在线观看视频 | 性欧美日本大妈母与子| 性感美女高潮视频久久久| 青青草原网站在线观看| 精品一区二区三区在线观看| av无限看熟女人妻另类av| 午夜场射精嗯嗯啊啊视频| 亚洲综合乱码一区二区| 91九色国产熟女一区二区| 日韩美女综合中文字幕pp| 国产又色又刺激在线视频| 国产日韩av一区二区在线| 亚洲高清一区二区三区视频在线| 孕妇奶水仑乱A级毛片免费看 | 欧美aa一级一区三区四区| 91色网站免费在线观看| 亚洲精品 日韩电影| 国产白袜脚足J棉袜在线观看| 欧美亚洲自偷自拍 在线| 高潮喷水在线视频观看| 2021年国产精品自拍| 女人精品内射国产99| 免费无码人妻日韩精品一区二区 | 岛国黄色大片在线观看| 男女啪啪啪啪啪的网站| 日噜噜噜夜夜噜噜噜天天噜噜噜| 色吉吉影音天天干天天操| 亚洲蜜臀av一区二区三区九色| 高清一区二区欧美系列| 国产第一美女一区二区三区四区| 久草视频在线看免费| 中文字日产幕乱六区蜜桃| 亚洲av日韩av第一区二区三区| 在线播放一区二区三区Av无码| 中文字幕在线一区精品| 91色九色porny| 国产在线免费观看成人| 亚洲成人精品女人久久久| 国产成人午夜精品福利| 沙月文乃人妻侵犯中文字幕在线| 日韩av有码一区二区三区4| 日韩欧美亚洲熟女人妻| 亚洲一区二区三区精品乱码| 中文 成人 在线 视频| 国产精品久久久久网| 视频一区二区三区高清在线| 最近中文字幕国产在线| 精品亚洲在线免费观看| 98精产国品一二三产区区别| 护士特殊服务久久久久久久| 亚洲一区二区三区久久午夜| 最新欧美一二三视频| 9久在线视频只有精品| 日噜噜噜夜夜噜噜噜天天噜噜噜| 亚洲一级美女啪啪啪| 直接能看的国产av| 高潮喷水在线视频观看| 这里只有精品双飞在线播放| 青青青aaaa免费| 成年人午夜黄片视频资源| 日本性感美女写真视频| 不戴胸罩引我诱的隔壁的人妻| 一区二区三区四区中文| 午夜dv内射一区区| 六月婷婷激情一区二区三区| 年轻的人妻被夫上司侵犯| 91成人精品亚洲国产| av成人在线观看一区| 黑人变态深video特大巨大| 40道精品招牌菜特色| 久久热久久视频在线观看| 国产成人精品一区在线观看| 扒开让我视频在线观看| 白白操白白色在线免费视频| 好吊视频—区二区三区| 国产精品久久久久久久久福交 | 4个黑人操素人视频网站精品91| 亚洲免费va在线播放| 日韩欧美亚洲熟女人妻| 欧亚乱色一区二区三区| 馒头大胆亚洲一区二区| 夜色撩人久久7777| 天干天天天色天天日天天射| 不卡一区一区三区在线| 无码精品一区二区三区人| 亚洲欧美国产麻豆综合| 一本久久精品一区二区| 欧美成人小视频在线免费看 | 青娱乐蜜桃臀av色| 亚洲综合另类精品小说| 日日操夜夜撸天天干| 夜夜躁狠狠躁日日躁麻豆内射 | 92福利视频午夜1000看| 亚洲区欧美区另类最新章节| 亚洲av成人网在线观看| av欧美网站在线观看| 久久美欧人妻少妇一区二区三区| 日韩少妇人妻精品无码专区| 97a片免费在线观看| 小穴多水久久精品免费看| 精品久久久久久久久久久久人妻| 97瑟瑟超碰在线香蕉| 亚洲成人熟妇一区二区三区| 国产日本精品久久久久久久| 亚洲成人三级在线播放| 色吉吉影音天天干天天操| 日韩人妻在线视频免费| 久久久超爽一二三av| 亚洲黄色av网站免费播放| 人妻另类专区欧美制服| 亚洲 图片 欧美 图片| aaa久久久久久久久| 亚洲高清免费在线观看视频| 超碰在线观看免费在线观看| 国产精品大陆在线2019不卡| 欧美精品国产综合久久| 瑟瑟视频在线观看免费视频| 2019av在线视频| 亚洲高清国产自产av| av在线播放国产不卡| 18禁精品网站久久| 激情国产小视频在线| 天堂av在线最新版在线| 国产午夜亚洲精品不卡在线观看| 都市家庭人妻激情自拍视频| 日本免费一级黄色录像 | 日本脱亚入欧是指什么| 日韩成人免费电影二区| 欧美亚洲一二三区蜜臀| 一区二区三区 自拍偷拍| 九色porny九色9l自拍视频| 性生活第二下硬不起来| 99久久中文字幕一本人| 久久h视频在线观看| 美女操逼免费短视频下载链接| 啪啪啪操人视频在线播放| 成人av天堂丝袜在线观看| 超碰在线中文字幕一区二区| 日韩无码国产精品强奸乱伦| 亚洲公开视频在线观看| 哥哥姐姐综合激情小说| 天堂v男人视频在线观看| 天天干夜夜操啊啊啊| 老鸭窝在线观看一区| 亚洲国产最大av综合| 欧美日韩人妻久久精品高清国产 | 久久久麻豆精亚洲av麻花| 人妻丝袜精品中文字幕| 在线免费观看99视频| 国产熟妇人妻ⅹxxxx麻豆| 成年人午夜黄片视频资源| 美女操逼免费短视频下载链接| 中国熟女@视频91| 精品国产成人亚洲午夜| 国产一线二线三线的区别在哪| 亚洲av黄色在线网站| 久久美欧人妻少妇一区二区三区| 日本午夜福利免费视频| 成人福利视频免费在线| 成年人黄色片免费网站| 扒开腿挺进肉嫩小18禁视频| 天天射夜夜操狠狠干| 日韩精品二区一区久久| 婷婷激情四射在线观看视频| 欧洲国产成人精品91铁牛tv| 亚洲在线一区二区欧美| 男人插女人视频网站| 色吉吉影音天天干天天操| 国产高清在线在线视频| 亚洲福利精品福利精品福利| 天天日天天干天天要| 免费看国产av网站| 91亚洲精品干熟女蜜桃频道| 国产精品女邻居小骚货| 强行扒开双腿猛烈进入免费版| 亚洲超碰97人人做人人爱| 亚洲 自拍 色综合图| 含骚鸡巴玩逼逼视频| 日韩精品中文字幕播放| 国产欧美精品免费观看视频| 日本三极片视频网站观看| 欧美精品中文字幕久久二区| 中文字幕一区二 区二三区四区| 美日韩在线视频免费看| 青青草在观免费国产精品| 好太好爽好想要免费| 国产成人自拍视频播放| 人人妻人人爽人人澡人人精品| av一本二本在线观看| 久久久久五月天丁香社区| 色综合久久无码中文字幕波多| 孕妇奶水仑乱A级毛片免费看| 青青青青青青青在线播放视频 | 国产日韩欧美视频在线导航| 一级黄片久久久久久久久| 亚洲成人精品女人久久久| 亚洲国产精品久久久久久6| 天天色天天爱天天爽| 日本a级视频老女人| 国产av一区2区3区| 午夜激情精品福利视频| 日本美女成人在线视频| 又色又爽又黄的美女裸体| 日韩精品一区二区三区在线播放| 沙月文乃人妻侵犯中文字幕在线|