• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    ASP.NET Web API教程 創(chuàng)建域模型的方法詳細介紹

    來源:懂視網 責編:小采 時間:2020-11-27 22:42:16
    文檔

    ASP.NET Web API教程 創(chuàng)建域模型的方法詳細介紹

    ASP.NET Web API教程 創(chuàng)建域模型的方法詳細介紹:添加模型 There are three ways to approach Entity Framework: 有三種方式使用實體框架: Database-first: You start with a database, and Entity Framework generates the code. Database-first(數(shù)據(jù)庫先
    推薦度:
    導讀ASP.NET Web API教程 創(chuàng)建域模型的方法詳細介紹:添加模型 There are three ways to approach Entity Framework: 有三種方式使用實體框架: Database-first: You start with a database, and Entity Framework generates the code. Database-first(數(shù)據(jù)庫先

    添加模型
    There are three ways to approach Entity Framework:
    有三種方式使用實體框架:
    Database-first: You start with a database, and Entity Framework generates the code.
    Database-first(數(shù)據(jù)庫先行):從一個數(shù)據(jù)庫開始,然后實體框架生成相應代碼。
    Model-first: You start with a visual model, and Entity Framework generates both the database and code.
    Model-first(模型先行):先從一個可視化模型開始,然后實體框架生成數(shù)據(jù)庫和代碼。
    Code-first: You start with code, and Entity Framework generates the database.
    Code-first(代碼先行):先從代碼開始,然后實體框架生成數(shù)據(jù)庫。
    We are using the code-first approach, so we start by defining our domain objects as POCOs (plain-old CLR objects). With the code-first approach, domain objects don't need any extra code to support the database layer, such as transactions or persistence. (Specifically, they do not need to inherit from the EntityObject class.) You can still use data annotations to control how Entity Framework creates the database schema.

    我們打算使用code-first方法,因此,首先把域對象定義成POCO(plain-old CLR objects — 舊式無格式公共語言運行時(CLR)對象。很多人不太理解POCO對象,其實這種對象就像文本文件一樣,是一種最簡單、最原始、不帶任何格式的對象。因此,在各種環(huán)境中最容易對這類對象進行處理,包括用各類語言進行處理 — 譯者注)。利用code-first方法,域對象不需要任何附加代碼去支持數(shù)據(jù)庫層,如事務處理、持久化等。(特別是它們不需要繼承于EntityObject類。)你仍可以使用數(shù)據(jù)注解(data annotation)對實體框架如何創(chuàng)建數(shù)據(jù)庫方案進行控制。
    Because POCOs do not carry any extra properties that describe database state, they can easily be serialized to JSON or XML. However, that does not mean you should always expose your Entity Framework models directly to clients, as we'll see later in the tutorial.
    由于POCO不帶描述數(shù)據(jù)庫狀態(tài)的任何附加屬性,它們可以很容易地被序列化成JSON或XML。然而,這并不意味著你應當總是把實體框架模型直接暴露給客戶端,就像我們稍后在本教程所看到的那樣。

    We will create the following POCOs:
    我們將創(chuàng)建以下POCO:
    Product
    Order
    OrderDetail
    To create each class, right-click the Models folder in Solution Explorer. From the context menu, select Add and then select Class.
    要創(chuàng)建每個類,在“解決方案資源管理器”中右擊Models文件夾。從上下文菜單選擇“添加”,然后選擇“類”(如圖2-14所示)。
    WebAPI2-14 
    圖2-14. 創(chuàng)建POCO類
    Add a Product class with the following implementation:
    用以下實現(xiàn)添加一個Product類(產品類):
    代碼如下:


    namespace ProductStore.Models
    {
    using System.ComponentModel.DataAnnotations;
    public class Product
    {
    [ScaffoldColumn(false)]
    public int Id { get; set; }
    [Required]
    public string Name { get; set; }
    public decimal Price { get; set; }
    public decimal ActualCost { get; set; }
    }
    }

    By convention, Entity Framework uses the Id property as the primary key and maps it to an identity column in the database table. When you create a new Product instance, you won't set a value for Id, because the database generates the value.
    根據(jù)約定,實體框架用Id屬性作為主鍵,并把它映射成數(shù)據(jù)庫表中的標識列。當創(chuàng)建一個新的Product實例時,不必為Id設置值,因為數(shù)據(jù)庫會生成它。
    The ScaffoldColumn attribute tells ASP.NET MVC to skip the Id property when generating an editor form. The Required attribute is used to validate the model. It specifies that the Name property must be a non-empty string.
    ScaffoldColumn(支架列)注解屬性是告訴ASP.NET MVC,在生成編輯表單時,跳過這個Id屬性。Required注解屬性用于對模型進行驗證。它指定Name屬性必須是一個非空字符串。
    注:本文把ScaffoldConlumn、Required等這一類英文中叫做Annotation Attribute的屬性(Attribute)譯為注解屬性(Annotation Attribute),以便與類中的那些屬性加以區(qū)別 — 譯者注
    Add the Order class:
    添加Order類(訂單類):
    代碼如下:

    namespace ProductStore.Models
    {
    using System.Collections.Generic;
    using System.ComponentModel.DataAnnotations;
    public class Order
    {
    public int Id { get; set; }
    [Required]
    public string Customer { get; set; }
    // Navigation property
    // 導航屬性
    public ICollection<OrderDetail> OrderDetails { get; set; }
    }
    }

    Add the OrderDetail class:
    添加OrderDetail類(訂單細節(jié)類,或訂單詳情類):
    代碼如下:

    namespace ProductStore.Models
    {
    public class OrderDetail
    {
    public int Id { get; set; }
    public int Quantity { get; set; }
    public int OrderId { get; set; }
    public int ProductId { get; set; }
    // Navigation properties
    public Product Product { get; set; }
    public Order Order { get; set; }
    }
    }

    Foreign Key Relations
    外鍵關系
    An order contains many order details, and each order detail refers to a single product. To represent these relations, the OrderDetail class defines properties named OrderId and ProductId. Entity Framework will infer that these properties represent foreign keys, and will add foreign-key constraints to the database.
    一份訂單包含很多訂單細節(jié),而每個訂單細節(jié)指向一個單一的產品。為了表示這些關系,OrderDetail類定義了名稱為OrderId和ProductId的屬性。實體框架將會推斷出這些屬性表示的是外鍵,并會把外鍵約束添加到數(shù)據(jù)庫(見圖2-15)。
    WebAPI2-15 
    圖2-15. 外鍵關系
    The Order and OrderDetail classes also include “navigation” properties, which contain references to the related objects. Given an order, you can navigate to the products in the order by following the navigation properties.
    Order和OrderDetail類也包含了“導航(navigation)”屬性,導航屬性包含了對相關對象的引用。對于一份給定的訂單,可以根據(jù)導航屬性導航到這份訂單的產品。
    Compile the project now. Entity Framework uses reflection to discover the properties of the models, so it requires a compiled assembly to create the database schema.
    現(xiàn)在,編譯這個項目。實體框架會使用反射來發(fā)現(xiàn)這些模型的屬性,因此它需要編譯后的程序集來創(chuàng)建相應的數(shù)據(jù)庫方案(這里的數(shù)據(jù)庫方案意指數(shù)據(jù)庫、表結構以及關系等數(shù)據(jù)庫方面的定義 — 譯者注)。
    Configure the Media-Type Formatters
    配置Media-Type格式化器
    A media-type formatter is an object that serializes your data when Web API writes the HTTP response body. The built-in formatters support JSON and XML output. By default, both of these formatters serialize all objects by value.
    media-type(媒體類型)格式化器是Web API書寫HTTP響應體時對數(shù)據(jù)進行序列化的一個對象。內建的格式化器支持JSON和XML
    輸出。默認地,這兩種格式化都會按值序列化所有對象。
    Serialization by value creates a problem if an object graph contains circular references. That's exactly the case with the Order and OrderDetail classes, because each holds a reference to the other. The formatter will follow the references, writing each object by value, and go in circles. Therefore, we need to change the default behavior.
    如果對象圖含有循環(huán)引用,按值序列化會出現(xiàn)問題。這恰好是Order類和OrderDetail類的情況,因為每一個都含有對另一個的引用。格式化器會遵循這些引用,按值寫出每一個對象,于是會引起循環(huán)。因此,我們需要修改這種默認行為。
    In Solution Explorer, expand the App_Start folder and open the file named WebApiConfig.cs. Add the following code to the WebApiConfig class:
    在“解決方案資源管理器”中,展開App_Start文件夾,并打開名為WebApiConfig.cs的文件。將以下代碼添加到這個WebApiConfig.cs類中(以下代碼中的“新代碼” — 譯者注):
    代碼如下:

    public static class WebApiConfig
    {
    public static void Register(HttpConfiguration config)
    {
    config.Routes.MapHttpRoute(
    name: "DefaultApi",
    routeTemplate: "api/{controller}/{id}",
    defaults: new { id = RouteParameter.Optional }
    );
    // New code:
    // 新代碼:
    var json = config.Formatters.JsonFormatter;
    json.SerializerSettings.PreserveReferencesHandling =
    Newtonsoft.Json.PreserveReferencesHandling.Objects;
    config.Formatters.Remove(config.Formatters.XmlFormatter);
    }
    }

    This code sets the JSON formatter to preserve object references, and removes the XML formatter from the pipeline entirely. (You can configure the XML formatter to preserve object references, but it's a little more work, and we only need JSON for this application. For more information, see Handling Circular Object References.)
    這段代碼把JSON格式化器設置為防止對象引用(“新代碼”第二行的作用 — 譯者注),并把XML格式化器從管線(指HTTP的請求處理管線 — 譯者注)中完全刪除(“新代碼”最后一行的作用 — 譯者注)。(你也可以把XML格式化器配置成防止對象引用,但這還要做一點工作,而對于這個應用程序,我們只需要JSON。更多信息參閱“處理循環(huán)對象引用”

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    ASP.NET Web API教程 創(chuàng)建域模型的方法詳細介紹

    ASP.NET Web API教程 創(chuàng)建域模型的方法詳細介紹:添加模型 There are three ways to approach Entity Framework: 有三種方式使用實體框架: Database-first: You start with a database, and Entity Framework generates the code. Database-first(數(shù)據(jù)庫先
    推薦度:
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 国产精品久线在线观看| 麻豆精品成人免费国产片| 97精品国产福利一区二区三区 | 国产精品久久久久aaaa| 亚洲精品二三区| 87国产私拍福利精品视频| 91精品在线播放| 精品国产sm捆绑最大网免费站| 在线观看亚洲精品福利片| 久久青青草原精品国产不卡| 97精品人妻一区二区三区香蕉 | 亚洲国产成人乱码精品女人久久久不卡 | 国产A级毛片久久久精品毛片| 97久久超碰成人精品网站| 亚洲精品无码不卡在线播HE| 久久久久久国产精品免费免费| 成人精品一区二区久久久| 国产精品久久久久久搜索| 国产精品区免费视频| 日本午夜精品一区二区三区电影| 中文字幕无码精品三级在线电影| 欧美日韩精品一区二区三区不卡| 精品a在线观看| 精品福利一区二区三区精品国产第一国产综合精品 | 91在线视频精品| 国产精品高清视亚洲精品| 91精品美女在线| 国产成人精品免费视| 国产精品久久久久久久久| 久久精品国产免费| 在线精品视频播放| 国产91精品黄网在线观看 | 国产精品中文字幕在线观看| 成人区人妻精品一区二区不卡视频 | 2020国产精品永久在线| 国产精品毛片一区二区三区| 国产麻豆一精品一AV一免费| 国产精品对白刺激久久久| 国产成人精品白浆久久69| 99久久国语露脸精品国产| 久久精品国产精品国产精品污|