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

编者:李国帅

qq:9611153 微信lgs9611153

时间:2008-7-22

背景:

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

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

 

问题描述:

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

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

所需资源:

Sqlserver2000,查询分析器

 

插入数据:

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

 

打印发现数据长度不对,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这样的文件,因为可能关联文件的数据,不妨直接使用文件方式存放。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

微澜-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值