欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#實(shí)現(xiàn)根據(jù)實(shí)體類自動(dòng)創(chuàng)建數(shù)據(jù)庫(kù)表

 更新時(shí)間:2016年12月16日 14:40:56   作者:天碼行空  
本文主要介紹了C#通過(guò)自定義特性實(shí)現(xiàn)根據(jù)實(shí)體類自動(dòng)創(chuàng)建數(shù)據(jù)庫(kù)表的方法。具有很好的參考價(jià)值,需要的朋友一起來(lái)看下吧

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

屬性指的類中封裝的數(shù)據(jù)字段;而特性是對(duì)類、字段、方法和屬性等元素標(biāo)注的聲明性信息

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

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

特性分預(yù)定義特性和自定義特性,本節(jié)主要講述自定義特性

特性能解決什么問(wèn)題?

假如現(xiàn)在需要通過(guò)定義一些實(shí)體類,動(dòng)態(tài)創(chuàng)建出對(duì)應(yīng)的數(shù)據(jù)庫(kù)表,該怎么做呢?

直接上代碼

namespace CustomerAttribute
{
 /// <summary>
 /// 數(shù)據(jù)庫(kù)主鍵
 /// </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("角色I(xiàn)D")]
 public string RoleId { get; set; }
 }
}
namespace CustomerAttribute
{
 class Program
 {
 /// <summary>
 /// 獲取數(shù)據(jù)庫(kù)主鍵字段
 /// </summary>
 /// <typeparam name="T"></typeparam>
 /// <returns></returns>
 private static IEnumerable<PropertyInfo> getDbKeyFields<T>()
 {
 // 獲取當(dāng)前類中的公共字段
 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();
 }
 }
 }
}

從上邊代碼可以看出來(lái),特性本身也是類,繼承自Attribute類,我們可以對(duì)類、方法、屬性等元素進(jìn)行特性標(biāo)注

上邊是一個(gè)簡(jiǎn)單示例,我們可以通過(guò)自定義[DbKey]特性,標(biāo)注在需要設(shè)置主鍵的字段上

需要?jiǎng)討B(tài)創(chuàng)建數(shù)據(jù)庫(kù)的時(shí)候,可以從實(shí)體類中解析出表名、字段名、主鍵字段、字段說(shuō)明等等,然后生成創(chuàng)建數(shù)據(jù)庫(kù)表的腳本,動(dòng)態(tài)創(chuàng)建數(shù)據(jù)庫(kù)表

創(chuàng)建數(shù)據(jù)庫(kù)的代碼,后邊可以進(jìn)一步補(bǔ)充

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • 利用C#/VB.NET實(shí)現(xiàn)將PDF轉(zhuǎn)為Word

    利用C#/VB.NET實(shí)現(xiàn)將PDF轉(zhuǎn)為Word

    眾所周知,PDF 文檔支持特長(zhǎng)文件,集成度和安全可靠性都較高,可有效防止他人對(duì) PDF 內(nèi)容進(jìn)行更改,所以在工作中深受大家喜愛(ài)。本文將分為兩部分介紹如何以編程的方式將 PDF 轉(zhuǎn)換為 Word,需要的可以參考一下
    2022-12-12
  • C#使用ThreadPriority設(shè)置線程優(yōu)先級(jí)

    C#使用ThreadPriority設(shè)置線程優(yōu)先級(jí)

    這篇文章介紹了C#使用ThreadPriority設(shè)置線程優(yōu)先級(jí)的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-04-04
  • C# 數(shù)組實(shí)例介紹(圖文)

    C# 數(shù)組實(shí)例介紹(圖文)

    數(shù)組即是一組相同類型組合在一起,使用一個(gè)通用的名稱,通過(guò)分配的下標(biāo)訪問(wèn)的數(shù)據(jù)集合中的元素。
    2014-08-08
  • Unity?UGUI的PointerEventData的介紹及使用

    Unity?UGUI的PointerEventData的介紹及使用

    這篇文章主要為大家介紹了Unity?UGUI的PointerEventData的介紹及使用,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • C#使用JavaScriptSerializer序列化時(shí)的時(shí)間類型處理

    C#使用JavaScriptSerializer序列化時(shí)的時(shí)間類型處理

    這篇文章主要為大家詳細(xì)介紹了C#使用JavaScriptSerializer序列化時(shí)的時(shí)間類型處理,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • C#調(diào)用webservice接口的最新方法教程

    C#調(diào)用webservice接口的最新方法教程

    webservice 可以用于分布式應(yīng)用程序之間的交互,和不同程序之間的交互。下面這篇文章主要給大家介紹了關(guān)于C#調(diào)用webservice接口的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友下面隨著小編來(lái)一起看看吧。
    2017-11-11
  • C#交錯(cuò)數(shù)組淺析

    C#交錯(cuò)數(shù)組淺析

    這里介紹C#交錯(cuò)數(shù)組,數(shù)組是具有同一類型的一組值,數(shù)組是引用類型的,因此存在內(nèi)存堆中。數(shù)組中的元素值可以在定義數(shù)組時(shí)賦予,也可以在定義數(shù)組后對(duì)單個(gè)元素進(jìn)行賦值
    2012-09-09
  • C#實(shí)現(xiàn)通過(guò)winmm.dll控制聲音播放的方法

    C#實(shí)現(xiàn)通過(guò)winmm.dll控制聲音播放的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)通過(guò)winmm.dll控制聲音播放的方法,很實(shí)用的功能,需要的朋友可以參考下
    2014-08-08
  • C#用鏈?zhǔn)椒椒ū磉_(dá)循環(huán)嵌套

    C#用鏈?zhǔn)椒椒ū磉_(dá)循環(huán)嵌套

    這篇文章主要介紹了C#用鏈?zhǔn)椒椒ū磉_(dá)循環(huán)嵌套的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • C#定位txt指定行的方法小例子

    C#定位txt指定行的方法小例子

    近日,在開(kāi)發(fā)CAD插件時(shí)需要定位TXT文件指定行并將其選中,在網(wǎng)絡(luò)找了一下沒(méi)有找到現(xiàn)成的,自己編了一個(gè)定位程序,實(shí)現(xiàn)了定位功能..與大家分享
    2013-04-04

最新評(píng)論