中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

LINQ to SQL數據表怎么用

發布時間:2021-12-01 10:14:12 來源:億速云 閱讀:257 作者:小新 欄目:編程語言

這篇文章主要為大家展示了“LINQ to SQL數據表怎么用”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“LINQ to SQL數據表怎么用”這篇文章吧。

在LINQ to SQL數據表里面都是用的DbConnection,而不是SQLConnection,這樣的話理論上可以支持所有的數據,但對于一些數據庫的支持可能不是太好。例如分頁,SQL Server 2000,SQL Server 2005,SQL Server 2008數據,使用LINQ的代碼都不一樣,而ACCESS和SQL Server 2000比較接近,就可以直接使用SQL Server 2000Provider。查了一些資料看到,理論有那個數據庫provider,就可以支持這種數據庫。也看了dbLINQ 0.8支持不同數據庫的源碼,但自己能力有限不能寫一個ACCESS的,還是用官方的吧。下邊說一下方法。

其實他不太麻煩,只是改一下,*.designer.cs文件里的代碼。因為ACCESS 不支持dbo,而LINQ to SQL數據表前面都有dbo.的前綴, [Table(Name="dbo.wjk3")],將dbo.去掉,不然的話,會提示你找不到dbo數據庫,這點上,自己走了不少彎路。在public partial class DDataContext: System.Data.LINQ.DataContext上邊加上, [Provider(typeof(System.Data.LINQ.SQLClient.SQL Server 2000Provider))]設定為SQL Server 2000Provider,不然的話 LINQ 里面的first 不能使用,另外分頁也不能使用,因為他默認的是SQL Server 2008Provider。

這一點很重要,到現在為止,基本上解決LINQ to ACCESS的使用,但還有一點問題,從數據庫讀取一條記錄,修改后使用SubmitChanges()更新,提示錯誤,不能修改,錯誤內容:找不到行或行已更改。這一點可以使用一些自定義方法來實現更新,使用ExecuteCommand()直接執行更新SQL語句來實現。感覺LINQ to SQL數據表的跟蹤,如果不適用SubmitChanges()更新的話,跟蹤也每太大的意義,實現跟蹤可能會降低系能,另外添加,刪除也依賴跟蹤,如果不使用跟蹤的話,還要擴展添加,刪除的方法。

  1. public partial class dbgame  

  2. {  

  3. public IQueryable<TEntity> Find<TEntity>(TEntity obj) where TEntity : class  

  4. {  

  5. //獲得所有property的信息  

  6. PropertyInfo[] properties = obj.GetType().
    GetProperties(BindingFlags.Public | BindingFlags.Instance);  

  7. //構造初始的query  

  8. IQueryable<TEntity> query = this.GetTable<TEntity>().AsQueryable<TEntity> ();  

  9. //遍歷每個property  

  10. foreach (PropertyInfo p in properties)  

  11. {  

  12. if (p != null)  

  13. {  

  14. Type t = p.PropertyType;  

  15. //加入object,Binary,和XDocument,支持sql_variant,imager 和xml等的影射。  

  16. if (t.IsValueType || t == typeof(string) || t == typeof(System.Byte[])  

  17. || t == typeof(object) || t == typeof(System.Xml.Linq.XDocument)  

  18. || t == typeof(System.Data.Linq.Binary))  

  19. {  

  20. //如果不為null才算做條件  

  21. if (p.GetValue(obj, null) != null)  

  22. {  

  23. if (((ColumnAttribute)(p.GetCustomAttributes(typeof(ColumnAttribute), 
    true)[0])).IsPrimaryKey && Convert.ToInt32(p.GetValue(obj, null)) == 0)  

  24. {  

以上是“LINQ to SQL數據表怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

揭西县| 丹寨县| 昆明市| 灌云县| 邢台市| 壤塘县| 伊金霍洛旗| 特克斯县| 兴义市| 遂川县| 区。| 浦江县| 垫江县| 伊金霍洛旗| 鄄城县| 甘德县| 嘉义县| 三河市| 彩票| 正蓝旗| 嵊州市| 锡林浩特市| 福鼎市| 丹东市| 丰原市| 清涧县| 舞阳县| 邯郸县| 江北区| 科尔| 新邵县| 临泉县| 肥乡县| 衡阳县| 谷城县| 陵川县| 吴川市| 门头沟区| 内江市| 曲麻莱县| 丽水市|