FreeSql (三十三)CodeFirst 類型映射

前面有介紹過幾篇 CodeFirst 內容文章,有

  • 《(二)自動遷移實體》(https://www.cnblogs.com/FreeSql/p/11531301.html)
  • 《(三)實體特性》(https://www.cnblogs.com/FreeSql/p/11531302.html)
  • 《(四)實體特性 Fluent Api》(https://www.cnblogs.com/FreeSql/p/11531304.html)
  • 《(十八)導航屬性》(https://www.cnblogs.com/FreeSql/p/11531352.html)

入門 FreeSql 前這些算是基礎教程,需要提前了解,接下來進入 CodeFirst 功能的深入了解。

類型映射是 ORM 最重要的功能之一,FreeSql 支持五大數據庫大多數數據庫類型,包括 mysql 的 enum/set,pgsql 的 hstore/jsonb 等等。。除此默認之外,還提供了自定義類型映射。

類型映射,需要考慮寫入(我們的寫入需要考慮 NoneParameter 和 Parameter)、讀取時的轉換工作,這部分擴展對個人使用者而言比較復雜,如有需要請提出您的 issues。

FreeSql 擁有較高容錯處理,如:當數據庫類型為 bigint 可空,實體類為 int 時,讀取數據不會出錯。

自定義類型映射(MapType)

class EnumTestMap {public Guid id { get; set; }[Column(MapType = typeof(string))]public ToStringMapEnum enum_to_string { get; set; }[Column(MapType = typeof(string))]public ToStringMapEnum? enumnullable_to_string { get; set; }[Column(MapType = typeof(int))]public ToStringMapEnum enum_to_int { get; set; }[Column(MapType = typeof(int?))]public ToStringMapEnum? enumnullable_to_int { get; set; }[Column(MapType = typeof(string))]public BigInteger biginteger_to_string { get; set; }[Column(MapType = typeof(string))]public BigInteger? bigintegernullable_to_string { get; set; }
}
public enum ToStringMapEnum { 中國人, abc, 香港 }

應該不需要解釋了吧?

BigInteger 都可以映射使用了,但請注意:僅僅是 CURD 方便, Equals == 判斷可以使用,無法實現 + - * / 等操作;

FreeSql.Extensions.JsonMap

上面的 MapType 只能處理有限的類型,JsonMap 是一個擴展包,實現屬性對象映射為 varchar 字段,寫入時使用 json.net 序列化,讀取時使用 json.net 反序列化。

安裝擴展包:

dotnet add package FreeSql.Extensions.JsonMap

fsql.UseJsonMap(); //開啟功能, fsql 為 IFreeSql 對象class TestConfig
{public int clicks { get; set; }public string title { get; set; }
}
[Table(Name = "sysconfig")]
public class S_SysConfig<T>
{[Column(IsPrimary = true)]public string Name { get; set; }[JsonMap]public T Config { get; set; }
}

默認類型映射

csharpMySqlSqlServerPostgreSQLOracleSqlite
bool | bool?bit(1)bitboolnumber(1)boolean
sbyte | sbyte?tinyint(3)smallintint2number(4)smallint
short | short?smallint(6)smallintint2number(6)smallint
int | int?int(11)intint4number(11)integer
long | long?bigint(20)bigintint8number(21)integer
byte | byte?tinyint(3) unsignedtinyintint2number(3)int2
ushort | ushort?smallint(5) unsignedintint4number(5)unsigned
uint | uint?int(10) unsignedbigintint8number(10)decimal(10,0)
ulong | ulong?bigint(20) unsigneddecimal(20,0)numeric(20,0)number(20)decimal(21,0)
double | double?doublefloatfloat8float(126)double
float | float?floatrealfloat4float(63)float
decimal | decimal?decimal(10,2)decimal(10,2)numeric(10,2)number(10,2)decimal(10,2)
Guid | Guid?char(36)uniqueidentifieruuidchar(36 CHAR)character(36)
TimeSpan | TimeSpan?timetimetimeinterval day(2) to second(6)bigint
DateTime | DateTime?datetimedatetimetimestamptimestamp(6)datetime
DateTimeOffset | DateTimeOffset?--datetimeoffsettimestamp(6) with local time zone-
Enum | Enum?enumintint4number(16)mediumint
FlagsEnum | FlagsEnum?setbigintint8number(32)bigint
byte[]varbinary(255)varbinary(255)byteablobblob
stringvarchar(255)nvarchar(255)varchar(255)nvarchar2(255)nvarchar(255)
MygisPointpoint----
MygisLineStringlinestring----
MygisPolygonpolygon----
MygisMultiPointmultipoint----
MygisMultiLineStringmultilinestring----
MygisMultiPolygonmultipolygon----
BitArray--varbit(64)--
NpgsqlPoint | NpgsqlPoint?--point--
NpgsqlLine | NpgsqlLine?--line--
NpgsqlLSeg | NpgsqlLSeg?--lseg--
NpgsqlBox | NpgsqlBox?--box--
NpgsqlPath | NpgsqlPath?--path--
NpgsqlPolygon | NpgsqlPolygon?--polygon--
NpgsqlCircle | NpgsqlCircle?--circle--
(IPAddress Address, int Subnet) | (IPAddress Address, int Subnet)?--cidr--
IPAddress--inet--
PhysicalAddress--macaddr--
NpgsqlRange<int> | NpgsqlRange<int>?--int4range--
NpgsqlRange<long> | NpgsqlRange<long>?--int8range--
NpgsqlRange<decimal> | NpgsqlRange<decimal>?--numrange--
NpgsqlRange<DateTime> | NpgsqlRange<DateTime>?--tsrange--
PostgisPoint--geometry--
PostgisLineString--geometry--
PostgisPolygon--geometry--
PostgisMultiPoint--geometry--
PostgisMultiLineString--geometry--
PostgisMultiPolygon--geometry--
PostgisGeometry--geometry--
PostgisGeometryCollection--geometry--
Dictionary<string, string>--hstore--
JToken--jsonb--
JObject--jsonb--
JArray--jsonb--
數組--以上所有類型都支持--

以上類型和長度是默認值,可手工設置,如 string 屬性可指定 [Column(DbType = "varchar(max)")]

系列文章導航

  • (一)入門

  • (二)自動遷移實體

  • (三)實體特性

  • (四)實體特性 Fluent Api

  • (五)插入數據

  • (六)批量插入數據

  • (七)插入數據時忽略列

  • (八)插入數據時指定列

  • (九)刪除數據

  • (十)更新數據

  • (十一)更新數據 Where

  • (十二)更新數據時指定列

  • (十三)更新數據時忽略列

  • (十四)批量更新數據

  • (十五)查詢數據

  • (十六)分頁查詢

  • (十七)聯表查詢

  • (十八)導航屬性

  • (十九)多表查詢

  • (二十)多表查詢 WhereCascade

  • (二十一)查詢返回數據

  • (二十二)Dto 映射查詢

  • (二十三)分組、聚合

  • (二十四)Linq To Sql 語法使用介紹

  • (二十五)延時加載

  • (二十六)貪婪加載 Include、IncludeMany、Dto、ToList

  • (二十七)將已寫好的 SQL 語句,與實體類映射進行二次查詢

  • (二十八)事務

  • (二十九)Lambda 表達式

  • (三十)讀寫分離

  • (三十一)分區分表

  • (三十二)Aop

  • (三十三)CodeFirst 類型映射

  • (三十四)CodeFirst 遷移說明

  • (三十五)CodeFirst 自定義特性

轉載于:https://www.cnblogs.com/FreeSql/p/11531543.html

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

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

相關文章

FreeSql (三十四)CodeFirst 遷移說明

FreeSql 支持 CodeFirst 遷移結構至數據庫&#xff0c;這應該是(O/RM)必須標配的一個功能。 與其他(O/RM)不同FreeSql支持更多的數據庫特性&#xff0c;而不只是支持基礎的數據類型&#xff0c;這既是優點也是缺點&#xff0c;優點是充分利用數據庫特性輔助開發&#xff0c;缺點…

曾國藩家訓:三個地方看一個家庭的興敗

第一看&#xff1a;看子孫睡到幾點&#xff0c;假如睡到太陽都已經升得很高的時候才起來&#xff0c;那代表這個家族會慢慢懈怠下來;第二看&#xff1a;看子孫有沒有做家務&#xff0c;因為勤勞、勞動的習慣影響一個人一輩子;第三看&#xff1a;看后代子孫有沒有在讀圣賢的經典…

Linux 查看文件指定行數 內容

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1、tail date.log 輸出文件末尾的內容&#xff0c;默認10行 tail -20 date.log 輸出最后20行的內容 tail -n -20…

FreeSql (三十五)CodeFirst 自定義特性

比如項目內已經使用了其它 orm&#xff0c;如 efcore&#xff0c;這樣意味著實體中可能存在 [Key]&#xff0c;但它與 FreeSql [Column(IsPrimary true] 不同。 Q&#xff1a; FreeSql 實體特性為啥這么別扭&#xff1f; A&#xff1a; 為了考慮一致性用法&#xff0c;全部封裝…

相隨心轉,枯榮立現

宋朝時&#xff0c;有高孝標和高孝積兩個雙胞胎兄弟&#xff0c;舉止言談和才思穎悟都象同一人。十六歲時&#xff0c;他們一齊考上秀才。婚后&#xff0c;父母為使媳婦能辨認丈夫&#xff0c;命令他們穿著不同衣裳和鞋子&#xff0c;以便辨認。有一天&#xff0c;他們遇到陳希…

查看 linux 硬件信息:內存、分區、系統、環境變量、防火墻、路由、端口監聽、進程、CPU...

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 一、linux CPU大小&#xff1b; 其實應該通過Physical Processor ID來區分單核和雙核。而Physical Processor ID可以從cpuinfo或者dmesg…

成功人士高效率的工作法

現在的人總是忙個不停&#xff0c;尤其企業家或高階主管大多身兼數職&#xff0c;為了達成工作目標&#xff0c;不得不經常加班。加上現在社交媒體和各種電子產品的誘惑讓時間更加不夠用了。每天察看郵件并即時回覆并不代表工作效率。如何排除干擾、克服惰性和避免超時工作才是…

R語言 線性回歸分析實例

y,X1,X2,X3 分別表示第 t 年各項稅收收入(億元)&#xff0c;某國生產總值GDP(億元)&#xff0c;財政支出(億元)和商品零售價格指數(%). (1) 建立線性模型&#xff1a; ① 自己編寫函數&#xff1a; > library(openxlsx) > data read.xlsx("22_data.xlsx",shee…

maven 工程 pom.xml 中 relativePath 的作用

Maven parent.relativePath 前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 默認值為../pom.xml 查找順序&#xff1a;relativePath元素中的地址–本地倉庫–遠程倉庫 設定一個空值將…

【Cef編譯】 CefSharp編譯失敗,檢測到“RuntimeLibrary”的不匹配項: 值“MT_StaticRelease”不匹配值“MD_DynamicRelease”...

編譯CefSharp生成后一個libcef_dll_wrapper.lib時&#xff0c;供CefSharp使用。結果CefSharp編譯的時候報錯。遇到以下異常&#xff1a;libcef_dll_wrapper.lib(binary_value_ctocpp.obj) : error LNK2038: 檢測到“RuntimeLibrary”的不匹配項: 值“MT_StaticRelease”不匹配值…

做老板欣賞的優秀員工 十大準則你達標嗎?

在一個企業里&#xff0c;什么樣的員工才是優秀的員工&#xff1f;優秀的員工擁有的怎樣的特質&#xff1f;同在一個公司工作&#xff0c;同樣的學歷與相仿的年齡&#xff0c;為什么有的人總是業績更好、工資更高、待遇更優秀、更能夠獲得老板的信任&#xff1f;這是目前許多企…

2 小時學會 springboot ( 附實例講解 )

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 一.什么是spring boot Takes an opinionated view of building production-ready Spring applications. Spring Boot favors convention…

管理拾穗:四眼原則

日前聽到一位現在服務于一家德國公司的朋友提及他們公司里的主管有一個四眼原則(Four eyes principle)&#xff0c;意思是如果有一份對外的重要文件要發出前&#xff0c;要經過兩個人(四個眼睛)看過&#xff0c;確定內容無誤之后&#xff0c;再發出。我也曾經在一家國際知名的德…

CEF編譯 執行gn args out\Release_GN_x86異常

gn args out\Debug_GN_x86 用來配置編譯參數&#xff0c;執行gn args out\Release_GN_x86時異常&#xff1a; Toolchain is out of date. Run "gclient runhooks" to update the toolchain, or set DEPOT_TOOLS_WIN_TOOLCHAIN0 to use the locally installed toolcha…

成功者刻骨銘心的一句話

您知道嗎&#xff1f;在這個世界上有許多名人和飛黃騰達的企業家。他們的成功除了靠自己的努力外&#xff0c;還靠來自他人的啟發&#xff0c;改變了他們的觀點&#xff0c;因而攀上了人生的巔峰。就像美國著名顧問公司蓋洛普&#xff08;Gallup&#xff09;的CEO吉姆?克利夫頓…

js中的鼠標右鍵點擊事件

https://www.cnblogs.com/sea-stream/p/9638870.html window.onload function(){//去掉默認的contextmenu事件&#xff0c;否則會和右鍵事件同時出現。document.oncontextmenu function(e){e.preventDefault();};document.getElementById("test").onmousedown fun…

拜托!面試請不要再問我 Spring Cloud 底層原理 ...

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 >出處&#xff1a; >https://www.fangzhipeng.com > 本文出自[方志朋的博客](http://blog.csdn.net/forezp) 本文為轉載文章&…

Django ORM 知識點總結

Query是如何工作的 Django QuerySet是懶執行的&#xff0c;只有訪問到對應數據的時候&#xff0c;才會去訪問數據庫。另外如果你再次讀取查詢到的數據&#xff0c;將不會觸發數據庫的訪問&#xff0c;而是直接從緩存獲取。 比如 # 這里不會訪問數據庫&#xff0c;origins只是一…

22天養成好習慣,一年后脫胎換骨!

第一個習慣&#xff1a; 每天對鏡子的自己微笑。 親愛的&#xff0c;如果你都不喜歡自己的話&#xff0c;怎么可能指望別人喜歡你&#xff1f; 第二個習慣&#xff1a; 每天用涼水洗臉。 涼水洗臉&#xff0c;皮膚健康&#xff1b;熱水洗腳&#xff0c;強似吃藥。 第三個習…

springCloud - 第1篇 - 服務的注冊 Eureka

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 PS&#xff1a;這個系列不定時更新&#xff0c;只是個人的學習分享&#xff0c; 內容全程參考書目&#xff1a; 《Spring Cloud 與 Do…