发布网友 发布时间:2022-04-30 08:04
共5个回答
懂视网 时间:2022-04-30 12:26
早晨在群里灌水。突然有人发了这个,问哪里错了,下图是sql语句和报错信息。。。
一群人猜了半天,呵呵,最后发现是 ”全角空格“ 引起的。。。真是醉了。。记录下,引以为戒。
sql语句,一个全角空格的考验
标签:
热心网友 时间:2022-04-30 09:34
select unicode( 's')/*下面为全角与半角的转换函数*/
if object_id(N'u_convert',N'FN') is not null
drop function u_convert
GO
/*
转换原理
全角字符unicode编码从65281~65374
半角字符unicode编码从33~126
空格比较特殊,全角为 12288,半角为 32
而且除空格外,全角/半角按unicode编码排序在顺序上是对应的
所以可以直接通过用+-法来处理非空格数据,对空格单独处理
like的时候,指定排序规则 COLLATE Latin1_General_BIN
是保证字符顺序按unicode编码排序
*/
create function u_convert(
@str nvarchar(4000), --要转换的字符串
@flag bit --转换标志,0转换成半角,1转换成全角
)
returns nvarchar(4000)
AS
begin
declare
@pat nvarchar(8),
@step int,
@i int,
@spc int
if @flag=0
begin
select @pat=N'%[!-~]%',@step=-65248,
@str=replace(@str,N' ',N' ')
end
else
begin
select @pat=N'%[!-~]%',@step=65248,
@str=replace(@str,N' ',N' ')
end
set @i=patindex(@pat collate LATIN1_GENERAL_BIN,@str)
while @i>0
select @str=replace(@str,
substring(
@str,@i,1),
nchar(unicode(substring(@str,@i,1))+@step)),
@i=patindex(@pat collate LATIN1_GENERAL_BIN,@str)
return(@str)
end
GO
测试语句:
select dbo.u_convert('11',1) as [a],'11' as [b],dbo.u_convert('111',0) as [c]
热心网友 时间:2022-04-30 10:52
额,又是一个没说明数据环境的~~~~~~~~~~~~~~~~~~热心网友 时间:2022-04-30 12:26
给你个思路热心网友 时间:2022-04-30 14:18
select 1 from al where to_multi_byte('A')='A';