婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 使用c#構造date數據類型

使用c#構造date數據類型

熱門標簽:智能電銷機器人教育 無錫梁溪公司怎樣申請400電話 中國地圖標注省份用什么符號 電話機器人錄音師薪資 孝感銷售電銷機器人廠家 奧維地圖標注字體大小修改 高德地圖標注電話怎么沒了 北京智能外呼系統供應商家 江西穩定外呼系統供應商
/***********************************
作者: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列的值,這樣輸出的是一串二進制數
您可能感興趣的文章:
  • C#基礎之數據類型轉換
  • c#數據類型基礎
  • C# double和decimal數據類型以截斷的方式保留指定的小數位數
  • C#實現任意數據類型轉成json格式輸出
  • 淺析C#數據類型轉換的幾種形式
  • 數據庫 數據類型float到C#類型decimal, float數據類型轉化無效
  • C#判斷數據類型的簡單示例代碼
  • c# 數據類型占用的字節數介紹
  • C#的四種基本數據類型

標簽:那曲 通化 荊州 泰州 齊齊哈爾 阜陽 海北 臨滄

巨人網絡通訊聲明:本文標題《使用c#構造date數據類型》,本文關鍵詞  使用,構造,date,數據,類型,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用c#構造date數據類型》相關的同類信息!
  • 本頁收集關于使用c#構造date數據類型的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 望都县| 沙洋县| 鹰潭市| 濮阳市| 军事| 虹口区| 大渡口区| 鄂伦春自治旗| 灌阳县| 时尚| 长春市| 西藏| 贵南县| 安岳县| 日照市| 茌平县| 河北省| 吴忠市| 林口县| 建水县| 蒙阴县| 旬阳县| 丹巴县| 镇原县| 秦皇岛市| 梁平县| 界首市| 泰宁县| 阿巴嘎旗| 牡丹江市| 乌恰县| 阿克苏市| 宁乡县| 天门市| 五家渠市| 沁源县| 务川| 通道| 泾阳县| 育儿| 茶陵县|