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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

Xorm学习笔记

發布時間:2024/3/24 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Xorm学习笔记 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

與你相識


博主介紹:

– 本人是普通大學生一枚,每天鉆研計算機技能,CSDN主要分享一些技術內容,因我常常去尋找資料,不經常能找到合適的,精品的,全面的內容,導致我花費了大量的時間,所以會將摸索的內容全面細致記錄下來。另外,我更多關于管理,生活的思考會在簡書中發布,如果你想了解我對生活有哪些反思,探索,以及對管理或為人處世經驗的總結,我也歡迎你來找我。

– 目前的學習專注于Go語言,輔學算法,前端領域。也會分享一些校內課程的學習,例如數據結構,計算機組成原理等等,如果你喜歡我的風格,請關注我,我們一起成長。


Table of Contents

  • XORM學習筆記
    • 對xorm的說明
      • 安裝
    • 創建orm引擎
    • 定義表的結構體
      • 統一前綴,后綴
      • Column屬性
    • 表結構操作
      • 獲取數據庫表結構信息
      • 表操作
      • 同步數據庫結構
      • 導入導出sql腳本
    • 插入數據
      • 使用xorm api來插入數據
      • 使用SQL命令來插入數據
        • 第1種方式
        • 第2種方式
        • 第3種方式
        • 第4種方式
    • 創建時間Created
    • 查詢和統計數據
      • ORM方式查詢和統計數據
    • 更新數據
      • update方法
      • 樂觀鎖
      • 更新時間
      • 通過sql命令更新數據
        • 第1種方式
        • 第2種方式
        • 第3種方式
        • 第4種方式
    • 刪除數據
      • Delete方法
      • 軟刪除 Deleted
      • 通過sql語句刪除數據
        • 第1種方式
        • 第2種方式
        • 第3種方式
        • 第4種方式
    • 事務
      • 簡單事務使用
      • 嵌套事務使用
    • 數據導出
      • 查詢結果集導出csv、tsv、xml、json、xlsx、yaml、html
      • 多查詢集導出到單一文件
    • 連接池
    • 參考資料


XORM學習筆記

我直接看的官方說明文檔。

對xorm的說明

我現在所看的xorm庫,是基于原版xorm庫的定制增強版。

這是因為本定制版有第三方庫依賴,而就是為了維持原版xorm對第三方庫零依賴性,所以單獨開了一個定制增強版本的xorm庫。

相關核心功能和原版xorm一致并隨原版xorm更新。

安裝

go get -u github.com/xormplus/xorm

創建orm引擎

xorm可以同時存在多個orm引擎,一個orm引擎稱為Engine,一個Engine一般只對應一個數據庫。

Engine通過調用xorm.NewEngine生成。

import (_ "github.com/go-sql-driver/mysql""github.com/xormplus/xorm" )var engine *xorm.Enginefunc main() {var err errorengine, err = xorm.NewEngine("mysql", "root:123@/test?charset=utf8") }

engine可以通過engine.Close來手動關閉,但是一般情況下可以不用關閉,在程序退出的時候會自動關閉。

在engine創建完成之后可以設置一些選項:

日志是一個接口,通過設置日志,可以顯示SQL,警告以及錯誤等,默認的顯示級別為INFO。

  • engine.ShowSQL(true),則會在控制臺打印出生成的SQL語句;
  • engine.Logger().SetLevel(core.LOG_DEBUG),則會在控制臺打印調試及以上的信息;

如果希望將信息不僅打印到控制臺,而是保存為文件,那么可以通過類似如下的代碼實現,NewSimpleLogger(w io.Writer)接收一個io.Writer接口來將數據寫入到對應的設施中。

f, err := os.Create("sql.log") if err != nil {println(err.Error())return } engine.SetLogger(xorm.NewSimpleLogger(f))

定義表的結構體

統一前綴,后綴

可以通過一種方式在表的字段前加上統一的前綴,后綴或緩存映射,但是表字段不會改變。

// 統一前綴 tbMapper := core.NewPrefixMapper(core.SnakeMapper{}, "prefix_") engine.SetTableMapper(tbMapper) // 統一后綴 ore.NewSufffixMapper(core.SnakeMapper{}, "suffix")

Column屬性

可以在列中對Column的一些屬性進行定義

type User struct {Id int64Name string `xorm:"varchar(25) notnull unique 'usr_name'"` }

還有很多其它的內容,參考官方操作手冊。

表結構操作

獲取數據庫表結構信息

  • DBMetas()
    xorm支持獲取表結構信息,通過調用engine.DBMetas()可以獲取到數據庫中所有的表,字段,索引的信息。

表操作

  • CreateTables()

創建表使用engine.CreateTables(),參數為一個或多個空的對應Struct的指針。同時可用的方法有Charset()和StoreEngine(),如果對應的數據庫支持,這兩個方法可以在創建表時指定表的字符編碼和使用的引擎。Charset()和StoreEngine()當前僅支持Mysql數據庫。

  • IsTableEmpty()

判斷表是否為空,參數和CreateTables相同

  • IsTableExist()

判斷表是否存在

  • DropTables()

刪除表使用engine.DropTables(),參數為一個或多個空的對應Struct的指針或者表的名字。如果為string傳入,則只刪除對應的表,如果傳入的為Struct,則刪除表的同時還會刪除對應的索引。

同步數據庫結構

同步能夠部分智能的根據結構體的變動檢測表結構的變動,并自動同步。目前有兩個實現:

Sync


Sync將進行如下的同步操作:

  • 自動檢測和創建表,這個檢測是根據表的名字
  • 自動檢測和新增表中的字段,這個檢測是根據字段名
  • 自動檢測和創建索引和唯一索引,這個檢測是根據索引的一個或多個字段名,而不根據索引名稱
err := engine.Sync(new(User), new(Group))

Sync2


對sync進行了改進,目前推薦使用。

下面的警告信息需要將engine.ShowWarn設置為true才會實現

  • 自動檢測和創建表,這個檢測是根據表的名字
  • 自動檢測和新增表中的字段,這個檢測是根據字段名,同時對表中多余的字段給出警告信息
  • 自動檢測,創建和刪除索引和唯一索引,這個檢測是根據索引的一個或多個字段名,而不根據索引名稱。因此這里需要注意,如果在一個有大量數據的表中引入新的索引,數據庫可能需要一定的時間來建立索引。
  • 自動轉換varchar字段類型到text字段類型,自動警告其它字段類型在模型和數據庫之間不一致的情況。
  • 自動警告字段的默認值,是否為空信息在模型和數據庫之間不匹配的情況
err := engine.Sync2(new(User), new(Group))

導入導出sql腳本

導入:

如果你需要將保存在文件或者其它存儲設施中的SQL腳本執行,那么可以調用

engine.Import(r io.Reader)

engine.ImportFile(fpath string)

導出:

如果需要在程序中Dump數據庫的結構和數據可以調用

engine.DumpAll(w io.Writer)

engine.DumpAllFile(fpath string)

DumpAll方法接收一個io.Writer接口來保存Dump出的數據庫結構和數據的SQL語句,這個方法導出的SQL語句并不能通用。只針對當前engine所對應的數據庫支持的SQL。

插入數據

使用xorm api來插入數據

使用Insert或InsertOne來插入數據

user := new(User) user.Name = "myname" affected, err := engine.Insert(user) // INSERT INTO user (name) values (?)
  • 批量插入會自動生成Insert into table values (),(),()的語句,因此各個數據庫對SQL語句有長度限制,因此這樣的語句有一個最大的記錄數,根據經驗測算在150條左右。大于150條后,生成的sql語句將太長可能導致執行失敗。因此在插入大量數據時,目前需要自行分割成每150條插入一次。

使用SQL命令來插入數據

第1種方式

sql ="insert into config(key,value) values (?, ?)" res, err := engine.Exec(sql, "OSCHINA", "OSCHINA")

第2種方式

sql_2 := "insert into config(key,value) values (?, ?)" affected, err := engine.Sql(sql_4, "OSCHINA", "OSCHINA").Execute()

第3種方式

//SqlMap中key為 "sql_i_1" 配置的Sql語句為:insert into config(key,value) values (?, ?) sql_i_1 := "sql_i_1" affected, err := engine.SqlMapClient(sql_i_1, "config_1", "1").Execute()//SqlMap中key為 "sql_i_2" 配置的Sql語句為:insert into config(key,value) values (?key, ?value) sql_i_2 := "sql_i_2" paramMap_i := map[string]interface{}{"key": "config_2", "value": "2"} affected, err := engine.SqlMapClient(sql_i_2, &paramMap_i).Execute()

第4種方式

sql_i_3 := "insert.example.stpl" paramMap_i_t := map[string]interface{}{"key": "config_3", "value": "3"} affected, err := engine.SqlTemplateClient(sql_i_3, &paramMap_i_t).Execute()

創建時間Created

我感覺這個特性很有意思。它可以讓你在數據插入到數據庫的時候自動將對應的字段設置為當前的時間,需要在xorm標記中使用created標記。 字段可以是time.Time、int、int64、int32等int類型。

只需要在后面加上xorm的映射即可,當添加記錄的時候,created標記的字段就會被自動更新為當前時間。

type User struct {Id int64Name stringCreatedAt time.Time `xorm:"created"` }

查詢和統計數據

ORM方式查詢和統計數據

ORM所有的查詢條件不區分調用順序,但必須在調用Get,Find,Count,Iterate,Rows之前調用。

查詢單條語句用Get,查詢多條語句用Find

Rows和Iterate方法可以把查詢的結果逐條的展示出來,Rows更加靈活。

更新數據

update方法

使用如下的方式來更新

user := new(User) user.Name = "myname" affected, err := engine.Id(id).Update(user)

樂觀鎖

可以使用如下方式添加樂觀鎖,在insert的時候,version標記的字段將會被設置為1。

type User struct { Id int64 Name string Version int xorm:"version" }

在update的時候,update結構體中的內容必須包含原version的值

var user User engine.Id(1).Get(&user) // SELECT * FROM user WHERE id = ? engine.Id(1).Update(&user) // UPDATE user SET ..., version = version + 1 WHERE id = ? AND version = ?

更新時間

可以通過updated標記,當調用Insert(), InsertOne(), Update()方法的時候,會自動的將對應自動設置為當前時間,對應的字段可以為time.Time或者自定義的time.Time或者int,int64等int類型。

type User struct {Id int64Name stringUpdatedAt time.Time `xorm:"updated"` }

通過sql命令更新數據

第1種方式

sql ="update user set age = ? where name = ?" res, err := engine.Exec(sql, 1, "xorm")

第2種方式

sql_2 := "update user set age = ? where name = ?" affected, err := engine.Sql(sql_2, 1, "xorm").Execute()

第3種方式

//SqlMap中key為 "sql_i_1" 配置的Sql語句為:update user set age = ? where name = ? sql_i_1 := "sql_i_1" affected, err := engine.SqlMapClient(sql_i_1, 1, "xorm").Execute()//SqlMap中key為 "sql_i_2" 配置的Sql語句為:update user set age = ?age where name = ?name sql_i_2 := "sql_i_2" paramMap_i := map[string]interface{}{"age": 1, "name": "xorm"} affected, err := engine.SqlMapClient(sql_i_2, &paramMap_i).Execute()

第4種方式

sql_i_3 := "insert.example.stpl" paramMap_i_t := map[string]interface{}{"age": 1, "name": "xorm"} affected, err := engine.SqlTemplateClient(sql_i_3, &paramMap_i_t).Execute()

刪除數據

Delete方法

第一個參數為刪除的記錄數,第二個為執行錯誤

user := new(User) affected, err := engine.Id(id).Delete(user)

注意:當刪除時,如果user中包含有bool,float64或者float32類型,有可能會使刪除失敗。具體請查看 FAQ

軟刪除 Deleted

在我以前的使用中,軟刪除都是要自己去做的,但是XORM通過標記給我們做好了。

type User struct {Id int64Name stringDeletedAt time.Time `xorm:"deleted"`// 通過Cols來指定只更新某列affected, err := engine.Id(id).Cols("age").Update(&user) }

通過sql語句刪除數據

第1種方式

sql ="delete from user where id = ?" res, err := engine.Exec(sql, 1)

第2種方式

sql_2 := "delete from user where id = ?" affected, err := engine.Sql(sql_2, 1).Execute()

第3種方式

//SqlMap中key為 "sql_i_1" 配置的Sql語句為:delete from user where id = ? sql_i_1 := "sql_i_1" affected, err := engine.SqlMapClient(sql_i_1, 1).Execute()//SqlMap中key為 "sql_i_2" 配置的Sql語句為:delete from user where id = ?id sql_i_2 := "sql_i_2" paramMap_i := map[string]interface{}{"id": 1} affected, err := engine.SqlMapClient(sql_i_2, &paramMap_i).Execute()

第4種方式

sql_i_3 := "insert.example.stpl" paramMap_i_t := map[string]interface{}{"id": 1} affected, err := engine.SqlTemplateClient(sql_i_3, &paramMap_i_t).Execute()

事務

簡單事務使用

session := engine.NewSession() defer session.Close() // add Begin() before any action err := session.Begin() user1 := Userinfo{Username: "xiaoxiao", Departname: "dev", Alias: "lunny", Created: time.Now()} _, err = session.Insert(&user1) if err != nil {session.Rollback()return } user2 := Userinfo{Username: "yyy"} _, err = session.Where("id = ?", 2).Update(&user2) if err != nil {session.Rollback()return }_, err = session.Exec("delete from userinfo where username = ?", user2.Username) if err != nil {session.Rollback()return }// add Commit() after all actions err = session.Commit() if err != nil {return }

嵌套事務使用

在通常情況下,簡單事務夠我們使用了。 它與簡單事務的不同在于,簡單事務在同一個session下工作,而嵌套事物則會返回Transaction實例,后續操作則在同一個實例下操作。

session := engine.NewSession() defer session.Close() // add BeginTrans() before any action tx, err := session.BeginTrans() if err != nil {return }user1 := Userinfo{Username: "xiaoxiao", Departname: "dev", Alias: "lunny", Created: time.Now()} _, err = tx.Session().Insert(&user1) if err != nil {tx.Rollback()return }user2 := Userinfo{Username: "yyy"} _, err = tx.Session().Where("id = ?", 2).Update(&user2) if err != nil {tx.RollbackTrans()return }_, err = tx.Session().Exec("delete from userinfo where username = ?", user2.Username) if err != nil {tx.RollbackTrans()return }_, err = tx.Session().SqlMapClient("delete.userinfo", user2.Username).Execute() if err != nil {tx.RollbackTrans()return }// add CommitTrans() after all actions err = tx.CommitTrans() if err != nil {...return }

數據導出

查詢結果集導出csv、tsv、xml、json、xlsx、yaml、html

xorm查詢結果集支持導出csv、tsv、xml、json、xlsx、yaml、html七種文件格式

以導出xlsx文件格式為例,代碼如下

err := engine.Sql("select * from category").Query().SaveAsXLSX("1.xlsx", []string{"id", "name", "counts", "orders", "createtime", "pid", "lastupdatetime", "status"}, 0777)if err != nil {t.Fatal(err) }
  • SaveAsCSV(filename string, headers []string, perm os.FileMode)

導出CSV文件,filename為完整路徑,headers為每列的列名,需要結果集中有該字段,此處[]string是為了確定列的順序,perm為文件權限位

  • SaveAsTSV(filename string, headers []string, perm os.FileMode)

導出TSV文件,filename為完整路徑,headers為每列的列名,需要結果集中有該字段,此處[]string是為了確定列的順序,perm為文件權限位

  • SaveAsHTML(filename string, headers []string, perm os.FileMode)

導出HTML文件,filename為完整路徑,headers為每列的列名,需要結果集中有該字段,此處[]string是為了確定列的順序,perm為文件權限位

  • SaveAsXML(filename string, headers []string, perm os.FileMode)

導出XML文件,filename為完整路徑,headers為每列的列名,需要結果集中有該字段,此處[]string是為了確定列的順序,perm為文件權限位

  • SaveAsXMLWithTagNamePrefixIndent(tagName string, prifix string, indent string, filename string, headers []string, perm os.FileMode)

導出指定格式化的XML文件,filename為完整路徑,headers為每列的列名,需要結果集中有該字段,此處[]string是為了確定列的順序,perm為文件權限位

  • SaveAsYAML(filename string, headers []string, perm os.FileMode)

導出YAML文件,filename為完整路徑,headers為每列的列名,需要結果集中有該字段,此處[]string是為了確定列的順序,perm為文件權限位

  • SaveAsJSON(filename string, headers []string, perm os.FileMode)

導出JSON文件,filename為完整路徑,headers為每列的列名,需要結果集中有該字段,此處[]string是為了確定列的順序,perm為文件權限位

  • SaveAsXLSX(filename string, headers []string, perm os.FileMode)

導出XLSX文件,filename為完整路徑,headers為每列的列名,需要結果集中有該字段,此處[]string是為了確定列的順序,perm為文件權限位

多查詢集導出到單一文件

樣例代碼:

_, results, err := engine.Sqls(map[string]string{"category": "select * from category", "category-16-17": "select * from category where id in (16,17)"}).Execute()if err != nil {t.Fatal(err) }databook, err := xorm.NewDatabookWithData(map[string]string{"category": "category","category-16-17": "category-16-17"},results,true,map[string][]string{"category": []string{"id", "name", "counts", "orders", "createtime", "pid", "lastupdatetime", "status"},"category-16-17": []string{"id", "name", "counts", "orders", "createtime", "pid", "lastupdatetime", "status"}})if err != nil {t.Fatal(err) }err = databook.SaveAsXLSX("c:/2.xlsx", 0777) if err != nil {t.Fatal(err) } err = databook.SaveAsHTML("c:/2.html", 0777) if err != nil {t.Fatal(err) } err = databook.SaveAsJSON("c:/2.json", 0777) if err != nil {t.Fatal(err) } err = databook.SaveAsXML("c:/2.xml", 0777) if err != nil {t.Fatal(err) } err = databook.SaveAsYAML("c:/2.yaml", 0777) if err != nil {t.Fatal(err) }

連接池

engine內部支持連接池接口和對應的函數。

  • 如果需要設置連接池的空閑數大小,可以使用engine.SetMaxIdleConns()來實現。
  • 如果需要設置最大打開連接數,則可以使用engine.SetMaxOpenConns()來實現。

參考資料

  • xorm操作指南(官方)

歡迎評論區討論,或指出問題。 如果覺得寫的不錯,歡迎點贊,轉發,收藏。

總結

以上是生活随笔為你收集整理的Xorm学习笔记的全部內容,希望文章能夠幫你解決所遇到的問題。

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

在线观看黄污 | 久久久亚洲麻豆日韩精品一区三区 | 香蕉视频在线免费 | 99久久99久久精品免费 | 麻豆影视在线免费观看 | 国产成人av电影在线观看 | 国产精品一区欧美 | 欧美精品在线观看免费 | 99久久99热这里只有精品 | 日韩av影片在线观看 | 亚洲成av人片在线观看 | 亚洲欧洲国产精品 | 亚洲作爱 | 日韩视频一区二区三区在线播放免费观看 | 婷婷六月综合网 | 69av视频在线| 99久久久国产精品免费观看 | 免费日韩一区二区三区 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 色狠狠综合天天综合综合 | 久久国产精彩视频 | 婷婷色视频 | 天天射天天干天天插 | 精品国产免费av | 欧美成亚洲 | 久久xx视频 | 欧美日韩免费一区二区 | 亚洲视频免费在线观看 | 国产精品视频app | 久草视频视频在线播放 | 亚洲精品在线观看中文字幕 | 亚洲精品黄网站 | 97人人爽人人 | 国产成人一区二区三区久久精品 | 99在线播放 | 国产在线第三页 | 国产亚洲精品久久19p | 久久精品高清视频 | 在线中文字幕av观看 | 91精品国产九九九久久久亚洲 | 国内精品久久久久影院日本资源 | 亚洲一区 av | 久久综合五月婷婷 | 色大片免费看 | 麻豆视频观看 | 在线成人高清电影 | 免费精品人在线二线三线 | 最新日韩视频在线观看 | 欧美一级免费黄色片 | 国产麻豆剧果冻传媒视频播放量 | 国产粉嫩在线 | 黄色av电影免费观看 | 国内精品久久久久久久 | 在线播放一区 | 国内精品久久影院 | 日韩精品视频免费 | 激情电影影院 | 婷婷色在线| 成人免费在线观看av | 久热爱| 人人澡人人草 | 欧美日一级片 | 三级av在线 | 久久久久久久亚洲精品 | 中文字幕在线影视资源 | 成人黄色国产 | 黄色三级网站在线观看 | 麻豆91网站| 91精品一区在线观看 | 久久久久久久国产精品视频 | 国产精品18久久久久白浆 | 免费观看性生活大片 | 国产在线精品区 | 99精品视频免费全部在线 | 久章操 | 中文字幕在线观看三区 | 中文字幕大全 | 在线国产一区二区三区 | 国产一级二级三级在线观看 | 国产在线视频在线观看 | 一本到在线 | 91网址在线| 国产一性一爱一乱一交 | 91九色网站 | 国产精品欧美日韩在线观看 | av中文字幕在线观看网站 | 国产精品va在线播放 | 国产精品久久久久久一区二区三区 | 国产亚洲在 | 国产中文字幕视频在线观看 | 亚洲精品在线观看视频 | 欧美精品乱码99久久影院 | 一级欧美一级日韩 | 日韩大片免费在线观看 | 亚洲精品一区二区18漫画 | 亚洲精品在线二区 | 99精品视频在线 | 日韩精品一区二区三区水蜜桃 | 日韩中文字幕亚洲一区二区va在线 | 国产综合婷婷 | 国产又黄又硬又爽 | 久久亚洲免费视频 | 五月天电影免费在线观看一区 | 黄色亚洲精品 | 91精彩在线视频 | 夜色在线资源 | 中文字幕韩在线第一页 | 国内综合精品午夜久久资源 | 国产成人三级在线 | 天天曰夜夜爽 | 亚洲综合欧美精品电影 | 国内揄拍国产精品 | 色噜噜狠狠狠狠色综合久不 | 国产毛片在线 | 91视频在线观看免费 | 粉嫩高清一区二区三区 | 欧美男女爱爱视频 | av网址在线播放 | 在线观看成人毛片 | 深夜成人av| 亚洲精品乱码久久久久久写真 | 久久超碰在线 | 亚洲电影黄色 | 日本中文字幕高清 | 国产精品久久久久久久av电影 | 国产99久久 | 在线观看中文字幕一区二区 | 久久免费播放 | 伊人影院在线观看 | 免费在线观看的av网站 | 日韩在线中文字幕视频 | 国产精品99久久久久久人免费 | 丁香激情综合久久伊人久久 | 欧美大香线蕉线伊人久久 | 又黄又刺激又爽的视频 | 福利视频网址 | 精品伦理一区二区三区 | 国产色网 | 亚洲免费高清视频 | 91av在线不卡| 日韩激情三级 | 日韩黄色av网站 | 久久久久国产精品一区 | 婷婷久久久久 | 国内精品久久久久久久久久清纯 | 天天干天天操人体 | 亚洲精品久久在线 | 色综合久久久久综合体 | 国产无遮挡猛进猛出免费软件 | 久久美女高清视频 | 黄色软件在线观看视频 | 91中文字幕在线播放 | 日本久久综合网 | 精品久久久久免费极品大片 | 综合网天天色 | 九色91福利 | 成人黄色大片网站 | 91大神精品视频在线观看 | 欧日韩在线 | 久久久午夜电影 | 国产视频一区二区三区在线 | 国产区网址 | 久久精品国产免费看久久精品 | 超碰国产97 | 夜夜躁狠狠燥 | 欧美精品v国产精品 | 日本福利视频在线 | 国产天天爽 | 久久国产精品99久久久久久老狼 | 亚洲在线精品 | 亚洲成人黄色在线观看 | 91片黄在线观 | 国产精品k频道 | 2023亚洲精品国偷拍自产在线 | 97日日| 免费中文字幕视频 | 久久亚洲免费视频 | 亚洲精品黄 | 最近免费观看的电影完整版 | 国内精品久久久久久久久 | 在线三级播放 | 亚洲综合一区二区精品导航 | 天堂视频一区 | 亚洲91av| 国产精品一区二区三区免费看 | 午夜视频免费在线观看 | 波多野结衣电影一区二区 | 日韩和的一区二在线 | 免费看国产a| 少妇bbb好爽| 国产精品亚洲精品 | 久久经典视频 | 久久久国产精品亚洲一区 | 丁香六月五月婷婷 | 国产亚洲视频在线观看 | 日韩一区二区三区不卡 | 国产69精品久久久久99尤 | 91精品系列 | 97人人模人人爽人人喊中文字 | 视频一区视频二区在线观看 | 亚洲爱av | 国产精品久久久久av福利动漫 | 最新亚洲视频 | 人人插人人玩 | 国产一二三四在线视频 | 91精品国产三级a在线观看 | 97香蕉超级碰碰久久免费软件 | 韩国一区在线 | 亚洲精品动漫在线 | 久久午夜精品视频 | 天天操天天操天天爽 | 国产精品丝袜在线 | 国产小视频免费观看 | 在线看一区 | 伊人久久五月天 | 国产成人在线观看 | 日韩毛片精品 | 最新日韩精品 | 天堂在线一区 | 超碰在线cao | 日免费视频 | 国产精品美女久久久免费 | 欧美综合干 | 久久精品男人的天堂 | 久久久黄视频 | 国产美女精品视频 | 在线黄色免费 | 免费看wwwwwwwwwww的视频 久久久久久99精品 91中文字幕视频 | 日韩欧美精品在线观看 | 顶级bbw搡bbbb搡bbbb | 最近字幕在线观看第一季 | 久久调教视频 | 99亚洲国产精品 | 四虎成人精品永久免费av | 粉嫩av一区二区三区四区 | 日韩精品久久一区二区三区 | 韩国一区二区av | 成人在线免费视频 | 免费黄色网址大全 | 中文字幕在线国产 | 国产精品porn | 久久黄色精品视频 | 日本黄色免费观看 | 欧洲精品久久久久毛片完整版 | 国产97视频 | 国产亚洲精品成人av久久影院 | 成人av片在线观看 | 日韩在线观看第一页 | 中文在线亚洲 | 五月激情五月激情 | 欧美与欧洲交xxxx免费观看 | 成人在线观看av | 亚洲精品国产综合99久久夜夜嗨 | 色91av| 国产人成在线观看 | 久99热| 人人插人人艹 | 综合网天天 | 国产免费叼嘿网站免费 | 91av影视| 亚洲第一色| 国产二区免费视频 | 国产精品久久久久久婷婷天堂 | 夜夜天天干 | 伊人色**天天综合婷婷 | 免费看片亚洲 | 四虎影视欧美 | 天堂av免费看 | 国产糖心vlog在线观看 | 国产一区成人 | 四虎成人精品 | 成人av观看 | 国内免费久久久久久久久久久 | 亚洲国产激情 | 91精品亚洲影视在线观看 | 91精品国产成 | 日韩av看片 | 欧美亚洲精品在线观看 | 1000部国产精品成人观看 | 久草在线视频网站 | 日韩毛片在线免费观看 | 久久综合久久综合这里只有精品 | 精品黄色在线 | 日韩电影在线观看一区二区三区 | 日韩在线视频免费观看 | 午夜视频免费在线观看 | 一区在线免费观看 | 欧美成人精品欧美一级乱黄 | 中文字幕在线观看视频一区 | 99久免费精品视频在线观看 | 日韩爱爱片 | 中文字幕av免费 | 日韩高清免费电影 | 天堂网一区二区三区 | 久久综合狠狠综合久久狠狠色综合 | 国产成人精品一区二区在线 | 日韩美一区二区三区 | 性色va | 麻豆视频成人 | 亚洲男男gaygayxxxgv | 免费看的黄色小视频 | 国产免费叼嘿网站免费 | www久久 | 中文字幕资源网 | 日韩在线第一区 | 韩国av永久免费 | 久久精品波多野结衣 | 一区二区视频在线观看免费 | 2019中文字幕网站 | 免费下载高清毛片 | 亚洲区视频在线 | 91中文字幕永久在线 | 久久综合爱| 天天射网| 在线免费观看视频a | 97超视频免费观看 | 日韩一区二区久久 | 久草视频网 | 97人人澡人人添人人爽超碰 | 99热这里只有精品8 久久综合毛片 | 视频国产一区二区三区 | 99视频精品免费观看, | 97国产电影 | 国产麻豆视频 | 婷婷成人综合 | 久久精品屋 | 免费网站在线观看成人 | 欧美视频二区 | 久久免费在线观看 | 热久久精品在线 | 欧美日韩一区二区在线观看 | 激情久久久久 | 亚洲精品一区二区在线观看 | 精品国产精品久久一区免费式 | 视频在线99 | 中文超碰字幕 | 色综合久久久网 | 国产在线观看网站 | 亚洲人久久久 | 色久天 | 91av蜜桃| 国产一区在线观看免费 | 久久久久99精品国产片 | 亚洲激精日韩激精欧美精品 | 亚洲人人网 | 久久久久色 | 国产成人精品国内自产拍免费看 | 国产亚洲观看 | 亚洲天堂香蕉 | 欧美激情视频一区二区三区免费 | 欧美91视频| 丁香免费视频 | 亚洲专区欧美专区 | 91人人爽人人爽人人精88v | 国产最顶级的黄色片在线免费观看 | 青青河边草免费直播 | 五月婷婷丁香色 | 在线免费观看国产 | 狠狠色丁香婷婷综合视频 | 毛片永久免费 | 久久综合久久综合这里只有精品 | 有码视频在线观看 | 亚洲精品在线播放视频 | 亚洲涩涩色 | 久久亚洲影院 | 久草影视在线观看 | 99精品国产在热久久下载 | 久久久www成人免费毛片 | 久久久久久免费网 | 亚洲综合一区二区精品导航 | 欧美一区二区精品在线 | 国产精品久久久久久久久蜜臀 | 国产精品99久久久久 | av在线免费播放网站 | 91久久久久久国产精品 | 日韩久久精品一区二区三区下载 | 午夜久久美女 | 欧美91片| 久久国内精品视频 | 久久美女电影 | 天天色棕合合合合合合 | 亚洲美女精品视频 | 五月天天色 | 亚洲欧美视频一区二区三区 | 99久久国产免费看 | 日本中文字幕在线播放 | 午夜久久网站 | 免费一级片观看 | 国产一级大片免费看 | 欧美analxxxx| 欧美性粗大hdvideo | 国产一区二区精 | 天天操天天射天天操 | 国产精品午夜av | 成年人在线免费视频观看 | 天天综合色天天综合 | 国产一级做a| 中文字幕视频 | 婷婷成人亚洲综合国产xv88 | 亚洲伦理中文字幕 | 日日摸日日 | 69欧美视频| 成人午夜电影在线播放 | 色综合久久综合中文综合网 | 日本爱爱片 | 深夜福利视频一区二区 | 97精品一区二区三区 | 狠狠狠狠狠操 | 国产成人精品一区在线 | 99热在线观看 | 国产精品精品久久久 | 国产精品久久久久久a | 久久久免费观看完整版 | 亚洲无吗天堂 | 91精品久久久久久久99蜜桃 | 国产美女主播精品一区二区三区 | 国产一区黄色 | 久草免费在线视频观看 | 日本三级久久 | 麻豆传媒视频在线播放 | 亚洲男人天堂a | 丁香婷婷基地 | 五月婷婷香蕉 | 日色在线视频 | 成人毛片一区二区三区 | 亚洲专区 国产精品 | 日韩有码在线播放 | 四虎影院在线观看av | 国产黄色精品在线观看 | 久久精品一区二区国产 | 国产成年免费视频 | 亚洲视频综合在线 | 久久国产网| 欧美成人999 | 久久精品一区二区三区国产主播 | 91免费高清 | 日日色综合| 日韩精品中文字幕在线不卡尤物 | 国产精品女同一区二区三区久久夜 | 久久99久久99精品免费看小说 | 91在线文字幕 | 狠狠操导航 | 蜜臀av性久久久久av蜜臀三区 | 日韩女同av | 精品亚洲午夜久久久久91 | 婷婷丁香七月 | 国产玖玖在线 | 一区国产精品 | 色插综合 | 黄色三级免费网址 | 国产精品一区二区三区久久久 | av中文字幕在线观看网站 | www.久草视频 | 中文字幕一区二区三区四区在线视频 | 亚洲一二三久久 | 狠色在线 | 91成人看片| 激情视频一区二区三区 | 国产日韩欧美在线观看 | 天天爽综合网 | www免费看片com | 国内精品毛片 | 国产午夜精品一区二区三区 | 99久久www免费 | 激情五月伊人 | 在线观看www视频 | 中文字幕久久精品 | 超碰999 | 9色在线视频 | 亚洲成熟女人毛片在线 | 91传媒91久久久 | 六月丁香伊人 | 激情视频91 | 国产福利专区 | 中文字幕中文 | 亚洲精品视频在线 | 在线观看视频免费大全 | 国产经典av| 国产精品美女久久久久久免费 | 久久久久久99精品 | 午夜色婷婷| 亚洲涩涩涩涩涩涩 | 成人黄色在线观看视频 | 久久国产欧美日韩精品 | 久久免费视频观看 | 成人av电影免费 | 久久久国产影视 | 国产理论免费 | 久久国产精品免费一区 | 午夜国产一区二区 | 精品国产一区二区三区蜜臀 | 久久精选 | 亚洲精品99久久久久久 | 中文字幕亚洲五码 | 日日干视频| avav片 | 97av在线视频免费播放 | 99精品免费视频 | 91视频在线 | 白丝av免费观看 | 色香com. | 久久玖| 玖玖玖国产精品 | 激情综合网婷婷 | 国产精品久久久久久久av大片 | 超碰在线日韩 | 久久久午夜电影 | adc在线观看| 91精品日韩 | 天天草综合网 | 日本不卡一区二区三区在线观看 | 在线观看免费国产小视频 | 国产极品尤物在线 | 在线一区av | 丁香激情综合久久伊人久久 | 热99久久精品 | 天天色天天上天天操 | 日本女人的性生活视频 | 五月婷婷丁香在线观看 | 国产精品短视频 | 国产福利一区二区在线 | 国内揄拍国产精品 | 91精品一区二区三区蜜臀 | 日日碰夜夜爽 | 亚洲一区欧美精品 | 日韩免费不卡视频 | 免费视频资源 | www成人av| 日韩免费视频播放 | 久久久久这里只有精品 | 欧美在线一级片 | 在线观看亚洲视频 | 欧美一区二区三区免费看 | 久草免费手机视频 | 成人午夜精品福利免费 | 欧美精品v国产精品v日韩精品 | 亚洲国产69| 国产一区二区不卡视频 | 98福利在线 | caobi视频 | 超级碰碰免费视频 | 免费久久久久久久 | 免费成人短视频 | 中文视频在线 | 久久色在线播放 | 天天艹天天爽 | 九九九视频在线 | 黄色免费大片 | 久久久精品欧美一区二区免费 | 国产区网址 | 狠狠网 | 九色精品 | 国产精品不卡视频 | 四虎海外影库www4hu | 亚洲精品成人在线 | 狠狠干天天射 | 欧美日韩三区二区 | 日韩国产精品一区 | 久久黄色a级片 | 久久久精品成人 | 国产精品va最新国产精品视频 | 日韩精品91偷拍在线观看 | 九九热精品视频在线播放 | 中文字幕资源网在线观看 | 超碰大片 | 国模一区二区三区四区 | 夜夜视频资源 | 日韩精品欧美视频 | 免费在线国产精品 | 中文字幕 影院 | 亚洲涩涩一区 | 精品国产乱子伦一区二区 | 中国精品少妇 | 99热手机在线观看 | 亚洲成人免费在线 | 亚洲精品美女在线 | 九九色综合 | 91网页版免费观看 | 久久精品国产亚洲精品 | se婷婷| 亚洲精品合集 | 天堂网av 在线 | 91探花国产综合在线精品 | 91久久精品日日躁夜夜躁国产 | 亚洲国产午夜视频 | 激情久久综合 | 国产成人精品久久亚洲高清不卡 | 狠狠亚洲 | 久久精品国产成人 | 国产黄色精品在线观看 | 日韩在线观看不卡 | 天天躁日日躁狠狠 | japanese黑人亚洲人4k | 国产亚洲精品久久久久久网站 | 在线观看av黄色 | 亚洲1区在线 | 黄视频色网站 | 91高清视频在线 | av电影 一区二区 | 亚洲一区精品人人爽人人躁 | 午夜久久福利 | 看毛片的网址 | 96av在线| 综合激情 | 日本免费一二三区 | 免费在线色视频 | 欧日韩在线 | 婷婷网五月天 | 日韩大片在线免费观看 | 日韩免费电影在线观看 | 精品国产一区在线观看 | 日韩av网址在线 | 亚洲精品综合欧美二区变态 | 亚洲国产精品久久久久婷婷884 | 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产精品久久久久久久久久99 | 黄色毛片电影 | 69亚洲精品 | 欧美亚洲成人xxx | 亚洲天天做 | 国产亲近乱来精品 | 国产中文字幕一区二区三区 | 久久在草 | 国产精品久久久久久久毛片 | 国产高清视频免费最新在线 | 日韩和的一区二在线 | 久久看看 | 成年人免费电影在线观看 | 亚州国产精品久久久 | 99在线精品观看 | 99精品在线播放 | 精品99在线| 日韩精品免费一区 | 久亚洲| 免费 在线 中文 日本 | 色视频 在线 | 国产精品久久久久9999 | 一二三区av| 久草精品视频在线看网站免费 | 国产一级片网站 | 婷婷国产精品 | 亚洲成人av电影在线 | 久久久www成人免费精品张筱雨 | 日韩成人免费在线观看 | 国产伦精品一区二区三区无广告 | 亚洲成av人电影 | 在线亚洲高清视频 | 最新日韩电影 | 欧美国产日韩激情 | 久久久精品网站 | 亚洲国产日韩精品 | 韩国av免费观看 | 色www精品视频在线观看 | 国产手机av在线 | 黄色网址a | 亚洲韩国一区二区三区 | 精品视频在线观看 | 免费三及片 | 91精品视频免费看 | 成人香蕉视频 | 国产精品激情 | 亚洲欧美视频一区二区三区 | 国产精品毛片网 | 欧美不卡视频在线 | 91夜夜夜| 四虎影视成人 | 美女免费视频一区二区 | 丁香六月网| 国产欧美最新羞羞视频在线观看 | 视频在线观看亚洲 | 91porny九色91啦中文 | 黄色片网站大全 | 国产剧情一区 | 国内精品久久久精品电影院 | 国产精品久久久久久高潮 | 久久久久久久久综合 | 8x成人在线 | 91精品区 | 最新国产精品拍自在线播放 | 久久久久影视 | 久久久久一区二区三区 | 国产成人久久精品一区二区三区 | 日韩有码网站 | 色婷婷av一区 | 成人久久久精品国产乱码一区二区 | 人人添人人澡 | 成人av视屏 | 久久久久女人精品毛片九一 | 久久免费电影网 | 久章草在线 | 91精品在线观看入口 | 亚洲欧美综合精品久久成人 | 免费成人在线观看视频 | 精品久久久久久久久中文字幕 | 国模视频一区二区三区 | 中文字幕久久亚洲 | 亚洲激情校园春色 | 色综合久久88色综合天天 | 黄色片网站免费 | 亚洲欧洲中文日韩久久av乱码 | 欧美成年网站 | 成 人 黄 色 视频免费播放 | 国产原创在线视频 | 久久激情五月丁香伊人 | 日日射av| 国产亚洲精品久久久久久久久久久久 | 毛片久久久 | 亚洲精品在线观看中文字幕 | 婷婷国产一区二区三区 | 亚洲 欧美 日韩 综合 | 中文字幕丝袜一区二区 | 国产精彩视频 | 狠狠干夜夜操天天爽 | 久久久综合 | 天天色天天射综合网 | 欧美国产日韩在线视频 | 97国产情侣爱久久免费观看 | av在线电影网站 | 99久久精品免费看国产麻豆 | 亚洲最大成人网4388xx | 日本三级大片 | 久久99国产精品二区护士 | 黄色片免费在线 | 97碰碰视频 | 国产麻豆精品一区二区 | 97视频在线 | 国产精品一区二区av日韩在线 | 日韩在线观看视频中文字幕 | 粉嫩aⅴ一区二区三区 | 亚洲精品在线资源 | 91人人揉日日捏人人看 | 国产精品久久久久久久电影 | 91精品中文字幕 | 国产成人一区二区啪在线观看 | 99日韩精品| 极品中文字幕 | 日本精品久久 | 中文字幕123区 | 18网站在线观看 | 国产精品福利在线播放 | 久久99在线观看 | 69国产盗摄一区二区三区五区 | 狠狠狠狠狠狠狠狠干 | 中文字幕一区二区三区在线播放 | 91精品国产自产老师啪 | 三日本三级少妇三级99 | 免费黄av| 在线视频免费观看 | 91av在线看 | 99热最新精品| 亚洲另类在线视频 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 国产精品免费观看视频 | 欧美激情第十页 | 亚洲视频久久久 | 中文字幕丝袜制服 | 国产精品不卡在线播放 | www.xxx.性狂虐 | 中文字幕在线观看第一区 | 欧美成人视 | 国内精品久久久久久久久久清纯 | 色婷婷视频在线 | 欧美黄色高清 | 国产精品自拍av | 亚洲色视频 | 在线岛国av | 日日干天天爽 | 在线精品亚洲一区二区 | 国产玖玖在线 | 免费高清影视 | 国色天香在线观看 | 亚洲精品字幕在线观看 | 丁香久久久 | 麻豆传媒电影在线观看 | 最新色站 | 四虎国产精品成人免费4hu | 伊人一级 | 久久久精品免费观看 | av线上看| 中文字幕在线高清 | 在线不卡中文字幕播放 | 日韩资源在线 | 最新日韩在线观看视频 | 日本精品视频网站 | 精品国产一区二区三区四区vr | 成人毛片a| 久久午夜免费视频 | 日本精品一区二区三区在线观看 | 欧美91精品国产自产 | 激情丁香在线 | 免费视频在线观看网站 | 久久免费成人 | 在线中文字幕播放 | 精品9999| 九九免费视频 | 特级西西444www高清大视频 | 美女中文字幕 | 国产亚洲欧美一区 | .国产精品成人自产拍在线观看6 | 欧美日本不卡视频 | 国内精品国产三级国产aⅴ久 | 天天射网站| 精品女同一区二区三区在线观看 | www.香蕉视频在线观看 | 日本中文字幕视频 | 天天爽夜夜爽人人爽一区二区 | 日韩久久午夜一级啪啪 | 亚洲午夜不卡 | wwwww.国产 | 99r在线| 午夜av免费看 | 在线观看视频一区二区 | 亚洲最新av在线网址 | 91片网 | 日日操天天操狠狠操 | 久久人人爽人人人人片 | 国产高清无av久久 | 综合激情 | 久草视频在线免费播放 | 九九热免费在线观看 | 欧美日韩高清不卡 | 在线韩国电影免费观影完整版 | 99久久日韩精品免费热麻豆美女 | 久久精品国产一区二区三区 | av经典在线 | 色无五月| 国产人成免费视频 | 国产黄色免费 | 国产精品久久久久久久久毛片 | 久久久国产99久久国产一 | 999色视频 | 久久国产剧场电影 | 九九热av | 99爱这里只有精品 | 黄色av网站在线观看 | 麻豆国产精品一区二区三区 | www.com黄| 国产综合视频在线观看 | www.狠狠操| 国产日韩高清在线 | 91精品国产乱码久久 | 伊人婷婷激情 | 天天操综合网站 | 2019av在线视频| 精品一区欧美 | www.夜夜夜| 97福利在线观看 | 久久久久在线 | 18岁免费看片 | 91福利试看| 成人影片在线免费观看 | 天天爱天天操 | 色吊丝在线永久观看最新版本 | 999视频在线播放 | 久久国产精品一区二区三区四区 | 亚洲欧美日韩一二三区 | 精品久久久久久综合日本 | 91人人澡| 91麻豆视频 | 综合网av| 97超级碰碰碰视频在线观看 | 狠狠ri| 久久精品视频18 | 综合久久综合久久 | 九九精品毛片 | 国产精品久久婷婷六月丁香 | 成人看片 | 在线一二区 | 欧美一区免费在线观看 | 久久黄色片子 | 成人在线黄色 | 色婷婷国产精品一区在线观看 | 中文在线免费视频 | 国产中年夫妇高潮精品视频 | 九九热精品视频在线播放 | 亚洲国产综合在线 | 欧美日韩精品二区第二页 | 嫩草91影院| 久久婷婷国产 | 国产四虎在线 | 成人国产精品久久久久久亚洲 | av成人免费在线观看 | 日本性生活免费看 | 制服丝袜成人在线 | 久草视频免费在线播放 | 日韩激情在线视频 | 欧美日韩一区二区在线观看 | av成年人电影 | 久久视频国产精品免费视频在线 | 国产精品欧美久久久久天天影视 | 99久e精品热线免费 99国产精品久久久久久久久久 | 日韩最新在线视频 | 91色偷偷 | 免费在线一区二区 | 久草在线这里只有精品 | 亚洲影院色 | 久久精品亚洲国产 | 欧美黄色成人 | 91高清完整版在线观看 | 色.com| 香蕉视频久久 | 久久 地址 | 91看片看淫黄大片 | 国产xx在线 | 国产福利电影网址 | 美女很黄免费网站 | 精品国产一区二区三区久久影院 | 国产小视频在线免费观看 | 亚洲九九九 | 中午字幕在线观看 | 国产人成看黄久久久久久久久 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 国产精品久久久久久久毛片 | 成人午夜精品久久久久久久3d | 国产91免费观看 | 色94色欧美 | 91在线播放综合 | 欧美一级片在线观看视频 | 日韩av福利在线 | 在线观看岛国片 | 中文字幕在线免费看 | 激情伊人 | 欧美日韩三级在线观看 | 久久免费精品一区二区三区 | 一区三区在线欧 | 午夜av网站| 国产人成一区二区三区影院 | 亚洲黄色区 | 在线观看国产日韩欧美 | 亚洲精品麻豆 | 国产高清网站 | 不卡的av中文字幕 | 一区二区三区四区精品视频 | 欧美一区日韩精品 | 日韩精品在线视频免费观看 | 中文字幕中文字幕在线一区 | 免费观看成人网 | 超碰在97 | 一区二区三区四区在线 | 国产黄网在线 | 日韩高清精品一区二区 | 91色蜜桃| 综合久色 | 久久综合免费视频影院 | 色综合国产 | 成人a视频片观看免费 | 亚州黄色一级 | 久久久影片 | 色婷婷综合久久久 | 美女视频黄在线观看 | 九九九在线 | 一区二区三区高清在线 | 国产精品伦一区二区三区视频 | 在线播放国产一区二区三区 | 超碰av在线 | 99久久夜色精品国产亚洲 | 久久99精品久久只有精品 | 精品久久网 | 黄色网www | 久久久999免费视频 日韩网站在线 | 一区二区三区观看 | 天天色.com| 国产在线不卡一区 | 久久久久国产成人免费精品免费 | 久久 在线 | 91传媒免费观看 | 欧美精品日韩 | 日日碰狠狠添天天爽超碰97久久 | 中日韩在线 | 999成人| 精品国产一区二区三区四区vr | av日韩中文 | 国产精品久久久免费看 | 国产亚洲久久 | 伊人狠狠色丁香婷婷综合 | 久久99精品国产99久久 | 午夜精品一区二区三区免费视频 | 嫩草av影院 | 国产一级二级在线观看 | 欧美日韩精品免费观看 | 又色又爽又黄高潮的免费视频 | 久久精品123 | 日韩中文字幕视频在线观看 | 国产精品久久久久久久毛片 | 色综合天天视频在线观看 | 五月婷av| 欧美一级视频免费看 | 国产剧情久久 | 午夜视频一区二区三区 | 欧美不卡在线 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 欧美一级艳片视频免费观看 | 91高清完整版在线观看 | 亚洲成av人影院 | 精品国内自产拍在线观看视频 | 片黄色毛片黄色毛片 | 一区二区三区动漫 | 久久久久国产a免费观看rela |