使用用户自定义类型 CLR UDT
一些复合类型进行范式分解是没有必要的,尤其是一些统一模型的情况下
- DECLARE @i TimeBalance
- SELECT @i
- SELECT @i.ToString()
- SELECT @i.ToTimeString()
- '' m
- SELECT '' s ,
- '37次' m
- SELECT 'Y/2015-1-5/1' s ,
- '包年' m
- SELECT 'M/2015-1-5/11' s ,
- '包个月' m
- SELECT 'D/2015-1-1/7' s ,
- '包天' m
- SELECT '' s ,
- '包天' m
- SELECT 'H/2015-1-5 8:30/10' s ,
- '包小时' m
- )
- SELECT m + '
' + s , - t.ToString() string ,
- t.ToHex() hex ,
- t.ToTimeString() timeString ,
- t.ToValue() value ,
- t.Distance() distance
- m ,
- FROM A
- ) tt

相关资料:
TSql vs. SQL CLR Performance Analysis
- using System;
- using System.Data;
- using System.Data.SqlClient;
- using System.Data.SqlTypes;
- using Microsoft.SqlServer.Server;
- /// <summary>
- /// 时间钱包余额类型
- ///
- /// </summary>
- /// <remarks>
- /// 基于长整型,结构如下:
- /// 包时类型2B,起始时间UTC秒数4B,时间总长2B(单位同类型决定)
- /// <p>包时类型:0不包时1秒2分3时4日5月6年</p>
- /// </remarks>
- /// <see cref="https://msdn.microsoft.com/en-us/library/ms131086.aspx"/>
- [Serializable]
- [Microsoft.SqlServer.Server.SqlUserDefinedType(Format.Native)]
- public
struct TimeBalance : INullable - {
- public
override
string ToString() - {
- switch (type)
- {
- case 0:
- case 1:
- return ToValue().ToString();
- default:
- return
string.Format("{0}/{1}/{2}", (TimeEnum)type, UTCSecondToDateTime(startSecond).ToString("yyyy-MM-dd HH:mm:ss"), value); - }
- }
- public
string ToHex() - {
- return type.ToString("X4") +"
" + startSecond.ToString("X8") + value.ToString("X4"); - }
- public
string ToTimeString() - {
- switch (type)
- {
- case 0:
- case 1:
- return ToValue().ToString();
- default:
- TimeEnum typeEnum = (TimeEnum)type;
- string format = "";
- switch (typeEnum)
- {
- case TimeEnum.S:
- default:
- format = "HH:mm:ss";
- break;
- case TimeEnum.Mi:
- format = "dd HH:mm";
- break;
- case TimeEnum.H:
- format = "MM-dd HH";
- break;
- case TimeEnum.D:
- format = "yyyy-MM-dd";
- break;
- case TimeEnum.M:
- format = "yyyy-MM";
- break;
- case TimeEnum.Y:
- format = "yyyy";
- break;
- }
- return
string.Format("{0}/{1}/{2}", (TimeEnum)type, UTCSecondToDateTime(startSecond).ToString(format), EndTime().ToString(format)); - }
- }
- public
long ToValue() - {
- switch (type)
- {
- case 0:
- case 1:
- return
value; - default:
- return ((long)type << 48) + ((long)startSecond << 16) + value;
- }
- }
- public
static TimeBalance Parse(SqlString s) - {
- if (s.IsNull)
- return Null;
- try
- {
- TimeBalance u = new TimeBalance();
- if (s.Value.Contains("/"))
- {
- u.type = (short)(TimeEnum)Enum.Parse(typeof(TimeEnum), (s.Value.Split('/')[0]));
- u.startSecond = DateTimeToUTCSecond(DateTime.Parse(s.Value.Split('/')[1]));
- u.value = long.Parse(s.Value.Split('/')[2]);
- }
- else
- {
- byte[] bs = BitConverter.GetBytes(long.Parse(s.Value));
- u.type = BitConverter.ToInt16(bs, 6);
- switch (u.type)
- {
- case 0:
- u.value = long.Parse(s.Value);
- break;
- case 1:
- u.value = BitConverter.ToInt16(bs, 0);
- break;
- default:
- u.startSecond = BitConverter.ToInt32(bs, 2);
- u.value = BitConverter.ToInt16(bs, 0);
- break;
- }
- }
- return u;
- }
- catch (Exception ex)
- {
- throw
new Exception(s.Value + "\r\n" + ex.ToString()); - }
- }
- public
bool IsNull - {
- get
- {
- // 在此处放置代码
- return _null;
- }
- }
- public
static TimeBalance Null - {
- get
- {
- TimeBalance h = new TimeBalance();
- h._null = true;
- return h;
- }
- }
- public
long Distance() - {
- return
value; - }
- public DateTime EndTime()
- {
- short v = (short)(value & 0xffff);
- TimeEnum typeEnum = (TimeEnum)type;
- switch (typeEnum)
- {
- // case TimeEnum.N:
- case TimeEnum.S:
- default:
- return UTCSecondToDateTime(startSecond).AddSeconds(v);
- case TimeEnum.Mi:
- return UTCSecondToDateTime(startSecond).AddMinutes(v);
- case TimeEnum.H:
- return UTCSecondToDateTime(startSecond).AddHours(v);
- case TimeEnum.D:
- return UTCSecondToDateTime(startSecond).AddDays(v);
- case TimeEnum.M:
- return UTCSecondToDateTime(startSecond).AddMonths(v);
- case TimeEnum.Y:
- return UTCSecondToDateTime(startSecond).AddYears(v);
- }
- }
- #region 获取UTC
- public
static
int DateTimeToUTCSecond(DateTime dateTime) - {
- return (int)dateTime.ToUniversalTime().Subtract(UTC).TotalSeconds;
- }
- static DateTime UTCSecondToDateTime(int second)
- {
- return UTC.AddSeconds(second).ToLocalTime();
- }
- #endregion
- // 这是占位符成员字段
- public
int startSecond; - public
short type; - public
long
value; - static
readonly DateTime UTC = TimeZoneInfo.ConvertTimeToUtc(new DateTime(1970, 1, 1), TimeZoneInfo.Utc); - // 私有成员
- private
bool _null; - }
- public
enum TimeEnum - {
- N = 0,
- T = 1,//Times
- S = 2,
- Mi = 3,
- H = 4,
- D = 5,
- M = 6,
- Y = 7
- }
使用用户自定义类型 CLR UDT的更多相关文章
- 使用用户自定义类型作为map的key
有时候我们想把用户自定义类型作为std::map的键值.方法一)最简单的方法就是实现该自定义类型的<操作符,代码如下:class Foo{public: Foo(int num_) ...
- 内建类型,与用户自定义类型,返回值为const
1对内建类型来说,按值返回的是否为const,是无关紧要的,因为编译器已经不让它成为一个坐直,因为它总是一个值,而不是一个变量(thing in c++ page192) 2当处理用户自定义的类型时, ...
- SQL Server用户自定义类型与统计信息
用户自定义数据类型不支持统计信息! 所以查询对它的查询会慢一些.
- 用户自定义类型《lua程序设计》 28章 笔记
本实例实现一种很简单的类型------布尔数组.C语言可以实现将每个布尔值存储在一个bit中,从而减少内存用量. 必须的一些宏 Code Snippet #defineBITS_PER_WORD (C ...
- Python 中的用户自定义类型
Python中面向对象的技术 Python是面向对象的编程语言,自然提供了面向对象的编程方法.但要给面向对象的编程方法下一个定义,是很困难的.问题关键是理解对象 的含义.对象的含义是广泛的,它是对现实 ...
- 结构体struct、联合体union、枚举类型enum
1.c语言中的类型 1)内置类型——char,short,int,float,double: 2)用户自定义类型(UDT)——struct结构体,union联合体,enum枚举类型 2.内存对齐 2. ...
- lob结构
lob是什么? 从网上查了好多资料没找到,最后还是同事给我找到了. lob他是这样解释的:LOB专门存储大型对象数据的,类型text.image这些数据类型的数据就是存储在LOB页面 LOB_DATA ...
- 利用sys.dm_db_index_physical_stats查看索引碎片等数据(转)
我们都知道,提高sql server的数据查询速度,最有效的方法,就是为表创建索引,而索引在对数据进行新增,删除,修改的时候,会产生索引碎片,索引碎片多了,就需要重新组织或重新生成索引,以达到索引的最 ...
- SQL反模式学习笔记11 限定列的有效值
目标:限定列的有效值,将一列的有效字段值约束在一个固定的集合中.类似于数据字典. 反模式:在列定义上指定可选值 1. 对某一列定义一个检查约束项,这个约束不允许往列中插入或者更新任何会导致约束失败的值 ...
随机推荐
- Objective-C中的Block回调模式
在前面的博客中提到了Block的概念和使用方法,个人感觉Block最爽的用法莫过于在回调时用block.感觉比委托回调和目标方法回调用着要顺手,好不好用还得读者亲自用一下才知道.如果 读者之前用过SS ...
- 修改USB固件库的Customer_HID例程
我用的是神州三号开发板子,板子的USB模块原理图为: 配置端口G的11号引脚为usb的使能引脚,按理来说应该是开漏输出的(看了很多的修改代码都是这个模式),不过就是不能使能usb,只能配置成推挽的才行 ...
- bootstrap 学习总结
Bootstrap 是最受欢迎的 HTML.CSS 和 JS 框架,用于开发响应式布局.移动设备优先的 WEB 项目.当前最新版本是3.2.0; 使用的第一步,可以直接复制官方的模版,另存为index ...
- OWIN 中 K Commands(OwinHost.exe)与 Microsoft.AspNet.Hosting 的角色问题
问题详情:K Commands(OwinHost.exe)是不是 OWIN 中的 Host 角色?如果是,那 Microsoft.AspNet.Hosting 对应的是 OWIN 中的哪个角色? OW ...
- Mac如何删除MySQL,Mac下MySQL卸载方法
在Mac下安装完MySQL之后,出现了无法启动的问题,多翻尝试依然不能解决问题,最后只能把它删掉. 如何在Mac下删除MySQL呢,只需要在终端执行如下命令就可以把MySQL在Mac下彻底删除干净了. ...
- Myeclipse无法开启Servers视图解决办法
IDE报错如下: 解决办法:1.首先关闭MyEclipse工作空间. 2.然后删除工作空间下的 “/.metadata/.plugins/org.eclipse.core.runtime/.sett ...
- Cesium应用篇:3控件(2)BaseLayerPicker
所有范例均在github中搜索:ExamplesforCesium BaseLayerPicker控件非常简单,似乎没什么可说的,确实非常的简单,但作为一个底图选择控件,可以说是最基本的一个控件. C ...
- Javascript数组常用方法
一.forEach对数组的遍历 二.map返回经过运算的新数组 三.filter返回满足条件的新数组 四.返回数组前后元素运算的结果 五.every遍历数组每项元素是否满足某个条件,全部满足返回tru ...
- jQuery打造智能提示插件
插件根据实际需要在单功能上封装的,实现传入后台数据地址,要保存值的input,前台要传入的参数(过滤条件),来返回下拉提示数据,数据过多可上下滚动选择,选择后显示文本与对应的值,供后台操作,如图: j ...
- maven全局配置文件settings.xml详解
概要 settings.xml有什么用? 如果在Eclipse中使用过Maven插件,想必会有这个经验:配置settings.xml文件的路径. settings.xml文件是干什么的,为什么要配置它 ...