一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Sql Server - 使用c#構造date數據類型

使用c#構造date數據類型

2020-06-28 15:03MSSQL教程網 Sql Server

在sql server2005沒有實現date類型,但是提供了很好的擴展性,可以利用CLR來構造date類型。有一部分是參考了Fc的代碼寫的。

/***********************************
作者:trieagle(讓你望見影子的墻)
日期:2009.8.14
注: 轉載請保留此信息
************************************/
使用c#構造date數據類型
在sql server2005沒有實現date類型,但是提供了很好的擴展性,可以利用CLR來構造date類型。有一部分是參考了Fc的代碼寫的。
步驟:
1、在vs 2005中新建項目,一次選擇c#——>>數據庫——>>sql server項目,輸入項目名稱
2、選擇要連接的數據庫
3、在項目名稱右鍵,添加——>>新建項——>>用戶定義的類型——>>輸入類型名稱
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 ("無效的時間");
return u;
}
}
public string _date
{
get
{
return this.m_date;
}
set
{
m_Null = true;
m_date = value;
if (!ValidateDate())
throw new ArgumentException("無效的時間");
}
}
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() //判斷時間是否有效
{
try
{
DateTime dt = Convert.ToDateTime(m_date);
return true;
}
catch
{
return false;
}
}
}


5、按F5進行部署
6、測試:

復制代碼 代碼如下:


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;
/*
結果:
id dt
1 2009-08-14
*/
DROP TABLE tb;


注:
1、 如果要對date類型進行日期的加減,可以調用ToString()方法輸出為字符串,然后轉化為datetime類型,然后再進行日期的計算。
2、 不能直接使用select * from tb 來輸出dt列的值,這樣輸出的是一串二進制數

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 小苹果日本在线观看 | 亚洲 小说 欧美 激情 另类 | 成人亚洲欧美日韩在线观看 | 天堂a视频 | 出a级黑粗大硬长爽猛视频 吃胸膜奶视频456 | 国产有码在线 | 春色视频网站 | 天天躁天天碰天天看 | 日本福利视频网站 | 久久精品国产清白在天天线 | 艾秋果冻麻豆老狼 | 91久色| 涩涩国产精品福利在线观看 | 国产91在线九色 | 涩涩五月天 | 色综合久久日韩国产 | 肥胖女性大bbbbbb视频女厕 | 韩国久久精品 | 亚洲色图15p | 亚洲精品www久久久久久 | 国产精品1页 | xnxx老师 | 色欲麻将 | 无人区免费一二三四乱码 | 亚洲国产欧美在线成人aaaa | 欧美有码 | kk4kk免费毛片 | 免费看黄色片的网站 | 男同巨黄gay小说好爽 | 牛牛影院成人免费网页 | ai换脸造梦jennie | 操破苍穹小说 | 青草青草视频2免费观看 | heyzo在线观看 | 日b视频免费看 | 日本老妇成熟 | 艾秋果冻麻豆老狼 | 色综合视频在线 | 国产九九视频在线观看 | 成人伊人青草久久综合网破解版 | 大胆暴露亚洲美女xxxx |