在SQL中使用CLR提供基本函数对二进制数据进行解析与构造
二进制数据包的解析一般是借助C#等语言,在通讯程序中解析后形成字段,再统一单笔或者批量(表类型参数)提交至数据库,在通讯程序中,存在BINARY到struct再到table的转换。
现借助CLR提供基本的INT2HEX(小端)等函数,在SQL中直接解析数据包。
基本函数
- [Microsoft.SqlServer.Server.SqlFunction(Name = "Time2UTCBin")]
- public
static SqlBinary Time2UTCBin(DateTime time) - {
- return
new SqlBinary(BitConverter.GetBytes((uint)(MyTime.ConverDateTimeToJavaMilliSecond(time) / 1000))); - }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "UTCBin2Time")]
- public
static SqlDateTime UTCBin2Time(byte[] data,int offset) - {
- return
new SqlDateTime(MyTime.ConverDateTimeFromJavaMilliSecond(BitConverter.ToUInt32(data, offset) * 1000L)); - }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "getSum")]
- public
static SqlByte Sum(byte[] buffer, int startPos, int endPos) - {
- byte b = 0;
- for (int i = startPos; i <= endPos; i++)
- {
- b ^= buffer[i];
- }
- return b;
- }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "updateSum")]
- public
static SqlBinary updateSum(byte[] buffer, int startPos, int endPos, int sumPos) - {
- byte b = 0;
- for (int i = startPos; i <= endPos; i++)
- {
- b ^= buffer[i];
- }
- buffer[sumPos] = b;
- return
new SqlBinary(buffer); - }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "Int2Bin")]
- public
static SqlBinary Int2Bin(int number) - {
- return
new SqlBinary(BitConverter.GetBytes(number)); - }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "Long2Bin")]
- public
static SqlBinary Long2Bin(long number) - {
- return
new SqlBinary(BitConverter.GetBytes(number)); - }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "Bin2Int")]
- public
static SqlInt32 Bin2Int(byte[] data, int offset) - {
- return
new SqlInt32(BitConverter.ToInt32(data,offset)); - }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "Bin2Long")]
- public
static SqlInt64 Bin2Long(byte[] data, int offset) - {
- return
new SqlInt64(BitConverter.ToInt64(data, offset)); - }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "getByte")]
- public
static SqlByte getByte(byte[] data, int offset) - {
- return
new SqlByte(data[offset]); - }
- [Microsoft.SqlServer.Server.SqlFunction(Name = "getBytes")]
- public
static SqlBytes getBytes(byte[] data, int offset,int count) - {
- byte[] temp = new
byte[count]; - Array.Copy(data, offset, temp, 0, count);
- return
new SqlBytes(temp); - }
数据包的结构体(表类型)
SQL中借助CLR实现的转换函数
- (
- @offset INT = 1 ,
- @withDeviceID BIT = 0
- )
- (
- [DeviceID] UNIQUEIDENTIFIER ,
- Meter INT ,
- run INT ,
- dead INT ,
- StartTime DATETIME ,
- EndTime DATETIME
- )
- IF @withdeviceid = 1
- SET @sized = 16
- SET @sized = 0
- WITH sub
- @size) binDATA
- FROM sys_id
- WHERE id < @c
- )
- INSERT @emv
- ( rawdata ,
- DeviceID ,
- hardwareno ,
- meter ,
- run ,
- WORK ,
- dead ,
- starttime ,
- endtime ,
- emvtype ,
- emvno
- )
- END ,
- CASE @withDeviceID
- END ,
- dbo.Bin2Int(bindata, 0 + @sized) RecordNo ,
- dbo.Bin2Int(bindata, 4 + @sized) Meter ,
- dbo.Bin2Int(bindata, 8 + @sized) run ,
- dbo.Bin2Int(bindata, 16 + @sized) dead ,
- dbo.utcbin2time(bindata, 20 + @sized) StartTime ,
- dbo.utcbin2time(bindata, 24 + @sized) EndTime ,
- dbo.getByte(bindata, 61 + @sized) RecordType ,
- dbo.getByte(bindata, 62 + @sized) EMVNo
- FROM sub
- (
- @emv DeviceTranscationEMV READONLY ,
- @withDeviceID BIT = 0
- )
- SET @bin = 0x0
- IF @withDeviceID = 0
- + dbo.int2Bin(meter)
- + dbo.int2Bin(run)
- + dbo.int2Bin(dead)
- + dbo.time2utcbin(starttime)
- + dbo.time2utcbin(endtime)
- 0, 62, 63)
- FROM @emv
- + dbo.updatesum(dbo.int2Bin([HardwareNo])
- + dbo.time2utcbin(starttime)
- + dbo.time2utcbin(endtime)
- FROM @emv
- RETURN @bin
测试代码
- PRINT N'构造EMV数据,转换为BIN,然后再转换回EMV数据'
- go
- DECLARE @emv DeviceTranscationEMV
- WITH data
- 15 Meter ,
- 100 run ,
- 80 WORK ,
- 20 dead ,
- DATEADD(s, id, '2014-9-1 12:50:01') StartTime ,
- DATEADD(mi, id, '2014-9-1 13:23:11') EndTime ,
- 4 RecordType ,
- 0 EMVNo
- FROM dbo.Sys_ID
- WHERE id < 100
- )
- ( rawdata ,
- deviceid ,
- emvtype ,
- emvno ,
- hardwareno ,
- meter ,
- run ,
- work ,
- dead ,
- starttime ,
- endtime
- )
- SELECT 0x00 ,
- NEWID() ,
- recordtype ,
- emvno ,
- recordno ,
- meter ,
- run ,
- work ,
- dead ,
- starttime ,
- EndTime
- FROM data
- SELECT *
- FROM @emv
- PRINT @data
- SELECT *
执行结果:

资源:

在SQL中使用CLR提供基本函数对二进制数据进行解析与构造的更多相关文章
- sql中根据逗号分隔,查出多行数据
--sql中根据逗号分隔,查出多行数据 select a.DiscussID,b.LocationID from (select DiscussID,LocationID=c ...
- sql中的 where 、group by 和 having 用法解析
--sql中的 where .group by 和 having 用法解析 --如果要用到group by 一般用到的就是“每这个字” 例如说明现在有一个这样的表:每个部门有多少人 就要用到分组的技术 ...
- ORA-01406:提取的列值被截断 ; SQL Server :将截断字符串或二进制数据
oracle 数据库可以正常连接,表数据也可以正常读取, 但在程序中相同的位置,有时会报错,有时不会报错,有的电脑会报错,有的不会 报错内容为 ORA-01406:提取的列值被截断 查了网上提供的一些 ...
- 在SQL中直接把查询结果转换为JSON数据
下面这篇中,已经有准备一些数据: <MS SQL server对象类型type>https://www.cnblogs.com/insus/p/10903916.html 为前端服务,直接 ...
- SQL中 根据行号设置每行数据的排序数值
根据行号自动把当前行号插入到某列中 实现排序 update tempTable set DisplayOrder = right( CAST(rownum as NVARCHAR),5) from( ...
- sql中关闭自增,并插入数据
ET IDENTITY_INSERT 允许将显式值插入表的标识列中. 语法 SET IDENTITY_INSERT [ database.[ owner.] ] { table } { ON | OF ...
- sql 中如何查询某一列的数据在另一个表中有没有?
假设表table1,列a,表table2,列bselect a from table1where a not in(select b from table2)
- Sql 中的as是什么意思 + 无列名注入解析
相当于取别名 这里结合一下无列名注入的知识点: 这种方法在第十届SWPUCTF的web1——广告招租里考到了:
- SQL中采用Newtonsoft.Json处理json字符串
原文 SQL中采用Newtonsoft.Json处理json字符串 使用环境: SQL Server2005; VS2010; 关于SQL中部署CLR程序集的方法,网上一搜一大把,需要了解的自行查阅, ...
随机推荐
- js简单实现div宽度匀速增加/减小
效果类似百度首页音乐盒. 点击音乐右边的div可以变长或者变短. 代码: <!DOCTYPE html> <html lang="en"> <head ...
- .NET Core 调用WCF 服务
.NET Core 和ASP.NET Core 已经可以调用WCF 服务. 环境要求: VS2015 Update 2 +VS2015 Tooling + .NET Core SDK 下载地址: ht ...
- 炉石传说 C# 开发笔记(6月底小结)
炉石传说的开发,已经有30个工作日了. 关于法术的定义方法,有过一次重大的变更:法术效果是整个炉石的核心,正是因为丰富的法术效果,才造就了炉石的可玩性. 原来构思的时候,对于法术效果没有充分的理解,所 ...
- 【C#进阶系列】12 泛型
泛型是CLR和编程语言提供的一种特殊机制,它用于满足“算法重用” . 可以想象一下一个只有操作的参数的数据类型不同的策略模式,完全可以用泛型来化为一个函数. 以下是它的优势: 类型安全 给泛型算法应 ...
- tps (事务处理系统)
事务处理系统:Transaction processing systems (TPS) 提高事务处理效率与保证其正确性 在数据(信息)发生处将它们记录下来 通过OLTP产生新的信息 将信息保存到数据库 ...
- sql传入组合字符串批量操作
批量操作时我们可以传入一个有规律的ID或则是其他唯一值字段的组合字符串,然后:select/update/inset......where 字段 in(传入的组合字符串),而且很多时候我们还涉及到其 ...
- Python实现装饰模式的一段代码
# 实现装饰模式的一段代码 import functools def log(func): @functools.wraps(func) def wrapper(*args,**kw): print( ...
- linux常用命令之文件系统
df df - report file system disk space usage 查看文件系统的使用清空 用法 df [-hi] [path] 选项 -h human readable ,以人类 ...
- PS教程:20个新鲜出炉的 Photoshop 中级教程
Photoshop 实例教程是提高 Photoshop 技能的最佳学习途径.今天,我向大家分享最新20个 Photoshop 进阶教程,提高你的图片处理技巧,制作时尚的效果.这些教程可以帮助把你的想法 ...
- Unicode Character Table – Unicode 字符大全
Unicode(统一码.万国码.单一码)是一种在计算机上使用的字符编码.它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言.跨平台进行文本转换.处理的要求.Unicode Chara ...