Code First02---CodeFirst配置實體與數據庫映射的兩種方式

Code First有兩種配置數據庫映射的方式,一種是使用數據屬性DataAnnotation,另一種是Fluent API.

這兩種方式分別是什么呢?下面進行一一解釋:

DataAnnotation的配置方式需要你給定義實體和值對象的類和類中的屬性加上與數據庫映射相關的配置標簽。

比如說:我有一個實體類:Customers 按照Code First的規則,數據庫的表名應該是跟這個一致Customers,但是如果我想表名為Customer,那怎么才能讓實體識別到這個表名呢。

[Table(“CustomerInfo”)]

public class Customer·

{

???? …….

}

另外一種配置的方式是使用Fluent API,Code First Fluent API 是在DbContext中定義數據庫配置的一種方式。要使用Fluent API 就必須在你自定義的繼承自DbContext的類中重載OnModelCreating這個方法。這個方法的簽名如下:

?

protected override void OnModelCreating(DbModelBuilder modelBuilder)

通過modelBuilder這個對象的Entity<>泛型方法來配置DbContext中的每個類的數據庫映射。

我們可以通過Fluent API 配置數據表的名字:

protected override void OnModelCreating(DbModelBuilder modelBuilder)

{

?? modelBuilder.Entity<Customer>().ToTable(“CustomerInfo”)

}

?其實在業務中我們都用Fluent API的方式去配置,這樣才能提現出Code First的原則,即是代碼和數據存儲分離開來的理念。

好吧。說了這么多理論,下面介紹一個例子來介紹一下怎么使用Fluent API來實現。

?

那我們假設一個需求,假設我們的訂單管理系統處理的都是個人客戶,假設每個個人客戶都是domain中的實體,假設實體的標識符是每個人的身份證號。假設我們的客戶都是中國人,那么身份證號應該是18位。客戶的名字應該不會太長,中國人的名字一般不會超過十個字吧?性別用M和F標識,我們還記錄客戶的地址和聯系電話。我們假設客戶的聯系電話記錄中國境內客戶的手機號,現在的手機號一般都是13位。我們的實體類如下:

?

大家應該清楚按照Code First的規則,數據表的主鍵必須是int,并且名稱必須是Id或者類名+Id。我們Customer表默認的主鍵應該是public int CustomerId{get;set;}。string類型默認會映射為nvarchar(max)

我們應該怎么寫這個映射關系?

?

下面介紹關于數據庫字段怎么修改對應的設置

modelBuilder的Entity<T>方法的返回值都為EntityTypeConfiguration<T>


IsRequired():通過這個方法指定該列是not-null的。

HasMaxLength():設定nvarchar列的最大字符數。

HasPercision(percison,scale):設定decimal列的最大值和小數點后位數。

HasColumnType(“TypeName”):設定列的類型,但是指定的列的類型必須與類中的屬性的類型相兼容。這個兼容規則后面將詳細介紹。

HasDatabaseGeneratedOption(DatabaseGeneratedOption):指定列是否是自增長列。

DatabaseGeneratedOption有三個選項:Idnetity:自增長

None:非自增長

Computed:用于一些通過計算得到值的列。

modelBuilder的Entity<Customer>方法的返回值還有一個HasKey方法用于設置數據表的主鍵。

?

?總結:這一節主要介紹了實體跟數據庫表的對應映射。

?

轉載于:https://www.cnblogs.com/duyao/p/4671098.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/258567.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/258567.shtml
英文地址,請注明出處:http://en.pswp.cn/news/258567.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

sigmoid函數的數值穩定性

在深度學習中&#xff0c;我們常常選用sigmoid函數作為激活函數。sigmoid函數的具體形式如下&#xff1a; f(x)11e?xf(x)=\frac{1}{1+e^{-x}}曲線表示為&#xff1a; 再畫大一點&#xff0c;取x區間更大一些&#xff0c;則為&#xff1a; 顯然從圖像上看&#xff0c;sigmoid函…

查看CentOS版本方法

有以下命令可以查看&#xff1a; # lsb_release -a LSB Version: :core-3.1-ia32:core-3.1-noarch:graphics-3.1-ia32:graphics-3.1-noarchDistributor ID: CentOSDescription: CentOS release 5.4 (Final)Release: 5.4Codename: Final這個命令適用于所有的li…

windows遠程連接ubuntu 黑屏_Windows跟Windows遠程連接傳輸文件

關注奕奇科技&#xff0c;學習更多小妙招電腦小知識&#xff0c;值得收藏我們一般在使用windows遠程連接時需要傳輸文件該怎么辦&#xff1f;我們可以插入U盤導入導出&#xff0c;但這樣很是麻煩而且如果身邊暫時沒有U盤的情況就要通過社交工具傳播文件&#xff0c;大的文件也更…

思維導圖分析http之前端組成

思維導圖分析http前端組成全文總覽本文分為三個部分&#xff1a;前端組成&#xff0c;http協議&#xff0c;http服務器應用程序。http的應用按照我自己的理解分為前端應用以及后端應用&#xff0c;所以我分別寫了前端組成以及http服務器應用程序兩章&#xff0c;中間穿插了一章…

Linux命令工具基礎02 文件及目錄管理

文件及目錄管理 文件管理不外乎文件或目錄的創建、刪除、查詢、移動&#xff0c;有mkdir/rm/mv 文件查詢是重點&#xff0c;用find來進行查詢&#xff1b;find的參數豐富&#xff0c;也非常強大&#xff1b; 查看文件內容是個大的話題&#xff0c;文本的處理有太多的工具供我們…

caffe 關于Deconvolution的初始化注意事項

對于fcn&#xff0c;經常要使用到Deconvolution進行上采樣。對于caffe使用者&#xff0c;使用Deconvolution上采樣&#xff0c;其參數往往直接給定&#xff0c;不需要通過學習獲得。 給定參數的方式很有意思&#xff0c;可以通過兩種方式實現&#xff0c;但是這兩種方式并非完…

多目標進化優化_SDIM 學術講座|分解多目標優化與帕累托多任務學習

分解多目標優化與帕累托多任務學習2020年11月4日晚&#xff0c;香港城市大學電腦學系講座教授、博士生導師、IEEE Fellow張青富教授應我院王振坤教授的邀請&#xff0c;在線舉辦了一場主題為“分解多目標優化與帕累托多任務學習”的學術講座。此次講座采用線上和線下兩種渠道&a…

hibernate(nested transactions not supported)異常

org.hibernate.TransactionException: nested transactions not supported錯誤的解決方法&#xff01; 原因&#xff1a;事務沒有提交&#xff0c;事務提交后正常 Transaction tx session.beginTransaction(); tx.commit(); //缺少這句話轉載于:https://www.cnblogs.com/lmq-1…

Ubuntu使用Windows下的conio.h

把虛線框里面的內容粘貼進文檔文本里面 ---------------------------------------------------------------------------------------------------------- #include <termios.h>#include <stdio.h>static struct termios old, new;/* Initialize new terminal i/o …

安裝oracle-java,并覆蓋原先的OpenJDK

Centos默認安裝openJDK只安裝了java,沒有安裝javac.如果需要安裝javac&#xff0c;需要install the openjdk-8-jdk package。參考&#xff1a;http://openjdk.java.net/install/ 為了完整地安裝java&#xff0c;我們轉而選擇使用oracle-java&#xff0c;由于我們沒有root權限&a…

反射創建對象_如何應用Java反射技術靈活地創建程序類的對象實例

軟件項目實訓及課程設計指導——如何應用Java反射技術靈活地創建程序類的對象實例1、如何應用屬性配置文件實現對系統中的配置信息進行讀寫操作Java中的屬性配置文件主要可以作為軟件應用系統及項目的配置文件&#xff0c;比如許多J2EE的開源框架系統中都提供了屬性配置文件作為…

js回到頂部

2019獨角獸企業重金招聘Python工程師標準>>> <html xmlns"http://www.w3.org/1999/xhtml"> <head runat"server"> <title></title> <style type"text/css"> #control_pannel …

java 產生的固體物的基礎上 增刪改的SQL聲明

經過多次修改。最后版本。package com.power.sql;import java.lang.reflect.Field; import java.lang.reflect.Modifier; import java.util.List; import java.util.Vector;import org.apache.commons.lang3.reflect.FieldUtils; /*** author Gary Huang* 博客地址&#xff1a;…

OSEK簡介

What is OSEKA specification for an RTOS?With standard software interfaces (OS API)?Including intertask & interprocessor communication (COM)?Including network management (NM)?Including the language used to statically declare OS elements used in an a…

python中布爾型的值_在python中對于bool布爾值的取反操作

背景根據公司業務的需求&#xff0c;需要做一個對于mysql數據庫的大批量更新。腳本嘛也是干干單單。使用了redis的隊列做緩存&#xff0c;可以異步并發的多任務進行更新。有點難受的地方在于&#xff0c;請求訪問時&#xff0c;因為一些網速&#xff0c;速率之內的原因&#xf…

門道多:一次MaxCompute PS任務的問題排查之旅

關于PS是什么&#xff0c;可以參考一下以下兩個介紹&#xff1a;基于參數服務器的大規模在線學習算法和Parameter Server。更多問題可以咨詢玄樂。下面主要總結一下這回遇到一個PS任務跑不起來的問題排查過程。不想看過程的直接看最后一點總結就行。一 為什么要分享一個問題排查…

源碼安裝Bazel

有時候我們需要源碼安裝tensorflow&#xff0c;這時逃不過的第一步就是安裝Bazel,如果沒有root權限的時候&#xff0c;這時我們就需要源碼安裝Bazel了。下面是安裝步驟&#xff0c;參考&#xff1a;https://docs.bazel.build/versions/master/install-compile-source.html 1. E…

234. Palindrome Linked List

Given a singly linked list, determine if it is a palindrome. Follow up:Could you do it in O(n) time and O(1) space? 先找到鏈表中點&#xff0c;將第二部分反轉&#xff0c;然后比較兩部分鏈表的值。 /** * Definition for singly-linked list. * public class ListNo…

當查找名字的時候通過外圍作用域向外查找(如何理解)

int a;//#1int b;//#2namespace A{int c;//#3void fun(){int a;//#4使用(a);//從里查找已經聲明名字首先尋找內層花括號之內a找#3//會繼續查找使用(b);//從里查找已經聲明名字//首先尋找內層花括號之內沒有聲明b//繼續外層花括號&#xff08;namespace A&#xff09;內尋找沒有…

python 服務注冊_將python程序注冊為Ubuntu系統服務,并開機啟動的方法。

一、系統環境操作系統&#xff1a;ubuntu 18 (該版本已默認使用systemd作為init)python版本&#xff1a;3.6二、步驟(一)準備python程序1、在 /usr/bin/ 下新建python程序 svc-test.py# nano /usr/bin/svc-test.py#! /usr/bin/python3import timewhile True:f open(/tmp/svc-t…