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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

[转]T4模版引擎之生成数据库实体类

發布時間:2025/3/19 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [转]T4模版引擎之生成数据库实体类 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文轉自:http://www.cnblogs.com/lzrabbit/archive/2012/07/18/2597953.html

?

在通過T4模版引擎之基礎入門?對T4有了初步印象后,我們開始實戰篇。T4模板引擎可以當做一個代碼生成器,代碼生成器的職責當然是用來生成代碼(這不是廢話嗎)。而這其中我們使用的最普遍的是根據數據庫生成實體類。

  工欲善其事必先利其器,在這之前先來介紹一款T4編輯器T4 Editor,我們可以點擊鏈接去下載然后安裝,不過還是推薦大家直接在VS擴展管理器里直接安裝來的方便 工具->擴展管理器->聯機庫 搜索 "T4 Editor",選擇第一項 "tangible T4 Editor 2.0 plus modeling tools for VS2010" 進行安裝即可,如下圖所示:

安裝上T4 Editor后,編輯T4模板是就有代碼著色和智能提示了,下圖為安裝T4 Editor后的代碼著色效果,怎么樣是不是耳目一新,呵呵

?

?

接下來開始正式進入我們的主題,從數據庫自動生成實體類

  • 新建一個控制臺項目,然后添加T4模板,這里我們起名字為Customers.tt

  • 修改輸出文件擴展名為.cs <#@ output extension=".cs" #>
  • 添加常用的程序集和命名空間引用 <#@ assembly name="System.Core.dll" #> <#@ assembly name="System.Data.dll" #> <#@ assembly name="System.Data.DataSetExtensions.dll" #> <#@ assembly name="System.Xml.dll" #> <#@ import namespace="System" #> <#@ import namespace="System.Xml" #> <#@ import namespace="System.Linq" #> <#@ import namespace="System.Data" #> <#@ import namespace="System.Data.SqlClient" #> <#@ import namespace="System.Collections.Generic" #> <#@ import namespace="System.IO" #>
  • 添加數據庫操作DbHelper引用 <#+public class DbHelper{#region GetDbTablespublic static List<DbTable> GetDbTables(string connectionString, string database, string tables = null){if (!string.IsNullOrEmpty(tables)){tables = string.Format(" and obj.name in ('{0}')", tables.Replace(",", "','"));}#region SQLstring sql = string.Format(@"SELECTobj.name tablename,schem.name schemname,idx.rows,CAST(CASE WHEN (SELECT COUNT(1) FROM sys.indexes WHERE object_id= obj.OBJECT_ID AND is_primary_key=1) >=1 THEN 1ELSE 0END AS BIT) HasPrimaryKey from {0}.sys.objects obj inner join {0}.dbo.sysindexes idx on obj.object_id=idx.id and idx.indid<=1INNER JOIN {0}.sys.schemas schem ON obj.schema_id=schem.schema_idwhere type='U' {1}order by obj.name", database, tables);#endregionDataTable dt = GetDataTable(connectionString, sql);return dt.Rows.Cast<DataRow>().Select(row => new DbTable{TableName = row.Field<string>("tablename"),SchemaName = row.Field<string>("schemname"),Rows = row.Field<int>("rows"),HasPrimaryKey = row.Field<bool>("HasPrimaryKey")}).ToList();}#endregion#region GetDbColumnspublic static List<DbColumn> GetDbColumns(string connectionString, string database, string tableName, string schema = "dbo"){#region SQLstring sql = string.Format(@"WITH indexCTE AS(SELECT ic.column_id,ic.index_column_id,ic.object_id FROM {0}.sys.indexes idxINNER JOIN {0}.sys.index_columns ic ON idx.index_id = ic.index_id AND idx.object_id = ic.object_idWHERE idx.object_id =OBJECT_ID(@tableName) AND idx.is_primary_key=1)selectcolm.column_id ColumnID,CAST(CASE WHEN indexCTE.column_id IS NULL THEN 0 ELSE 1 END AS BIT) IsPrimaryKey,colm.name ColumnName,systype.name ColumnType,colm.is_identity IsIdentity,colm.is_nullable IsNullable,cast(colm.max_length as int) ByteLength,(case when systype.name='nvarchar' and colm.max_length>0 then colm.max_length/2 when systype.name='nchar' and colm.max_length>0 then colm.max_length/2when systype.name='ntext' and colm.max_length>0 then colm.max_length/2 else colm.max_lengthend) CharLength,cast(colm.precision as int) Precision,cast(colm.scale as int) Scale,prop.value Remarkfrom {0}.sys.columns colminner join {0}.sys.types systype on colm.system_type_id=systype.system_type_id and colm.user_type_id=systype.user_type_idleft join {0}.sys.extended_properties prop on colm.object_id=prop.major_id and colm.column_id=prop.minor_idLEFT JOIN indexCTE ON colm.column_id=indexCTE.column_id AND colm.object_id=indexCTE.object_id where colm.object_id=OBJECT_ID(@tableName)order by colm.column_id", database);#endregionSqlParameter param = new SqlParameter("@tableName", SqlDbType.NVarChar, 100) { Value = string.Format("{0}.{1}.{2}", database, schema, tableName) };DataTable dt = GetDataTable(connectionString, sql, param);return dt.Rows.Cast<DataRow>().Select(row => new DbColumn(){ColumnID = row.Field<int>("ColumnID"),IsPrimaryKey = row.Field<bool>("IsPrimaryKey"),ColumnName = row.Field<string>("ColumnName"),ColumnType = row.Field<string>("ColumnType"),IsIdentity = row.Field<bool>("IsIdentity"),IsNullable = row.Field<bool>("IsNullable"),ByteLength = row.Field<int>("ByteLength"),CharLength = row.Field<int>("CharLength"),Scale = row.Field<int>("Scale"),Remark = row["Remark"].ToString()}).ToList();}#endregion #region GetDataTablepublic static DataTable GetDataTable(string connectionString, string commandText, params SqlParameter[] parms){using (SqlConnection connection = new SqlConnection(connectionString)){SqlCommand command = connection.CreateCommand();command.CommandText = commandText;command.Parameters.AddRange(parms);SqlDataAdapter adapter = new SqlDataAdapter(command);DataTable dt = new DataTable();adapter.Fill(dt);return dt;}}#endregion}#region DbTable/// <summary>/// 表結構/// </summary>public sealed class DbTable{/// <summary>/// 表名稱/// </summary>public string TableName { get; set; }/// <summary>/// 表的架構/// </summary>public string SchemaName { get; set; }/// <summary>/// 表的記錄數/// </summary>public int Rows { get; set; }/// <summary>/// 是否含有主鍵/// </summary>public bool HasPrimaryKey { get; set; }}#endregion#region DbColumn/// <summary>/// 表字段結構/// </summary>public sealed class DbColumn{/// <summary>/// 字段ID/// </summary>public int ColumnID { get; set; }/// <summary>/// 是否主鍵/// </summary>public bool IsPrimaryKey { get; set; }/// <summary>/// 字段名稱/// </summary>public string ColumnName { get; set; }/// <summary>/// 字段類型/// </summary>public string ColumnType { get; set; }/// <summary>/// 數據庫類型對應的C#類型/// </summary>public string CSharpType{get{return SqlServerDbTypeMap.MapCsharpType(ColumnType);}}/// <summary>/// /// </summary>public Type CommonType{get{return SqlServerDbTypeMap.MapCommonType(ColumnType);}}/// <summary>/// 字節長度/// </summary>public int ByteLength { get; set; }/// <summary>/// 字符長度/// </summary>public int CharLength { get; set; }/// <summary>/// 小數位/// </summary>public int Scale { get; set; }/// <summary>/// 是否自增列/// </summary>public bool IsIdentity { get; set; }/// <summary>/// 是否允許空/// </summary>public bool IsNullable { get; set; }/// <summary>/// 描述/// </summary>public string Remark { get; set; }}#endregion#region SqlServerDbTypeMappublic class SqlServerDbTypeMap{public static string MapCsharpType(string dbtype){if (string.IsNullOrEmpty(dbtype)) return dbtype;dbtype = dbtype.ToLower();string csharpType = "object";switch (dbtype){case "bigint": csharpType = "long"; break;case "binary": csharpType = "byte[]"; break;case "bit": csharpType = "bool"; break;case "char": csharpType = "string"; break;case "date": csharpType = "DateTime"; break;case "datetime": csharpType = "DateTime"; break;case "datetime2": csharpType = "DateTime"; break;case "datetimeoffset": csharpType = "DateTimeOffset"; break;case "decimal": csharpType = "decimal"; break;case "float": csharpType = "double"; break;case "image": csharpType = "byte[]"; break;case "int": csharpType = "int"; break;case "money": csharpType = "decimal"; break;case "nchar": csharpType = "string"; break;case "ntext": csharpType = "string"; break;case "numeric": csharpType = "decimal"; break;case "nvarchar": csharpType = "string"; break;case "real": csharpType = "Single"; break;case "smalldatetime": csharpType = "DateTime"; break;case "smallint": csharpType = "short"; break;case "smallmoney": csharpType = "decimal"; break;case "sql_variant": csharpType = "object"; break;case "sysname": csharpType = "object"; break;case "text": csharpType = "string"; break;case "time": csharpType = "TimeSpan"; break;case "timestamp": csharpType = "byte[]"; break;case "tinyint": csharpType = "byte"; break;case "uniqueidentifier": csharpType = "Guid"; break;case "varbinary": csharpType = "byte[]"; break;case "varchar": csharpType = "string"; break;case "xml": csharpType = "string"; break;default: csharpType = "object"; break;}return csharpType;}public static Type MapCommonType(string dbtype){if (string.IsNullOrEmpty(dbtype)) return Type.Missing.GetType();dbtype = dbtype.ToLower();Type commonType = typeof(object);switch (dbtype){case "bigint": commonType = typeof(long); break;case "binary": commonType = typeof(byte[]); break;case "bit": commonType = typeof(bool); break;case "char": commonType = typeof(string); break;case "date": commonType = typeof(DateTime); break;case "datetime": commonType = typeof(DateTime); break;case "datetime2": commonType = typeof(DateTime); break;case "datetimeoffset": commonType = typeof(DateTimeOffset); break;case "decimal": commonType = typeof(decimal); break;case "float": commonType = typeof(double); break;case "image": commonType = typeof(byte[]); break;case "int": commonType = typeof(int); break;case "money": commonType = typeof(decimal); break;case "nchar": commonType = typeof(string); break;case "ntext": commonType = typeof(string); break;case "numeric": commonType = typeof(decimal); break;case "nvarchar": commonType = typeof(string); break;case "real": commonType = typeof(Single); break;case "smalldatetime": commonType = typeof(DateTime); break;case "smallint": commonType = typeof(short); break;case "smallmoney": commonType = typeof(decimal); break;case "sql_variant": commonType = typeof(object); break;case "sysname": commonType = typeof(object); break;case "text": commonType = typeof(string); break;case "time": commonType = typeof(TimeSpan); break;case "timestamp": commonType = typeof(byte[]); break;case "tinyint": commonType = typeof(byte); break;case "uniqueidentifier": commonType = typeof(Guid); break;case "varbinary": commonType = typeof(byte[]); break;case "varchar": commonType = typeof(string); break;case "xml": commonType = typeof(string); break;default: commonType = typeof(object); break;}return commonType;}}#endregion#> <#@ include file="$(ProjectDir)DbHelper.ttinclude" #>

    DbHelper相對比較復雜,把一些常用操作進行了簡單封裝,因此放到一個單獨的文件里面進行引用,可以方便的進行復用,這里DbHelper的后綴名使用ttinclude,這里的后綴名可以隨便起,按照微軟的建議:用于include的文件盡量不要使用.tt做后綴名

  • 在頁面底部定義一些常用變量,以方便操作 <#+public class config{public static readonly string ConnectionString="Data Source=(local);Integrated Security=true;Initial Catalog=Northwind;";public static readonly string DbDatabase="Northwind";public static readonly string TableName="Customers";} #>

    這里我們把數據庫連接串和數據庫、表名字定義一下,方便修改和使用

  • 最后來編寫用于實體類生成的代碼 //------------------------------------------------------------------------------ // <auto-generated> // 此代碼由T4模板自動生成 // 生成時間 <#=DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")#> by 懶惰的肥兔 // 對此文件的更改可能會導致不正確的行為,并且如果 // 重新生成代碼,這些更改將會丟失。 // </auto-generated> //------------------------------------------------------------------------------using System; namespace T4ConsoleApplication.Entities { public class <#=config.TableName#>{<# foreach(DbColumn column in DbHelper.GetDbColumns(config.ConnectionString, config.DbDatabase, config.TableName)){#>/// <summary>/// <#=column.Remark#>/// </summary> public <#= column.CSharpType#><# if(column.CommonType.IsValueType && column.IsNullable){#>?<#}#> <#=column.ColumnName#> { get; set; }<#}#> } }
  • 全部完成后我們的Customers.tt文件就編寫好了 <#@ template debug="false" hostspecific="false" language="C#" #> <#@ output extension=".cs" #> <#@ assembly name="System.Core.dll" #> <#@ assembly name="System.Data.dll" #> <#@ assembly name="System.Data.DataSetExtensions.dll" #> <#@ assembly name="System.Xml.dll" #> <#@ import namespace="System" #> <#@ import namespace="System.Xml" #> <#@ import namespace="System.Linq" #> <#@ import namespace="System.Data" #> <#@ import namespace="System.Data.SqlClient" #> <#@ import namespace="System.Collections.Generic" #> <#@ import namespace="System.IO" #> <#@ include file="$(ProjectDir)DbHelper.ttinclude" #> //------------------------------------------------------------------------------ // <auto-generated> // 此代碼由T4模板自動生成 // 生成時間 <#=DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")#> by 懶惰的肥兔 // 對此文件的更改可能會導致不正確的行為,并且如果 // 重新生成代碼,這些更改將會丟失。 // </auto-generated> //------------------------------------------------------------------------------using System; namespace T4ConsoleApplication.Entities { public class <#=config.TableName#>{<# foreach(DbColumn column in DbHelper.GetDbColumns(config.ConnectionString, config.DbDatabase, config.TableName)){#>/// <summary>/// <#=column.Remark#>/// </summary> public <#= column.CSharpType#><# if(column.CommonType.IsValueType && column.IsNullable){#>?<#}#> <#=column.ColumnName#> { get; set; }<#}#> } }<#+public class config{public static readonly string ConnectionString="Data Source=(local);Integrated Security=true;Initial Catalog=Northwind;";public static readonly string DbDatabase="Northwind";public static readonly string TableName="Customers";} #>

    進行保存后會自動生成Customers.cs文件

    //------------------------------------------------------------------------------ // <auto-generated> // 此代碼由T4模板自動生成 // 生成時間 2012-07-18 17:51:26 by 懶惰的肥兔 // 對此文件的更改可能會導致不正確的行為,并且如果 // 重新生成代碼,這些更改將會丟失。 // </auto-generated> //------------------------------------------------------------------------------using System; namespace T4ConsoleApplication.Entities { public class Customers{/// <summary>/// /// </summary> public string CustomerID { get; set; }/// <summary>/// /// </summary> public string CompanyName { get; set; }/// <summary>/// /// </summary> public string ContactName { get; set; }/// <summary>/// /// </summary> public string ContactTitle { get; set; }/// <summary>/// /// </summary> public string Address { get; set; }/// <summary>/// /// </summary> public string City { get; set; }/// <summary>/// /// </summary> public string Region { get; set; }/// <summary>/// /// </summary> public string PostalCode { get; set; }/// <summary>/// /// </summary> public string Country { get; set; }/// <summary>/// /// </summary> public string Phone { get; set; }/// <summary>/// /// </summary> public string Fax { get; set; }} }

    ?

      至此完整演示了怎樣一步步根據數據庫生成實體類的操作,是不是很簡單,如對語法和操作不理解的地方可以參考T4模版引擎之基礎入門,稍微用心研究下,輕松打造屬于自己的代碼生成器。

  •   本文簡單介紹了基于單個模板生成數據庫實體類的示例,離具體實用還有一定的距離,畢竟總不能為每個數據表建一個模板吧,下一篇將揭曉如何通過單個T4模板生成多個文件,以及自動生成整個數據庫的所有實體類,敬請期待

      下班了,拍拍屁股走人。。。

    源碼:T4ConsoleApplication.rar

    注:此文章屬懶惰的肥兔原創,版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文鏈接:http://www.cnblogs.com/lzrabbit/archive/2012/07/18/2597953.html

    若您覺得這篇文章還不錯請點擊下右下角的推薦,有了您的支持才能激發作者更大的寫作熱情,非常感謝。

    如有問題,可以通過lzrabbit@126.com聯系我。

    總結

    以上是生活随笔為你收集整理的[转]T4模版引擎之生成数据库实体类的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    色婷婷视频网 | 九九久久在线看 | 成年人免费在线观看网站 | 亚洲小视频在线观看 | 国产精品一区二区久久精品爱涩 | 亚洲精品乱码久久久久久蜜桃不爽 | 丝袜精品视频 | 天堂av官网| 婷婷六月网 | 欧美一级在线观看视频 | 久操视频在线播放 | 亚洲一级电影在线观看 | 色偷偷人人澡久久超碰69 | 国产精品久久久久久久久软件 | 麻豆视频免费入口 | 99久久久国产精品 | 欧美一级性生活片 | 日韩女同一区二区三区在线观看 | 成人av电影在线播放 | 国产美女视频网站 | 日韩伦理片一区二区三区 | 亚洲成人免费 | 91九色在线视频 | 日韩一区二区三区在线观看 | 久久久久综合精品福利啪啪 | 久久久国产成人 | 欧美一二在线 | 日韩中文在线播放 | 亚洲国产美女精品久久久久∴ | 五月婷婷,六月丁香 | 亚洲午夜久久久久久久久久久 | 国产精华国产精品 | 日本黄色免费网站 | 日韩a欧美 | 精品国产精品久久一区免费式 | 国产一卡在线 | 人人网av| 91免费观看视频网站 | 五月天久久综合网 | 五月开心六月伊人色婷婷 | www.综合网.com | 美女视频黄是免费的 | 国内精品久久久久久久久久清纯 | 国产视频欧美视频 | 91av视频免费在线观看 | 天天射天天操天天干 | 久久试看 | 免费在线a| 天天干.com| 欧美一级视频在线观看 | 超碰久热| 国产原创在线观看 | 一区二区三区在线观看 | 超碰97免费 | 97香蕉超级碰碰久久免费软件 | 婷婷国产v亚洲v欧美久久 | 九九热在线免费观看 | 探花视频在线观看免费 | 91九色porny蝌蚪主页 | 日韩a欧美| 欧美日韩高清免费 | 国产亚洲视频系列 | 亚洲五月 | 热久久精品在线 | 国产99亚洲 | 99在线精品视频观看 | 中文字幕色站 | 国产手机av| 久久不射电影网 | 国产一在线精品一区在线观看 | 00av视频| 狠狠成人| 在线 视频 亚洲 | 免费观看av | 香蕉97视频观看在线观看 | 奇米7777狠狠狠琪琪视频 | 成人黄色国产 | 欧美激情综合五月色丁香 | 亚洲成a人片在线观看网站口工 | 成人免费视频观看 | 国产精品青青 | 国产一区电影在线观看 | 亚洲精品玖玖玖av在线看 | 亚洲国产午夜视频 | 欧美在线视频免费 | 91在线一区| 日韩视频二区 | 色视频在线看 | 97夜夜澡人人爽人人免费 | 久草视频在线新免费 | 韩日在线一区 | 成人免费观看av | 婷婷五天天在线视频 | 97超碰在线久草超碰在线观看 | 2019中文字幕网站 | 一区二区三区在线电影 | 一区 二区电影免费在线观看 | 成人丁香花 | 日韩免费观看一区二区三区 | 超碰在线色 | avav片| 国产精品久久久久久久久搜平片 | 亚洲精品午夜久久久久久久 | 激情一区二区三区欧美 | 欧洲视频一区 | 免费激情在线电影 | av丝袜在线 | 国产亚洲视频中文字幕视频 | 国产精品观看在线亚洲人成网 | 一级性视频| 在线涩涩 | 2018亚洲男人天堂 | 国产乱老熟视频网88av | 欧美一区二区三区在线视频观看 | 国产99久久久精品 | 久久精品欧美视频 | 久久ww| 国产精品一区二区久久久 | 国产一区二区久久久久 | 国产精品久久久久一区二区三区 | 日韩在线视频国产 | 亚洲视频电影在线 | 久久黄色网址 | 又长又大又黑又粗欧美 | 亚洲专区在线播放 | 天天av在线播放 | 欧美日韩在线视频一区二区 | 久久久这里有精品 | 777视频在线观看 | 色偷偷人人澡久久超碰69 | 欧美a在线看 | www.夜夜| 超碰公开在线观看 | 国产精品久久久视频 | 91麻豆精品国产91久久久无限制版 | 99av国产精品欲麻豆 | 午夜精品久久久久久中宇69 | 国产成人精品一区二区三区免费 | 日韩电影久久久 | 国产成人777777 | 亚洲欧洲精品一区二区精品久久久 | 福利视频 | 91精品国产高清自在线观看 | 又爽又黄又无遮挡网站动态图 | 日本三级不卡视频 | 亚洲国产欧美一区二区三区丁香婷 | 青草视频在线播放 | 欧美日韩一区二区在线观看 | 午夜视频在线观看一区二区 | 国产对白av | 欧美精品久久久久 | 国产视频亚洲 | 久久精品国产精品亚洲 | 久久久九色精品国产一区二区三区 | 久久av网址 | 久久国产精品一国产精品 | aaa毛片视频| 国产精品成人一区二区三区吃奶 | 国产精品美女久久久久久久 | 成人在线视频论坛 | 91亚洲网| 国产真实精品久久二三区 | 热热热热热色 | 日韩久久久久久久久久久久 | 97精品国自产拍在线观看 | 中文字幕黄色 | 欧美日韩高清一区二区 国产亚洲免费看 | 九九免费在线观看视频 | 在线观看成人 | 亚洲在线观看av | 国产 亚洲 欧美 在线 | 激情综合网在线观看 | 在线直播av | 夜色成人av | 亚洲欧洲国产视频 | 少妇精品久久久一区二区免费 | 日韩欧三级 | 四虎影视成人 | 国产免费午夜 | 免费高清无人区完整版 | 一区二区三区不卡在线 | 在线观看免费av网站 | 久久精品欧美一区 | 蜜臀久久99精品久久久无需会员 | 天天干天天操天天搞 | 九九免费在线观看 | 中文字幕 成人 | 中文av一区二区 | 亚洲精品动漫久久久久 | 99999精品 | 在线视频免费观看 | 久久人人射 | 欧美国产高清 | 欧美与欧洲交xxxx免费观看 | 精品国产一区二区三区久久久蜜臀 | 亚洲国产精品久久 | 91成人破解版 | 亚洲不卡av一区二区三区 | av成人免费在线观看 | 欧美精品日韩 | 在线www色 | 亚洲精品国偷自产在线99热 | 国产精品日韩欧美一区二区 | 色综合久久88色综合天天人守婷 | 97超碰人人在线 | 精品视频久久久久久 | 五月天电影免费在线观看一区 | 免费看日韩片 | 美女搞黄国产视频网站 | 国产麻豆视频网站 | 极品久久久久久久 | 国产一级片毛片 | 欧美性久久久久久 | 久久国产欧美日韩 | 久久香蕉电影网 | 久久精品视频在线观看免费 | 国产一区 在线播放 | 天天操网址 | 激情综合网五月激情 | 国产成人福利 | 国产精品日韩久久久久 | 91三级在线观看 | 我要色综合天天 | 激情视频区 | 黄色网中文字幕 | 日韩中文字幕免费在线播放 | 成年人在线看片 | 国产999精品久久久久久绿帽 | 国产精品久久久久久久久久尿 | 国产黄色片网站 | 91九色视频在线播放 | 亚洲一二视频 | 国产色拍| 九色精品免费永久在线 | 午夜av激情 | 亚洲视频999 | 欧美福利在线播放 | 五月婷婷在线播放 | 久久香蕉国产 | 国产精品一区二区中文字幕 | 深夜免费小视频 | 97在线视频观看 | 免费在线黄色av | 久久久久久久久久久久电影 | 五月天狠狠操 | 精品国产黄色片 | 午夜免费在线观看 | 天天爱天天 | 96久久久 | 欧美日本在线视频 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 成人久久久电影 | 免费观看一级视频 | 日韩一区视频在线 | 黄色免费大全 | japanese黑人亚洲人4k | 丝袜美腿在线 | 日韩精品一区二区三区在线播放 | 亚洲国产成人在线 | 最新精品视频在线 | 高潮久久久久久久久 | 日韩资源在线观看 | 亚洲国产精品久久久久久 | 狠色在线 | 国产做爰视频 | 免费视频久久久久久久 | 天堂入口网站 | 成年人app网址 | 人人看97 | 日韩精品一区二区在线 | 天天做日日爱夜夜爽 | 色99久久 | 欧美日韩大片在线观看 | 免费99精品国产自在在线 | 人人爽人人插 | 久久久国产精品一区二区中文 | 中文在线a在线 | 在线观看的a站 | 激情久久久久久久久久久久久久久久 | 婷婷色中文网 | 精品在线观看国产 | 免费在线观看毛片网站 | 亚洲国产成人精品在线观看 | 亚洲精品小视频 | 亚洲精品一区二区精华 | 韩国精品一区二区三区六区色诱 | 99性视频| 中文字幕 国产专区 | 久久国产成人午夜av影院潦草 | 综合铜03| 欧美日韩在线观看不卡 | 欧美久久久久久久久 | 二区精品视频 | 成人91在线 | 18岁免费看片 | 色综合久久88色综合天天人守婷 | 久产久精国产品 | 成人在线一区二区三区 | 国产精品麻| 91在线日韩| 国产免费叼嘿网站免费 | 在线免费观看羞羞视频 | 国产精品一区二区吃奶在线观看 | 丁香资源影视免费观看 | 精品国产99国产精品 | 国产精品久久久久久久久大全 | 九九视频一区 | 伊人亚洲综合网 | 亚洲精品乱码久久久久v最新版 | 天堂网在线视频 | 国产精品成人久久久 | 亚洲一级片在线观看 | 亚洲精品福利在线 | 亚洲视频axxx | 精品在线一区二区三区 | 亚洲综合在线视频 | 美女视频黄免费网站 | 91免费观看网站 | 国产小视频在线免费观看视频 | 天天干天天操天天入 | 久久成人麻豆午夜电影 | 黄色小视频在线观看免费 | 日韩av看片 | 日韩理论在线 | 国产又粗又猛又色又黄网站 | 成人av网站在线 | 精品亚洲成a人在线观看 | 亚洲91视频 | 成人在线视频在线观看 | 免费在线播放视频 | 亚洲国产中文字幕在线观看 | 人人讲 | 西西大胆啪啪 | 亚洲欧美日韩精品一区二区 | 亚洲色图激情文学 | 欧美美女一级片 | 日韩大片在线免费观看 | 日韩av午夜 | 免费高清影视 | 狠狠插狠狠干 | 公与妇乱理三级xxx 在线观看视频在线观看 | 在线电影a | 麻豆久久久 | 欧美精品亚州精品 | 国产精品成人久久久久久久 | 午夜国产在线 | 97超碰人人澡人人爱学生 | 亚洲无线视频 | 久久99精品国产一区二区三区 | 狠狠色综合网站久久久久久久 | 国产专区欧美专区 | 黄色的网站免费看 | 99精品国产福利在线观看免费 | 黄色大片日本免费大片 | 国产精品自产拍在线观看网站 | 人人爽人人爽av | 99热在线观看 | 正在播放国产一区 | 天天干天天操天天爱 | 日韩av视屏在线观看 | 国产一区视频免费在线观看 | 久久a v电影| 免费进去里的视频 | 色婷婷免费视频 | 狠狠色婷婷丁香六月 | 天天干一干 | av中文在线播放 | 在线一二区 | 999久久久久久久久 69av视频在线观看 | 狠狠狠色丁香婷婷综合久久五月 | 亚洲成av人片在线观看 | 黄色的视频网站 | 亚州日韩中文字幕 | 国产一区国产精品 | 欧美三人交 | 最新日韩精品 | 国产精品美女久久久久aⅴ 干干夜夜 | 久久久久久免费毛片精品 | 成人免费xyz网站 | 婷婷激情在线观看 | 欧美 亚洲 另类 激情 另类 | 顶级bbw搡bbbb搡bbbb | 国产成人精品日本亚洲999 | 日韩av电影手机在线观看 | 日韩激情片在线观看 | 婷婷在线色 | 69国产盗摄一区二区三区五区 | 国产精品嫩草影视久久久 | 天天视频色版 | 一区二区三区在线观看中文字幕 | 日韩一区二区三区观看 | 国产精品久久久久久久久蜜臀 | 婷婷免费视频 | 国产精品99久久免费观看 | 五月天色中色 | 久久国产区 | 国产高清日韩欧美 | 婷五月激情 | 国产欧美在线一区 | 久久免费国产精品1 | 91.dizhi永久地址最新 | 激情电影在线观看 | 超碰人人草 | 人人爽人人爱 | 午夜精品一区二区三区免费 | 国内精品久久久久久中文字幕 | 亚洲精品影院在线观看 | 日本精品小视频 | 一区二区激情视频 | 中文字幕精品www乱入免费视频 | 四虎国产精品成人免费4hu | 亚洲开心色 | 91av电影在线观看 | 欧美韩日视频 | 久二影院 | 一区 二区 精品 | 国产一级二级三级视频 | a级片久久久 | 国产 成人 久久 | 视频一区二区精品 | 色网址99| 在线观看岛国 | 精品一区二区免费 | 中文字幕二区三区 | 国产视频日韩视频欧美视频 | 91色九色 | 成人中文字幕+乱码+中文字幕 | 在线欧美中文字幕 | 亚洲理论片 | 中文字幕黄色av | 日本爱爱免费 | 精品国产一区二区三区久久久久久 | 国产成人在线综合 | 91在线视频 | 97国产精品亚洲精品 | 久久综合国产伦精品免费 | 国产美女精彩久久 | 久久视频免费在线 | 91精品久久久久久综合五月天 | 久久超级碰 | 国产一区自拍视频 | 国产中文字幕视频在线观看 | 国产理论一区二区三区 | 亚洲精品在线观看av | 久热电影| 九九精品视频在线观看 | 国产成a人亚洲精v品在线观看 | 久久美女精品 | 亚洲精品免费在线视频 | 免费a级黄色毛片 | 狠狠躁日日躁狂躁夜夜躁 | 黄色福利网 | 日本中文字幕视频 | 国产成人综合在线观看 | 怡红院av久久久久久久 | 亚洲视频精选 | 一区av在线播放 | 久久久久久久久久久电影 | 久久99视频免费 | 五月的婷婷 | 99精品欧美一区二区三区 | 91网址在线 | 欧美日韩高清一区 | 中文字幕资源在线 | 国产喷水在线 | 国产在线视频在线观看 | 99久久精品视频免费 | 欧美精品中文字幕亚洲专区 | 国产精品综合久久久久久 | 久草网站在线观看 | 麻豆一区二区三区视频 | 在线免费黄网站 | 五月婷在线视频 | 九九免费在线观看视频 | 999国产精品视频 | www.夜夜| 成人综合免费 | 日韩专区在线播放 | 96久久久 | 黄色网址a | 久久精品成人 | 又爽又黄又无遮挡网站动态图 | 91.dizhi永久地址最新 | 日韩在线免费观看视频 | 黄色av电影网 | 国产视频在线免费 | 国语黄色片| 欧美日韩一区二区三区视频 | 深夜免费福利 | 国产日韩欧美中文 | 天天综合导航 | 丰满少妇高潮在线观看 | 一区二区三区播放 | 在线a视频免费观看 | 国产精品视频永久免费播放 | 国产xxxxx在线观看 | 久久优| 亚洲黄色一级电影 | 日韩av影视在线 | 夜色资源站wwwcom | 国产精品毛片一区二区在线看 | 亚洲天天综合网 | 国产精品午夜免费福利视频 | 欧美性脚交 | 9999激情 | 欧美日韩1区 | 国产在线免费av | 日韩午夜三级 | 2021久久 | 国产精品18久久久 | 中文字幕国产精品 | 日韩精品久久中文字幕 | 91亚洲影院 | 欧美日韩一级在线 | 激情丁香综合五月 | www.888av| 日韩 精品 一区 国产 麻豆 | 亚洲色图色 | 91香蕉国产 | 日本中文字幕在线电影 | 日日夜夜婷婷 | 综合国产视频 | 久久天堂精品视频 | 日韩一区视频在线 | 美女网站免费福利视频 | 亚洲一二三区精品 | 国产精品久久免费看 | 五月综合婷 | 国产精品日韩欧美一区二区 | 精品久久久久久国产 | free. 性欧美.com| 中文字幕免费高 | 99久久精品免费看国产免费软件 | 97av视频| 丁香六月国产 | 国产手机在线精品 | 中文字幕资源在线 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 欧美日韩精品综合 | 久久社区视频 | 丁香婷婷电影 | 国产精品一区二区 91 | 99精品国产高清在线观看 | 亚洲国产中文在线观看 | 深夜免费小视频 | 四虎影院在线观看av | 99 视频 高清| www.天天操.com| 九九久久久久久久久激情 | 亚洲精品午夜一区人人爽 | 国产精品18久久久久久久久 | 麻豆免费精品视频 | 日本久久久久久科技有限公司 | 久久精品站 | 人人舔人人 | 激情av一区二区 | av噜噜噜在线播放 | 91| 天堂在线一区二区 | 在线导航av | 国产精品永久免费观看 | 在线a视频免费观看 | 亚洲一区二区精品3399 | 色婷在线 | 91久久精品一区二区二区 | 少妇高潮流白浆在线观看 | 久久国产精品成人免费浪潮 | 伊人黄| 99热国内精品 | 久久婷婷网 | 色婷婷天天干 | 国产一区欧美二区 | 免费国产视频 | 久久高清毛片 | 黄色网址中文字幕 | 中文日韩在线 | 日韩精品免费专区 | 色www免费视频 | 国产午夜不卡 | 国产成人三级在线播放 | 九九热.com| 综合在线观看色 | 久久欧美精品 | 中文字幕免费不卡视频 | 黄网站大全 | 91麻豆网| 亚洲精品国产精品国自 | 国产精品久久久久av免费 | 久草在线一免费新视频 | 射九九 | 亚洲成av片人久久久 | www.超碰97.com | 蜜桃视频在线观看一区 | 日韩精品一区二区三区免费视频观看 | 久久久久久久久久久免费av | 国产精品热 | 欧美一区免费在线观看 | 一区二区三区免费在线播放 | 欧美电影黄色 | 蜜臀av免费一区二区三区 | 国产永久免费 | 9i看片成人免费看片 | 97精品国产97久久久久久粉红 | 在线视频 影院 | 天天操夜夜操国产精品 | 日韩高清成人 | 亚洲国产精品一区二区尤物区 | 在线观看av中文字幕 | 香蕉视频日本 | 国产精品毛片一区视频播不卡 | 国产九色在线播放九色 | 日韩欧美一区二区三区黑寡妇 | 97精品超碰一区二区三区 | 欧美精品在线观看免费 | 午夜影院先 | 在线观看黄 | 9在线观看免费高清完整版在线观看明 | 国产手机免费视频 | 人人澡人人草 | www.久艹| 天天干天天拍天天操 | 欧美日本在线观看视频 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 国产资源站 | 探花视频免费在线观看 | 99精品欧美一区二区三区黑人哦 | 美女视频黄的免费的 | 美女国产免费 | 黄色的网站免费看 | 丁香久久婷婷 | 免费高清无人区完整版 | 成人免费在线视频 | 黄色三级网站在线观看 | 午夜免费电影院 | av高清一区 | 国产精品自在线 | 亚洲免费一级 | 久久久在线 | 97精品国产97久久久久久免费 | 中文字幕在线资源 | 99视频在线免费看 | a视频在线观看 | 日本精品视频在线观看 | 日韩成人一级大片 | 国产精品久免费的黄网站 | 黄色影院在线观看 | 成人app在线免费观看 | 成人在线观看影院 | 四虎成人精品在永久免费 | 中文字幕av在线电影 | 中文字幕在线视频一区二区三区 | 天天色视频 | 亚洲精品1区2区3区 超碰成人网 | 在线看v片成人 | 日日干视频 | 日本乱码在线 | 久久99亚洲网美利坚合众国 | 欧美日韩免费在线观看视频 | 欧美一级看片 | 国产视频在线观看一区 | 国产一区二区日本 | 日韩av网站在线播放 | 91精品国产九九九久久久亚洲 | 久久麻豆精品 | 久久国产精品一区二区三区 | 国产区av在线 | 91chinesexxx| 亚洲精品99久久久久中文字幕 | 91在线网址 | 成人国产精品免费观看 | 91精品国产综合久久久久久久 | 国产美女在线免费观看 | 黄色日本片 | 久草视频手机在线 | 免费日韩av片 | 天天综合中文 | 国产视频97 | 丁香六月久久综合狠狠色 | 午夜999 | 欧美精品日韩 | 日韩高清一二区 | www·22com天天操| 久久久久久久精 | 国产精品久久久久久久久久久久午 | av蜜桃在线 | 9ⅰ精品久久久久久久久中文字幕 | 蜜臀91丨九色丨蝌蚪老版 | 中文网丁香综合网 | 国产成人免费精品 | 久草爱| 久草在线久 | 又爽又黄在线观看 | 日韩精品一区二区三区丰满 | 日韩资源视频 | 国产大尺度视频 | 九九一级片 | 黄色福利网 | 国产精品美女久久 | 久久久久一区 | 国产精品中文字幕在线播放 | 久草免费手机视频 | 激情小说网站亚洲综合网 | 久久九九精品 | 伊人五月天 | 精品国精品自拍自在线 | 国产网红在线观看 | 国内精品久久久久久久久 | 亚在线播放中文视频 | 日韩欧美一区二区在线观看 | 日产乱码一二三区别在线 | 久久av一区二区三区亚洲 | 日本二区三区在线 | 久久久精品一区二区三区 | 最新国产福利 | 国产一区二区三区免费视频 | 超碰国产在线 | 99久久精品免费看国产免费软件 | 国产一级三级 | 日韩在线观看一区二区 | 91色一区二区三区 | 91av手机在线观看 | 亚洲精品中文字幕在线观看 | 欧美一级视频免费看 | 一区二区三区免费在线观看视频 | 激情综合亚洲精品 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 日日摸日日爽 | 女人高潮特级毛片 | 黄色高清视频在线观看 | 人人射人人澡 | 日本午夜在线亚洲.国产 | 一级片免费观看视频 | 在线观看久久久久久 | 日韩免费一二三区 | 亚洲资源一区 | 手机看国产毛片 | 日韩精品在线免费播放 | 久久成人综合视频 | 久草在线资源观看 | 国产一级片免费播放 | 欧美一级爽| 在线国产不卡 | 亚洲国产成人精品电影在线观看 | 国内视频| 在线国产能看的 | 亚洲最新av网址 | 亚洲欧美国产日韩在线观看 | 色婷婷丁香| 91日韩精品一区 | 1024在线看片 | 免费在线中文字幕 | 亚洲免费观看在线视频 | 色婷婷免费视频 | 国产精品一区二区白浆 | 在线观看视频免费播放 | 国产精品久久久久久999 | 天天艹天天操 | 亚洲一级国产 | 一本一本久久aa综合精品 | 亚洲综合视频网 | 夜夜躁日日躁 | 国产在线a | 亚洲精选在线观看 | 91精品1区2区 | 午夜视频在线网站 | 日韩免费一区二区 | 狠狠干天天操 | 中文字幕二区三区 | 欧洲一区二区在线观看 | 天堂av一区二区 | 伊人电影在线观看 | 中文字幕在线影视资源 | 亚洲天天在线日亚洲洲精 | 亚洲午夜精品电影 | 色多多视频在线 | 国产va精品免费观看 | 精品黄色在线观看 | 天天人人 | 在线播放视频一区 | 亚洲高清国产视频 | 亚洲国产精彩中文乱码av | 在线观看日本高清mv视频 | 欧美成年黄网站色视频 | 亚洲手机天堂 | 日韩免费久久 | 最近中文字幕在线 | 深夜免费福利在线 | 99日精品| 伊人影院得得 | 国产亚洲欧美一区 | 国产精品入口66mio女同 | 香蕉影院在线播放 | 国产小视频在线免费观看 | 国产在线观看,日本 | 去干成人网 | 97av影院 | 蜜桃av观看 | 中文字幕乱码在线播放 | 六月丁香在线观看 | 国产精品21区 | 91国内在线 | 中文字幕日韩电影 | 日韩精品一区二区三区三炮视频 | 亚洲涩涩色 | 久久热亚洲 | 国产免费人成xvideos视频 | 亚洲精品综合久久 | 天天爽人人爽夜夜爽 | 91资源在线观看 | 国产精品日韩 | 久久免费高清 | 中文字幕一区在线观看视频 | 激情www| 欧美精品一区二区在线观看 | 欧美日韩精品免费观看 | 亚洲成人xxx | 美女福利视频网 | 久久夜视频 | 最近最新中文字幕视频 | 亚洲日本va午夜在线电影 | 国产精品一码二码三码在线 | 五月激情视频 | 国产精品涩涩屋www在线观看 | 香蕉网在线观看 | 在线免费视 | 韩国av一区二区三区在线观看 | 亚洲视频www | 中文字幕亚洲在线观看 | 亚洲视频播放 | 九九免费在线观看视频 | 欧美一二区视频 | 缴情综合网五月天 | 美女久久久久久久久久 | www操操操 | 涩av在线| av 一区 二区 久久 | 人人爱爱 | 在线国产一区 | 91在线观看高清 | 欧美精品一级视频 | www.五月婷婷.com | 欧美看片| 又黄又爽又色无遮挡免费 | 国产美女被啪进深处喷白浆视频 | 久久综合九九 | 二区三区精品 | 午夜av激情| 亚洲日本一区二区在线 | 婷婷六月在线 | 亚洲国产人午在线一二区 | 99久久99精品| 91av视频在线免费观看 | 91久久久久久国产精品 | 婷婷久久网 | 91麻豆国产福利在线观看 | 久久久久久久18 | 麻豆av一区二区三区在线观看 | 亚洲精品午夜久久久久久久久久久 | 国产视频在| 91最新中文字幕 | 亚洲黄色在线 | 91精品一区国产高清在线gif | 国产主播大尺度精品福利免费 | 在线免费黄色毛片 | 日本黄色免费看 | 亚洲观看黄色网 | 亚洲精品字幕在线 | 精品国产黄色片 | 免费看污污视频的网站 | 色婷在线| 精品一二区 | 色噜噜日韩精品一区二区三区视频 | 天天做日日做天天爽视频免费 | 国产香蕉在线 | 黄色国产在线观看 | 香蕉视频国产在线观看 | 亚洲少妇激情 | 婷婷综合网 | 在线观看视频免费大全 | 亚洲国产中文字幕在线观看 | 日本黄色免费大片 | 精品国产大片 | 亚洲精品456在线播放第一页 | 国产精品久久久久久久久久妇女 | 人人插人人澡 | 狠狠色狠狠色综合系列 | 天堂网av 在线 | 综合天天色 | 婷婷综合久久 | 色婷婷激情四射 | 91在线网站 | 国产精品一区二区三区在线看 | 国产精品资源在线观看 | 国产日韩在线看 | 亚洲伊人成综合网 | 日韩深夜在线观看 | 久久大片网站 | 亚洲欧洲视频 | 99久久精品国产网站 | 欧美国产日韩在线观看 | 香蕉在线视频播放网站 | 久久婷婷激情 | 久久国产高清 | 96看片| 亚洲国产激情 | 成人免费在线看片 | 97超碰成人| 天天综合色天天综合 | 日韩色综合网 | 国产精品综合在线 | 久久久网站| 69精品在线 | av不卡在线看 | av亚洲产国偷v产偷v自拍小说 | 国产在线色 | 在线黄色毛片 | 日本中文字幕在线观看 | 久久影院精品 | 91精品免费在线视频 | 国产色拍拍拍拍在线精品 | 天天狠狠干 | 一区二区三区免费播放 | 天天操天天干天天干 | 天天操天天色天天射 | 中国美女一级看片 | 欧美一区二区免费在线观看 | 99热官网| 麻豆国产在线播放 | 四虎伊人 | 日韩精品一区二区三区高清免费 | 国产精品第十页 | 免费看的黄色 | 色福利网站 | 精品色综合 | 免费毛片一区二区三区久久久 | 2000xxx影视| 日本精品视频在线观看 | 久久久不卡影院 | 精品一区精品二区 | av成人在线网站 | 国产精品免费看久久久8精臀av | 99精品电影 | 日韩色视频在线观看 | 国产日韩欧美综合在线 | 日韩视频在线观看免费 | 欧美综合在线视频 | 天堂在线一区二区三区 | 欧美成人aa | 国产乱码精品一区二区三区介绍 | 国产精品成人国产乱一区 | 天天干天天操天天做 | 草久视频在线观看 | 亚洲国产精品成人综合 | 欧美巨大| 我要看黄色一级片 | 国产精品久久久久av福利动漫 | 91麻豆传媒 | 91三级在线观看 | 国产人成在线观看 | 日韩免费专区 | 欧美成人影音 | 91视频啊啊啊 | 久久国产亚洲 | 久久久久久国产精品久久 | 高潮久久久久久 | 亚洲精品午夜aaa久久久 | 五月天综合色 | 国产高清av免费在线观看 | 亚洲国产精品成人女人久久 | 日韩在线观看不卡 | 中文电影网 | 久章草在线 | 欧美精品乱码久久久久久按摩 | 国产九色91| 播五月婷婷| 日本中文一区二区 | 婷婷在线资源 | 国产99久久 | 免费福利在线 | 久久99网 | 日韩字幕 | 人人草在线视频 | 久久在线视频在线 | 91中文字幕在线视频 | 久久婷亚洲五月一区天天躁 | 欧美午夜视频在线 | 最近更新好看的中文字幕 | 久久久国产精华液 | 久久久久福利视频 | 国产综合在线视频 | www.久久精品视频 | 午夜免费福利片 | 有码中文字幕在线观看 | 国产亚洲片 | 精品免费视频123区 午夜久久成人 | 亚洲理论在线观看电影 | 色操插| 久章操 |