0
点赞
收藏
分享

微信扫一扫

mssql插入二进制大长度数据以及print打印


编者:李国帅


背景:

我们在操作数据的时候,会用到把一个较大数据存入数据库,字段类型可以使用blob,如果不是太大,也可以使用[varchar] (5000)字段存入较长数据。

下面在sqlserver中对插入大数据并查询进行了测试,分析了其中遇到的问题。

 

问题描述:

插入二进制这种操作,在查询管理器中编写和执行,有问题也不直观,因为很多字符根本无法显示。所以一般是在程序中使用代码方式直接存入的。

同时如果打印的话,可以使用convert(varbinary(的方式打印,虽然只能显示128个字符,但是二进制大数据确实已经存入数据库。

所需资源:

Sqlserver2000,查询分析器

 

插入数据:

编写插入数据,然后在ultraEdit中查看。

mssql插入二进制大长度数据以及print打印_2d

 

打印发现数据长度不对,print只能显示Message小于128的部分

--SET ANSI_PADDING ON
--print convert(varbinary(4096),'??0\t99999999999999541212-541216-54121232111114-541212321111133119.18.32!22;41.14121111111')

--反向查看
INSERT INTO [mydb].[dbo].[UnSendCommInfo]( [Type], [SendStatus], [Message])
VALUES( 303, 0, 0x3F3F010130020101055C7401013939393939393939393939393939050101013534313231322D3534313231362D35343132313233323131313131342D3534313231323332313131313133010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101333131392E31382E33322132323B34312E31340131323131313131313101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101)

实际数据是多少呢?

--insert into unsendcomminfo values(303,0,convert(varbinary(4096),'??0\t99999999999999541212-541216-54121232111114-541212321111133119.18.32!22;41.14121111111'))
--反向查看
--print len(convert(varchar(4096),0x3F3F010130020101055C7401013939393939393939393939393939050101013534313231322D3534313231362D35343132313233323131313131342D3534313231323332313131313133010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101))
select len(message) from UnSendCommInfo --4071
select convert(varchar(4096),message) from unsendcomminfo
--select * from UnSendCommInfo
--print len('...')

delete from unsendcomminfo
--SET ANSI_PADDING OFF

虽然只能打印出128个字节,实际上已经存入数据库

 

总结:

数据库中保留大数据字段也是有用处的,虽然日常生工作中更喜欢把文件直接存储在磁盘中,在数据库中仅仅保存文件地址。

我认为,如果是单文件数据,比如txt,word之类的不妨直接存到数据库;如果是html这样的文件,因为可能关联文件的数据,不妨直接使用文件方式存放。

 

举报

相关推荐

0 条评论