3

我有一个 SQL 查询,它带回 TYPE TEXT 的 2 列数据。

我想做的是:

UPDATE [DBNAME}
SET [3 15] = SUBSTR([3 15], -1))
where [3 15] LIKE  '%;'

其中 [3 15] 是列名,我想从以 ';' 结尾的列中提取数据 然后删除尾随';'

如果列类型是字符串但不是,这将很容易。

运行于:Microsoft SQL Server 2005 - Developer Edition

4

4 回答 4

4

希望这个sql对你有帮助

SELECT LEFT('CHAMLY', LENGTH('CHAMLY') -1);

进一步阅读使用http://dev.mysql.com/doc/refman/5.0/en/string-functions.html

于 2013-07-29T10:43:13.610 回答
3

尝试这个:

UPDATE table
SET someColumn = SUBSTRING(someColumn, 1, DATALENGTH(someColumn) - 1)
WHERE someColumn like '%;'

在您的示例中,您说UPDATE dbname-出于某种原因,我假设这是表的名称,因为如果那是数据库的名称,那么这是不正确的。

于 2013-07-29T10:48:44.777 回答
2

我会尽快将该文本字段更改为 varchar(max)。但是,这是一个应该可行的解决方案:

declare @a table([3 15] text)
insert @a values('aba;;;')
insert @a values('123abc;;')
insert @a values('abdc;')
insert @a values('abkjfshc')
insert @a values(';;;;')

;with a as
(
SELECT [3 15], cast([3 15] as varchar(max)) v 
-- replace @a with your actual tablename
FROM @a
)
UPDATE a
SET [3 15] = left(v, len(v)-patindex('%;[^;]%', reverse(v) + '+') + 1)
WHERE [3 15] LIKE  '%;;' -- notice the change

select * from @a

结果:

3 15
aba;
123abc;
abdc;
abkjfshc
;

编辑:

替换文本中所有 '%;;%' 的组合:

declare @a table([3 15] text)
insert @a values('aba;;;')
insert @a values('123abc;;')
insert @a values('abdc;')
insert @a values('ab;;kjf;;;;;shc')
insert @a values(';;;;')

-- if any combinations of ';;' still exists repeat until they are gone
while exists (select 1 from @a where [3 15] like '%;;%')
with a as
(
SELECT [3 15], cast([3 15] as varchar(max)) v 
-- replace @a with your actual tablename
FROM @a
WHERE [3 15] LIKE  '%;;%' -- notice the change
)
UPDATE a
-- to speed things up i used several replace
SET [3 15] = replace(replace(replace(replace(v, ';;;;', ';'), ';;;', ';'), ';;;', ';'), ';;', ';')
于 2013-07-29T10:46:10.480 回答
0

一个简单的

UPDATE Table SET column = LEFT(column,-1)
于 2015-01-12T15:10:28.417 回答