亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#實現根據實體類自動創建數據庫表

2020-01-24 00:52:58
字體:
來源:轉載
供稿:網友

.Net新手通常容易把屬性(Property)跟特性(Attribute)搞混,其實這是兩種不同的東西

屬性指的類中封裝的數據字段;而特性是對類、字段、方法和屬性等元素標注的聲明性信息

如下代碼(Id、Name為User的屬性,[DbKey]為Id的特性)

/// <summary>/// 用戶信息/// </summary>public class User{ [DbKey] public string Id { get; set; } public string Name { get; set; }}

特性分預定義特性和自定義特性,本節主要講述自定義特性

特性能解決什么問題?

假如現在需要通過定義一些實體類,動態創建出對應的數據庫表,該怎么做呢?

直接上代碼

namespace CustomerAttribute{ /// <summary> /// 數據庫主鍵 /// </summary> public class DbKey : Attribute { public string Description { get; set; } public DbKey() { } public DbKey(string description) { this.Description = description; } }}
namespace CustomerAttribute{ /// <summary> /// 用戶信息 /// </summary> public class User { [DbKey] public string Id { get; set; } public string Name { get; set; } } /// <summary> /// 用戶角色 /// </summary> public class UserRole { [DbKey("用戶ID")] public string UserId { get; set; } [DbKey("角色ID")] public string RoleId { get; set; } }}
namespace CustomerAttribute{ class Program { /// <summary> /// 獲取數據庫主鍵字段 /// </summary> /// <typeparam name="T"></typeparam> /// <returns></returns> private static IEnumerable<PropertyInfo> getDbKeyFields<T>() { // 獲取當前類中的公共字段 var fields = typeof(T).GetProperties(); // 查找有DbKey特性的字段 var keyFields = fields.Where(field => (DbKey)Attribute.GetCustomAttribute(field, typeof(DbKey)) != null); return keyFields; } private static string getDescription(PropertyInfo field) { string result = string.Empty; var dbKey = (DbKey)Attribute.GetCustomAttribute(field, typeof(DbKey)); if (dbKey != null) result = dbKey.Description; return result; } static void Main(string[] args) { try { var userKeyFields = getDbKeyFields<User>(); Console.WriteLine("User表的主鍵為:" + string.Join(",", userKeyFields.Select(field => field.Name))); var userRoleKeyFields = getDbKeyFields<UserRole>(); Console.WriteLine("UserRole表的主鍵為:" + string.Join(",", userRoleKeyFields.Select(field => field.Name))); foreach (PropertyInfo field in userRoleKeyFields) { string description = getDescription(field); Console.WriteLine(string.Format("{0}字段的描述信息為:{1}", field.Name, description)); } } catch (Exception ex) { Console.WriteLine(ex); } finally { Console.ReadLine(); } } }}

從上邊代碼可以看出來,特性本身也是類,繼承自Attribute類,我們可以對類、方法、屬性等元素進行特性標注

上邊是一個簡單示例,我們可以通過自定義[DbKey]特性,標注在需要設置主鍵的字段上

需要動態創建數據庫的時候,可以從實體類中解析出表名、字段名、主鍵字段、字段說明等等,然后生成創建數據庫表的腳本,動態創建數據庫表

創建數據庫的代碼,后邊可以進一步補充

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美在线日韩在线| www.亚洲男人天堂| 欧美成人午夜影院| 日韩精品极品毛片系列视频| 91久久夜色精品国产网站| 日韩在线免费观看视频| 国产午夜精品一区理论片飘花| 国产亚洲视频中文字幕视频| 日韩av一区二区在线观看| 亚洲国产精品yw在线观看| 超碰精品一区二区三区乱码| 精品欧美一区二区三区| 国产精品精品一区二区三区午夜版| 成人激情视频在线播放| 亚洲午夜女主播在线直播| 中文字幕亚洲一区二区三区| 日韩欧美国产中文字幕| 国产69久久精品成人看| 日韩精品视频中文在线观看| 欧美极品xxxx| 91久久综合亚洲鲁鲁五月天| 欧美在线观看视频| 5278欧美一区二区三区| 在线观看成人黄色| 国产亚洲精品久久| 国产精品视频xxx| 97婷婷涩涩精品一区| 国产在线视频不卡| 欧美色视频日本高清在线观看| 久久天天躁狠狠躁夜夜躁2014| 精品小视频在线| 欧美黑人又粗大| 久久99热精品这里久久精品| 欧美性猛交xxxx黑人猛交| 国产高清在线不卡| 91tv亚洲精品香蕉国产一区7ujn| 日本一区二区三区在线播放| 黄色成人在线播放| 国产精品久久一区主播| 高清在线视频日韩欧美| 欧美精品18videos性欧美| 久久综合免费视频| 欧美激情综合色综合啪啪五月| 国产一区欧美二区三区| 久久久久久久久久久网站| 亚洲激情在线观看| 久久精品小视频| 中文字幕日韩欧美精品在线观看| 欧美性一区二区三区| 日韩在线免费视频观看| 亚洲欧洲视频在线| 日韩欧美在线第一页| 欧美激情极品视频| 欧美久久精品一级黑人c片| 日本一区二区在线播放| 亚洲最大的成人网| 伊人久久综合97精品| 中文字幕国内精品| 免费91在线视频| 中文字幕久久精品| 在线国产精品播放| 欧美国产日韩一区二区三区| 亚洲电影免费观看| 亚洲欧美国产精品久久久久久久| 九九久久国产精品| 欧美激情区在线播放| 日韩经典中文字幕| 国产亚洲精品久久久| 日韩中文在线中文网三级| 91在线观看免费高清完整版在线观看| 久久精品2019中文字幕| 91麻豆桃色免费看| 精品福利一区二区| 亚洲一区国产精品| 日韩一区二区三区在线播放| 91香蕉国产在线观看| 国产精品永久免费观看| 亚洲欧美日本伦理| 国产一区二区三区欧美| 欧美国产精品日韩| 国产精品久久久久久久一区探花| 国产97在线观看| 国产一区二区三区在线免费观看| 亚洲视频自拍偷拍| 色偷偷偷综合中文字幕;dd| 亚洲福利在线看| 91久热免费在线视频| 日本不卡视频在线播放| 欧美成人免费va影院高清| 欧美在线观看www| 亚洲午夜av久久乱码| 久久精品久久久久久| 久久亚洲精品中文字幕冲田杏梨| 91影视免费在线观看| 国产日韩亚洲欧美| 懂色aⅴ精品一区二区三区蜜月| 日本欧美在线视频| 精品久久久av| 久久久久久网站| 亚洲男人天堂古典| 久久综合九色九九| 国产成人精彩在线视频九色| 91久久国产婷婷一区二区| 欧美影院成年免费版| 久久精品久久久久电影| 精品日本高清在线播放| 宅男66日本亚洲欧美视频| 国产成人aa精品一区在线播放| 欧美性xxxx极品hd欧美风情| 97视频国产在线| 黄色一区二区在线| 狠狠干狠狠久久| 亚洲一区二区三区久久| 91精品久久久久久| 欧美xxxx做受欧美| 成人黄色免费片| 亚洲福利影片在线| 国产精品高潮呻吟视频| 欧美中在线观看| 91色琪琪电影亚洲精品久久| 欧美成人激情视频免费观看| 亚洲女同性videos| 亚洲影院高清在线| 91精品91久久久久久| 成人午夜小视频| 国产精品久久久久久一区二区| 91国产视频在线| 97国产精品人人爽人人做| 国产日韩欧美91| 国产91色在线免费| 日韩一区二区三区在线播放| 久久久99久久精品女同性| 亚洲日韩中文字幕在线播放| 欧美性色xo影院| 91九色在线视频| 狠狠久久亚洲欧美专区| 欧美日韩综合视频| 欧美天天综合色影久久精品| 在线精品播放av| 久久久视频免费观看| 欧美电影免费观看高清完整| 精品久久久久久中文字幕大豆网| 亚洲专区在线视频| 亚洲第一网中文字幕| 久久精品美女视频网站| 夜夜狂射影院欧美极品| 97福利一区二区| 成人黄色影片在线| 欧美精品亚州精品| 欧美高清电影在线看| 国内成人精品视频| 一本色道久久88精品综合| 国精产品一区一区三区有限在线| 欧美成人高清视频| 国产精品久久久久久久9999| www欧美xxxx| 亚洲性猛交xxxxwww| 日本韩国在线不卡| 伊人av综合网| 欧美成人剧情片在线观看| 午夜免费在线观看精品视频| 国产一区二区三区中文| 尤物九九久久国产精品的分类| 亚洲精品永久免费|