惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

宝玉的分享
宝玉的分享
NISL@THU
NISL@THU
E
Exploit-DB.com RSS Feed
L
LINUX DO - 热门话题
L
Lohrmann on Cybersecurity
K
Kaspersky official blog
Project Zero
Project Zero
Cisco Talos Blog
Cisco Talos Blog
T
The Exploit Database - CXSecurity.com
P
Palo Alto Networks Blog
C
CXSECURITY Database RSS Feed - CXSecurity.com
T
Threatpost
S
Schneier on Security
G
GRAHAM CLULEY
The Hacker News
The Hacker News
T
Threat Research - Cisco Blogs
Scott Helme
Scott Helme
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
P
Privacy & Cybersecurity Law Blog
C
Cyber Attacks, Cyber Crime and Cyber Security
Cyberwarzone
Cyberwarzone
C
CERT Recently Published Vulnerability Notes
T
Tor Project blog
AWS News Blog
AWS News Blog
Simon Willison's Weblog
Simon Willison's Weblog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
爱范儿
爱范儿
P
Privacy International News Feed
云风的 BLOG
云风的 BLOG
P
Proofpoint News Feed
S
Securelist
G
Google Developers Blog
The Last Watchdog
The Last Watchdog
Google Online Security Blog
Google Online Security Blog
美团技术团队
F
Fortinet All Blogs
小众软件
小众软件
Recorded Future
Recorded Future
V
Visual Studio Blog
B
Blog RSS Feed
H
Help Net Security
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
Google DeepMind News
Google DeepMind News
Blog — PlanetScale
Blog — PlanetScale
博客园 - 聂微东
Stack Overflow Blog
Stack Overflow Blog
Martin Fowler
Martin Fowler
Latest news
Latest news
Spread Privacy
Spread Privacy
H
Heimdal Security Blog

博客园 - 董晓涛

如何将存储过程执行后的结果集放入临时表 Detect SQL timeout from ASP & Issue RollbackTrans SQL Server 2005 symmetric encrytion sample 如何解决:Error 14274: 无法添加、更新或删除从MSX服务器上发起的作业. Useful Links(to Learn SQL Server) Encrypting Data With the SQL Server Encrypt Function Convert IP To Numberic Generate table structure Generate Time Dim Generate Insert data script on a table. - 董晓涛 Execute T-SQL asynchronously Don't Use Select * Sql Server数据库被置疑后解决方法 SQL Server 2000 Service Pack 4 is released 数据规范化 Microsoft SQL Server 2005 and Vs.net 2005 April 2005 Version XML IN 20 MINUTES! CLR Integrated in SQL Server 2005 XQuery in SQL Server 2005
SQL Server 2005中对BLOB的支持(ntext,text and image)
董晓涛 · 2005-05-10 · via 博客园 - 董晓涛

前几天和一个朋友聊天的时候他说当存储非常超过8K数据的时候使用Text,ntext OR Image时,就像把这些东西扔进一个黑箱子里面,感觉这个比喻比较形象,当我们把数据存储在这几种数据类型中后,会有非常多的限制。

我们都知道当使用这三个数据类型时,如果我们需要对其进行操作时,就会发现非常麻烦,比如替换其中的某些字符,进行插入,更新时也比较麻烦。时隔5年,让我们来看一下在SQL Server 2005中是怎么解决这个问题的。

SQL Server 2005中,我们扩展了varchar,nvarchar AND binary的存储容量至2G,所以我们可以使用Varchar(max),nvarchar(max) AND varbinary(max)来取代text,ntext AND image;由于是从varchar,nvarchar AND binary进行的扩展,所以我们可以使用在SQL Server 2000中对这几种数据类型可以使用的所有函数,比如replace,upper,lower,substring.......这样我们进行许多操作时就非常有用。如下:

--附件中的po.xml是下面例子中要用到的数据。

USE AdventureWorks;

GO

--确认一下我所使用文件的长度超过8K

DECLARE @x varchar(max)

SELECT @x=s FROM OPENROWSET(BULK N'd:\po.xml',single_blob) AS a(s)---PO.xml will posted in the followed post

SELECT datalength(@x)

--the result IS

12328

下面我们试着对这个数据类型进行一些函数操作:

DECLARE @x varchar(max)

SELECT @x=s FROM OPENROWSET(BULK N'd:\po.xml',single_blob) AS a(s)

SELECT substring(@x,1,20)

--the result IS

<?xml version="1.0"

下面我们看一下怎么对这一拥有这一数据类型的列进行update,INSERT 操作。

--INSERT

CREATE TABLE test

(PID int IDENTITY(1,1) PRIMARY KEY,

doc varchar(max)

)

INSERT test(doc)

SELECT 'test'

GO

INSERT test(doc)

SELECT * FROM OPENROWSET(BULK N'd:\po.xml',single_blob) AS a

GO

SELECT * FROM test

GO

--UPDATE

UPDATE test

SET doc=(SELECT * FROM OPENROWSET(BULK N'd:\po.xml',single_blob) AS a)

WHERE PID=1

GO

SELECT * FROM test

GO

--UPDATE

UPDATE test

SET doc=upper(substring(doc,1,100))

WHERE PID=1

GO

SELECT * FROM test WHERE PID=1

GO

--the result IS

<?XML VERSION="1.0" ENCODING="UTF-8"?>

<IXQ:POLIST XMLNS:IXQ="HTTP://WWW.IPEDO.COM/XQUERYEXAMPLE"

SELECT @x=s FROM OPENROWSET(BULK N'd:\po.xml',single_blob) AS a(s)

SELECT upper(@x)