使用c#構(gòu)造date數(shù)據(jù)類型
作者:trieagle(讓你望見影子的墻)
日期:2009.8.14
注: 轉(zhuǎn)載請(qǐng)保留此信息
************************************/
使用c#構(gòu)造date數(shù)據(jù)類型
在sql server2005沒有實(shí)現(xiàn)date類型,但是提供了很好的擴(kuò)展性,可以利用CLR來構(gòu)造date類型。有一部分是參考了Fc的代碼寫的。
步驟:
1、在vs 2005中新建項(xiàng)目,一次選擇c#——>>數(shù)據(jù)庫——>>sql server項(xiàng)目,輸入項(xiàng)目名稱
2、選擇要連接的數(shù)據(jù)庫
3、在項(xiàng)目名稱右鍵,添加——>>新建項(xiàng)——>>用戶定義的類型——>>輸入類型名稱
4、代碼如下:
using System;
using System.Data;
using System.Data.SqlClient;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
[Serializable]
[Microsoft.SqlServer.Server.SqlUserDefinedTypeFormat.UserDefined ,IsByteOrdered=true,MaxByteSize =20,ValidationMethodName="ValidateDate")]
public struct date : INullable,IBinarySerialize
{
// 私有成員
private bool m_Null;
private string m_date;
public override string ToString()
{
if (this.m_Null)
return "null";
else
{
return this.m_date;
}
}
public bool IsNull
{
get
{
return m_Null;
}
}
public static date Null
{
get
{
date h = new date();
h.m_Null = true;
return h;
}
}
public static date Parse(SqlString s)
{
if (s.IsNull || (!s.IsNull && s.Value.Equals("")))
return Null;
else
{
date u = new date();
string[] xy = s.Value.Split(" ".ToCharArray());
u.m_date = xy[0];
if (!u.ValidateDate())
throw new ArgumentException ("無效的時(shí)間");
return u;
}
}
public string _date
{
get
{
return this.m_date;
}
set
{
m_Null = true;
m_date = value;
if (!ValidateDate())
throw new ArgumentException("無效的時(shí)間");
}
}
public void Write(System.IO.BinaryWriter w)
{
byte header = (byte)(this.IsNull ? 1 : 0);
w.Write(header);
if (header == 1)
{
return;
}
w.Write(this.m_date);
}
public void Read(System.IO.BinaryReader r)
{
byte header = r.ReadByte();
if (header == 1)
{
this.m_Null = true;
return;
}
this.m_Null = false ;
this.m_date = r.ReadString();
}
private bool ValidateDate() //判斷時(shí)間是否有效
{
try
{
DateTime dt = Convert.ToDateTime(m_date);
return true;
}
catch
{
return false;
}
}
}
5、按F5進(jìn)行部署
6、測(cè)試:
CREATE TABLE tb(id int,dt dbo.Date DEFAULT CONVERT(dbo.Date,CONVERT(VARCHAR(10),GETDATE(),120)));
insert into tb(id) values(1)
SELECT id,dt=dt.ToString() FROM tb;
/*
結(jié)果:
id dt
1 2009-08-14
*/
DROP TABLE tb;
注:
1、 如果要對(duì)date類型進(jìn)行日期的加減,可以調(diào)用ToString()方法輸出為字符串,然后轉(zhuǎn)化為datetime類型,然后再進(jìn)行日期的計(jì)算。
2、 不能直接使用select * from tb 來輸出dt列的值,這樣輸出的是一串二進(jìn)制數(shù)
- C#基礎(chǔ)之?dāng)?shù)據(jù)類型轉(zhuǎn)換
- c#數(shù)據(jù)類型基礎(chǔ)
- C# double和decimal數(shù)據(jù)類型以截?cái)嗟姆绞奖A糁付ǖ男?shù)位數(shù)
- C#實(shí)現(xiàn)任意數(shù)據(jù)類型轉(zhuǎn)成json格式輸出
- 淺析C#數(shù)據(jù)類型轉(zhuǎn)換的幾種形式
- 數(shù)據(jù)庫 數(shù)據(jù)類型float到C#類型decimal, float數(shù)據(jù)類型轉(zhuǎn)化無效
- C#判斷數(shù)據(jù)類型的簡單示例代碼
- c# 數(shù)據(jù)類型占用的字節(jié)數(shù)介紹
- C#的四種基本數(shù)據(jù)類型
相關(guān)文章
SQLServer 2005 列所有存儲(chǔ)過程的語句
對(duì)于數(shù)據(jù)庫管理員來說,可以經(jīng)常想了解一些之前未聽說過的存儲(chǔ)過程,特別是無文檔類型的存儲(chǔ)過程?;蛟S是用這些存儲(chǔ)過程,能夠簡化日常的數(shù)據(jù)管理。2008-11-11SQL2005學(xué)習(xí)筆記 EXCEPT和INTERSECT運(yùn)算符
EXCEPT和INTERSECT運(yùn)算符使您可以比較兩個(gè)或多個(gè)SELECT語句的結(jié)果并返回非重復(fù)值。2009-07-07SQL server 2005將遠(yuǎn)程數(shù)據(jù)庫導(dǎo)入到本地的方法
這篇文章主要介紹了SQL server 2005將遠(yuǎn)程數(shù)據(jù)庫導(dǎo)入到本地的方法,需要的朋友可以參考下2015-01-01SQL 2005 ERROR:3145 解決辦法(備份集中的數(shù)據(jù)庫備份與現(xiàn)有的數(shù)據(jù)庫不同)
在圖形界面中,選擇備份文件,設(shè)置覆蓋原有數(shù)據(jù)庫,指定現(xiàn)數(shù)據(jù)庫文件所在的位置,選擇錯(cuò)誤回滾,點(diǎn)擊確定2013-01-01SQL Server創(chuàng)建維護(hù)計(jì)劃失?。⊿QL Server:14234 錯(cuò)誤)的解決方法
這篇文章主要介紹了SQL Server創(chuàng)建維護(hù)計(jì)劃失?。⊿QL Server:14234 錯(cuò)誤)的解決方法,最后使用SQLServer2005 安裝向?qū)Ы鉀Q問題,需要的朋友可以參考下2014-08-08SQL2005查看死鎖存儲(chǔ)過程sp_who_lock
本文分享一個(gè)查看死鎖的存儲(chǔ)過程,方便技術(shù)人員查找產(chǎn)生死鎖的原因。2016-03-03mdf文件和ldf文件導(dǎo)入到sql server 2005實(shí)現(xiàn)語句
導(dǎo)入mdf文件和ldf文件到數(shù)據(jù)庫是網(wǎng)站搬家或者是初學(xué)者學(xué)習(xí)源碼是必要的一步,接下來為大家詳細(xì)介紹實(shí)現(xiàn)sql語句,感興趣的你可不要錯(cuò)過了哈希望可以幫助到你2013-03-03sql 2005不允許進(jìn)行遠(yuǎn)程連接可能會(huì)導(dǎo)致此失敗的解決方法
用vs.net2005連接sql server 2005 出現(xiàn)以下錯(cuò)誤:在建立與服務(wù)器的連接時(shí)出錯(cuò)。在連接到 SQL Server 2005 時(shí),在默認(rèn)的設(shè)置下 SQL Server 不允許進(jìn)行遠(yuǎn)程連接可能會(huì)導(dǎo)致此失敗。2008-04-04SqlServer 2005 T-SQL Query 學(xué)習(xí)筆記(2)
SqlServer 2005 T-SQL Query 學(xué)習(xí)筆記(2)2010-02-02SQLServer2005與SQLServer2008數(shù)據(jù)庫同步圖文教程
要實(shí)現(xiàn)SQLServer2005與2005的數(shù)據(jù)庫同步的話,直接用鏡像就可以實(shí)現(xiàn)。但是如果同步 SQLServer2008的話,2005的實(shí)例是連接不上08的。低版本的無法連接高版本的。所以我們可以通過復(fù)制的方式,也就是所謂的訂閱發(fā)布的方法來實(shí)現(xiàn)兩個(gè)不同版本數(shù)據(jù)庫的數(shù)據(jù)同步。2011-09-09