使用c#构造date数据类型
程序员文章站
2022-04-23 20:21:51
/*********************************** 作者:trieagle(让你望见影子的墙) 日期:2009.8.14 注: 转载请保留此信息 **...
/***********************************
作者: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列的值,这样输出的是一串二进制数
作者: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列的值,这样输出的是一串二进制数