濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 使用c#構(gòu)造date數(shù)據(jù)類型

使用c#構(gòu)造date數(shù)據(jù)類型

熱門標(biāo)簽:智能電銷機(jī)器人教育 無(wú)錫梁溪公司怎樣申請(qǐng)400電話 中國(guó)地圖標(biāo)注省份用什么符號(hào) 電話機(jī)器人錄音師薪資 孝感銷售電銷機(jī)器人廠家 奧維地圖標(biāo)注字體大小修改 高德地圖標(biāo)注電話怎么沒了 北京智能外呼系統(tǒng)供應(yīng)商家 江西穩(wěn)定外呼系統(tǒng)供應(yīng)商
/***********************************
作者:trieagle(讓你望見影子的墻)
日期:2009.8.14
注: 轉(zhuǎn)載請(qǐng)保留此信息
************************************/
使用c#構(gòu)造date數(shù)據(jù)類型
在sql server2005沒有實(shí)現(xiàn)date類型,但是提供了很好的擴(kuò)展性,可以利用CLR來(lái)構(gòu)造date類型。有一部分是參考了Fc的代碼寫的。
步驟:
1、在vs 2005中新建項(xiàng)目,一次選擇c#——>>數(shù)據(jù)庫(kù)——>>sql server項(xiàng)目,輸入項(xiàng)目名稱
2、選擇要連接的數(shù)據(jù)庫(kù)
3、在項(xiàng)目名稱右鍵,添加——>>新建項(xiàng)——>>用戶定義的類型——>>輸入類型名稱
4、代碼如下:
復(fù)制代碼 代碼如下:

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 ("無(wú)效的時(shí)間");
return u;
}
}
public string _date
{
get
{
return this.m_date;
}
set
{
m_Null = true;
m_date = value;
if (!ValidateDate())
throw new ArgumentException("無(wú)效的時(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è)試:
復(fù)制代碼 代碼如下:

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 來(lái)輸出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ù)庫(kù) 數(shù)據(jù)類型float到C#類型decimal, float數(shù)據(jù)類型轉(zhuǎn)化無(wú)效
  • C#判斷數(shù)據(jù)類型的簡(jiǎn)單示例代碼
  • c# 數(shù)據(jù)類型占用的字節(jié)數(shù)介紹
  • C#的四種基本數(shù)據(jù)類型

標(biāo)簽:那曲 通化 荊州 泰州 齊齊哈爾 阜陽(yáng) 海北 臨滄

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用c#構(gòu)造date數(shù)據(jù)類型》,本文關(guān)鍵詞  使用,構(gòu)造,date,數(shù)據(jù),類型,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用c#構(gòu)造date數(shù)據(jù)類型》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于使用c#構(gòu)造date數(shù)據(jù)類型的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    怀柔区| 信丰县| 洞头县| 永济市| 玉田县| 垫江县| 闵行区| 海盐县| 潼南县| 射阳县| 朔州市| 陇西县| 南陵县| 隆子县| 柳州市| 乌拉特后旗| 临江市| 宁乡县| 石屏县| 阿巴嘎旗| 贵港市| 饶阳县| 庆元县| 驻马店市| 嘉义市| 大厂| 桃园市| 南部县| 贵定县| 博白县| 大新县| 南京市| 乌兰县| 庆阳市| 博兴县| 白沙| 东兰县| 河间市| 克山县| 云阳县| 南涧|