当前位置: 首页 > 图文教程 > 数据库 > MSSQL > SQL Server TEXT、NTEXT字段拆分的问题

MSSQL
浅析SQL Server与Oracle、DB2的比较
SQL Artisan数据库访问组件功能概述
50种方法巧妙优化你的SQL Server数据库
SQL Server 2005数据库管理10个特点
拷贝的SQL Server 7的恢复方法
SQL Server 2000启动1069错误解决方法
SQL Server 2005—数据库管理10个特点
SQL概述及在网络安全中的应用(下)
深入浅出SQL教程之SELECT语句的自连接
SQL Server查询设计:避免10个错误
SQL概述及在网络安全中的应用(上)
某外企SQL Server面试题
解决MSSQL占用过多内存的简单方法介绍
安装SQL Server 2005实例环境图解
步骤指南:如何合并SQL Server
SQL Server查询处理器机制与结构(下)
避免在 SQL Server 中盲目地追求一句处理
Sql Sever数据库自动备份
SQL Server查询处理器机制与结构(上)
精华推荐:加速SQL查询的特征函数法

MSSQL 中的 SQL Server TEXT、NTEXT字段拆分的问题


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 115 ::
收藏到网摘: n/a

SQL Server TEXT、NTEXT字段拆分的问题

以下为引用的内容:

SET NOCOUNT ON
CREATE TABLE #T (C NTEXT)
GO
INSERT INTO #T VALUES('')
GO
CREATE TABLE #T2 (C CHAR(8))
GO

DECLARE @S1 VARCHAR(8000),@S2 VARCHAR(8000),@I INT
SET @S1=''
SET @S2=''
SET @I=1
WHILE @I<=1000
BEGIN
  SET @S1=@S1+'A'+RIGHT('0000000'+CAST(@I AS VARCHAR(5)),6)+','
  SET @S2=@S2+'B'+RIGHT('0000000'+CAST(@I AS VARCHAR(5)),6)+','
  SET @I=@I+1
END

DECLARE @P BINARY(16)
SELECT @P = TEXTPTR(C) FROM #T
UPDATETEXT #T.C @P NULL NULL @S1
UPDATETEXT #T.C @P NULL NULL @S2
SELECT DATALENGTH(C) FROM #T

DECLARE @DL INT
SET @DL = (SELECT DATALENGTH(C) FROM #T)/2
SET @I=1
WHILE @I <= @DL
BEGIN
  INSERT INTO #T2 SELECT SUBSTRING(C,@I,7) FROM #T
  SET @I=@I+8
END

SELECT * FROM #T2
 
/*
功能:实现split功能的函数
*/

以下为引用的内容:

create function dbo.fn_split
(
@inputstr varchar(8000),
@seprator varchar(10)
)
returns @temp table (a varchar(200))
as

begin
declare @i int

set @inputstr = rtrim(ltrim(@inputstr))
set @i = charindex(@seprator, @inputstr)

while @i >= 1
begin
insert @temp values(left(@inputstr, @i - 1))

set @inputstr = substring(@inputstr, @i + 1, len(@inputstr) - @i)
set @i = charindex(@seprator, @inputstr)
end

if @inputstr <> ''
insert @temp values(@inputstr)

return
end
go

--调用

declare @s varchar(1000)

set @s='1,2,3,4,5,6,7,8,55'

select * from dbo.fn_split(@s,',')

drop function dbo.fn_split


SQL Server TEXT、NTEXT字段拆分的问题