日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > C# >内容正文

C#

解决asp.net(C#)中 DataTime 空值 null为0001-01-01

發布時間:2024/9/20 C# 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 解决asp.net(C#)中 DataTime 空值 null为0001-01-01 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

SqlServer中的datetime類型的空值和c#中的DateTime的空值的研究

在SqlServer 2000中datetime 的空值即默認值為1900-01-01 00:00:00,C#中DateTime的空值是最小值0001-01-01 00:00:00,對于數據庫的插入,更新為空值的日期值來說多少有點不如人所愿。比如說我插入的是空值我取出的也要是空值,但SqlServer偏偏給了我一個默認值。有點無奈。對于如何協調二者,給我帶來了不少麻煩。

引起這樣的原因是:DateTime和Int,Double一樣都是值類型,必須有一個值。

解決的辦法:

1.從數據庫的角度:把該字段的類型改為自定義的字符串型,該字符串格式為日期樣式。這種辦法比較簡單,其實就是字符串型,插入時對插入的字符串做日期的正則判斷。

2.這種方法是從網上搜索出于:http://treexyz.spaces.live.com/blog/cns!6667864a1ffeabc7!300.entry 對數據類型null的處理當C#與SQL Server數據類型定義不一致時需要怎么處理呢?

例如一個DateTime,當DB中該字段可以為空時,要求它既能用C#的DateTime賦值,又可以賦SQL Server的null值。

我采用的解決方法是,在Model對應的類中,將該字段對應的property的數據類型設為object。

賦值時,判斷,若是空值則賦給DBNull.Value。

取值時,判斷,若取到DBNull.Value則顯示null,否則要進行一次數據轉換。

這是為了DA在對DB操作時,若將此字段作為參數,只需要將get到的值直接賦給salParameter即可。(若model的get不轉換,則DA中要判斷是否要轉換。因為C#的DBNull和DateTime均可賦給sqlDBType.DateTime;反之,sql中取到的空值是以DBNUll.Value出現的,不能賦給C#的DateTime。

Forum有一個很大的特點,就是在調用DB.cs的方法時,參數的類型幾乎都是object。在sp中再仔細定義各參數的格式,由sql自己轉換。對于可空的參數,在sp中定義=null即可。Forum傳一個null參數的情況很多,總是在接收方去判斷參數,有些參數是null寫入數據庫的;但是有些參數如果為null是有其它意義的,需要條件分支代碼去處理。而我習慣于參數首先初始化,如果有不同情況共用同一個方法則增加一個參數用于判斷。我認為使參數為null也有實際意義不是很好的辦法,因為會造成一些不明意義的條件分支,對以后的升級和維護造成潛在的危險。

3.如下語句能實現插入:

insert into Employees (lastname,firstname,hiredate) values ('hu','shuai',null),

insert into Employees (lastname,firstname,hiredate) values ('hu','shuaishuai','')

有著明顯不同的結果。可以在Sql 語句上實現。但在程序中,特別是面向對象的程序設計中,在加上三層架構的一些問題。實現起來頗為不便。所以我正在努力尋找一種方法巧妙的實現之,也希望大家給點建議。

三 。

最簡單的方法:

在頁面賦一個默認日期

在sql語句中參數賦值時判斷參數值是否等于默認日期 如果等于為參數賦值DBNull.Value

eg:

#Eval("CANCELACCT_DATE").ToString() == DateTime.MinValue.ToString() ? string.Empty :。。。。。

總結

以上是生活随笔為你收集整理的解决asp.net(C#)中 DataTime 空值 null为0001-01-01的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。