[C#]關於DBNULL的解釋

来源:http://www.cnblogs.com/wangjiming/archive/2017/09/28/7604460.html
-Advertisement-
Play Games

1 概述 1 概述 如下例子,你覺得有什麼問題?如你能很快的找出問題,並且解決它,那麼你可以跳過本篇文章,謝謝~~。 想一分鐘,OK,如果沒想出來,可以往下看,下圖標註處即為問題處。 ok,本篇文章就是來解決該問題的。也就是接下來要與大家分享的System.DBNULL類型。 2 內容分享 2 內容 ...


1   概述

如下例子,你覺得有什麼問題?如你能很快的找出問題,並且解決它,那麼你可以跳過本篇文章,謝謝~~。

1 List<Base_Employee> ltPI = new List<Base_Employee>();
2 DataTable dt = GetBase_UserInfoToDataTable();
3 for (int i = 0; i < dt.Rows.Count; i++)
4    {
5          Base_Employee base_Employee= new Base_Employee();
6          base_Employee.EmployeeId= dt.Rows[i]["EmployeeId"].ToString();//EmployeeId為string類型
7          base_Employee.Age =(int)dt.Rows[i]["Age"];//Age為int類型
8          base_Employee.GraduationDate = (DateTime)dt.Rows[i]["GraduationDate"];//GraduationDate 為DateTime類型
9    }

想一分鐘,OK,如果沒想出來,可以往下看,下圖標註處即為問題處。

 ok,本篇文章就是來解決該問題的。也就是接下來要與大家分享的System.DBNULL類型。

2   內容分享

2.1  在.NET中的,常用的基本數據類型

int,string,char等是大家比較熟悉的基本數據類型,但是大部分人都應該對System.DBNull比較陌生,然而,它又是解決如上問題的一大思路。

2.2  SqlServer中的常用數據類型

varchar,nvarchar,int,bit,decimal,datetime等,基本在與.net中的數據類型一一對應(varchar和nvarchar均對應.net中的string類型)

2.3  SqlServer中的常用數據類型的初始值

在.net中,當我們定義一個變數時,如果沒給其賦初始值,那麼系統會預設初始值,如int 類型預設為0,string類型預設為string.Empty,一般情況,不同類型的預設初始值是不同的;但是,在SqlServer中,幾乎所有變數類型的初始值為NULL,也就要麼為用戶自定義的值,要麼為系統預設的值NUL。問題的關鍵就在這,以int類型為例,當在資料庫中,我們沒有給INT賦值時,其預設值為NULL,當把這個值賦給.net中的整形變數時,就會引發異常。

 

2.4  System.DBNull是什麼?

DBNull是一個類,繼承Object,其實例為DBNull.Value,相當於數據中NULL值。

2.5  為什麼 DBNull可以表示其他數據類型?

在資料庫中,數據存儲以object來存儲的。

2.6 如何解決如上問題

加條件判斷

可以用string類型是否為空,或DBNull是否等於NULL來判斷

 1 List<Base_Employee> ltPI = new List<Base_Employee>();
 2 DataTable dt = GetBase_UserInfoToDataTable();
 3 for (int i = 0; i < dt.Rows.Count; i++)
 4    {
 5          Base_Employee base_Employee= new Base_Employee();
 6          base_Employee.EmployeeId= dt.Rows[i]["EmployeeId"].ToString();//EmployeeId為string類型
 7          //base_Employee.Age =(int)dt.Rows[i]["Age"];//Age為int類型
 8           if (dt.Rows[i]["Age"]!=System.DBNull.Value)
 9                 {
10                     base_Employee.Age = int.Parse(dt.Rows[i]["Age"].ToString());
11                     //base_Employee.Age = (int)dt.Rows[i]["Age"];//拆箱
12                     //base_Employee.Age =Convert.ToInt16( dt.Rows[i]["Age"]);
13                 }
14          //base_Employee.GraduationDate = (DateTime)dt.Rows[i]["GraduationDate"];//GraduationDate 為DateTime類型
15         if (dt.Rows[i]["GraduationDate"].ToString()!="")
16                 {
17                     base_Employee.GraduationDate = Convert.ToDateTime(dt.Rows[i]["GraduationDate"]);
18                     base_Employee.GraduationDate = (DateTime)dt.Rows[i]["GraduationDate"];
19                 }
20    }

3   版權

 

  • 感謝您的閱讀,若有不足之處,歡迎指教,共同學習、共同進步。
  • 博主網址:http://www.cnblogs.com/wangjiming/。
  • 極少部分文章利用讀書、參考、引用、抄襲、複製和粘貼等多種方式整合而成的,大部分為原創。
  • 如您喜歡,麻煩推薦一下;如您有新想法,歡迎提出,郵箱:[email protected]
  • 可以轉載該博客,但必須著名博客來源。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 自己挖了一個大坑,,,然後苦逼的在碼代碼重寫樣式! 廢物不多少 直接上代碼 先在前臺創建一個TextBox,然後各種附加的屬性加上去:如圖所示 效果圖: 樣式代碼: 本文原創出處:http://www.cnblogs.com/PettyHandSome/ 歡迎各位轉載,但是未經作者本人同意,轉載文章 ...
  • 1. foreach C#編譯器會把foreach語句轉換為IEnumerable介面的方法和屬性。 foreach語句會解析為下麵的代碼段。 調用GetEnumerator()方法,獲得數組的一個枚舉 在while迴圈中,只要MoveNext()返回true,就一直迴圈下去 用Current屬性訪 ...
  • 用socket做了個程式,本地測試沒有問題,發佈到伺服器上時連接不上,用telnet測試連接失敗 伺服器上netstat -a 查看埠情況,127.0.0.1綁定埠9300處於監聽狀態,如下圖: 修改socket綁定IP為伺服器IP,埠狀態變為下圖: telnet連接測試成功! 很納悶,查了下 ...
  • 問題的產生的背景 由於我們使用了jenkins進行部署(jenkins~集群分發功能和職責處理),而對於.net core項目來說又是跨平臺的,所以對它的項目拉取,包的還原,項目的編譯和項目的發佈都是在一臺linux的jenkins節點上進行的,而我們開發時是在windows系統,所以在進行還原和編 ...
  • Tips 原文作者:Thomas Anderson, Blinkist 原文地址:Steve Jobs was successful because he mastered 'deep work' — here's how you can, too 你喝過麥卡倫姆威士忌嗎?如果你有這樣的經歷,你一定 ...
  • 出於安全考慮,在後臺與前臺進行數據傳輸時,往往不會直接傳輸實體模型,而是使用Dto(Data transfer object 數據傳輸對象),這樣在後臺往前臺傳遞數據時可以省略不必要的信息,只保留必要的信息,大大增強數據安全性。 下麵給出兩個相互對應的關係模型User、UserDto public ...
  • 使用EntityFramework Code First開發,數據遷移是一個不得不提的技術。 在我們的開發過程中,難免需要對模型進行改進,模型改進後,會導致實體集與資料庫不一致,當然我們可以通過刪除資料庫然後再重構資料庫,但是在生產環境中這樣做,這樣或多或少會出現一些問題。使用“數據遷移”,可以幫助 ...
  • 由於HTTP協議是無狀態的,但對於認證來說,必然要通過一種機制來保存用戶狀態,而最常用,也最簡單的就是Cookie了,它由瀏覽器自動保存併在發送請求時自動附加到請求頭中。儘管在現代Web應用中,Cookie已略顯笨重,但它依然是最為重要的用戶身份保存方式。在 "上一章" 中整體的介紹了一下 ASP. ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...