sql - 如何更新或删除 varchar 列中的所有特殊字符

标签 sql sql-server database t-sql special-characters

我搞砸了,允许用户在他们创建公司名称的地方创建公司名称,如下所示:Tom & Marks Ice Cream Shop。

问题在于该公司名称有一个链接,其他人可以点击该链接来查看该公司的简介,而 .net 会抛出错误,指出不允许使用危险字符。

我不担心公司名称是否准确,当用户注意到“&”消失时,他们可以自行更新。

如何使用 SQL 语法更新 SQL 中的列,删除所有特殊字符并在特殊字符的位置添加空格?

有没有办法在sql中识别列值中是否有特殊字符?

UPDATE [BuildingPros].[utbProfessionals]
   SET [ProfessionalName] = Replace([ProfessionalName],'some character',' ')
 WHERE ProfessionalName =ProfessionalName

最佳答案

这是查找字符串是否包含特殊字符的示例代码。你可以试试这个

DECLARE @MyString VARCHAR(100)
SET @MyString = 'abcdef&&&&ybyds'

IF (@MyString LIKE '%[^a-zA-Z0-9]%')
    BEGIN
       SET @MyString = Replace(@MyString,'&',' ')
       PRINT 'Contains "special" characters'
       PRINT @MyString
  END
ELSE
    BEGIN
       PRINT 'Does not contain "special" characters'
       PRINT @MyString
    END

您的 UPDATE 查询将如下所示:-

UPDATE [BuildingPros].[utbProfessionals]
SET [ProfessionalName] = 
                        (
                         CASE 
                            WHEN [ProfessionalName] LIKE '%[^a-zA-Z0-9]%' 
                                  THEN Replace(REPLACE( ProfessionalName, SUBSTRING( ProfessionalName, PATINDEX('%[~,@,#,$,%,&,*,^,&,%,*,(,)]%', ProfessionalName), 1 ),''),'-',' ')
                            ELSE [ProfessionalName]
                          END
                         )

或者您可以创建一个函数来删除特殊的 char 函数,然后在 Update 语句下调用它。

1) 从字符串值中删除特殊字符。 2) 除 0-9、a-z 和 A-Z 之外的所有字符均被删除 3) 返回剩余字符。

 create function dbo.RemoveSpecialChars (@s varchar(256)) returns varchar(256)
       with schemabinding
    begin
       if @s is null
          return null
       declare @s2 varchar(256)
       set @s2 = ''
       declare @l int
       set @l = len(@s)
       declare @p int
       set @p = 1
       while @p <= @l begin
          declare @c int
          set @c = ascii(substring(@s, @p, 1))
          if @c between 48 and 57 or @c between 65 and 90 or @c between 97 and 122
             set @s2 = @s2 + char(@c)
          set @p = @p + 1
          end
       if len(@s2) = 0
          return null
       return @s2
       end

然后在更新语句中调用这个函数:-

UPDATE [BuildingPros].[utbProfessionals]
SET [ProfessionalName] = 
                   (
                     CASE 
                      WHEN [ProfessionalName] LIKE '%[^a-zA-Z0-9]%' 
                           THEN (SELECT dbo.RemoveSpecialChars(ProfessionalName))
                      ELSE [ProfessionalName]
                      END
                    )

Refer

关于sql - 如何更新或删除 varchar 列中的所有特殊字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27640566/

相关文章:

sql - Oracle SQL - 减少所选属性的数量会改变结果

java - 在 hazel 转换中使用 sql 谓词的嵌套获取/更新函数

sql - PL SQL Oracle PLS-00103 : Encountered the symbol “CREATE”

sql-server - 确定数据库是 Sybase 或 SQL Server

sql-server - EXEC 的费用是多少?

c++ - 如何使用C编程创建图像数据库?

android - 在手机(ios android)跨平台QT上调用sqlite数据库路径

mysql - 将多个列连接到一个查找表的一种更简单的方法

asp.net - 如何处理每条聊天消息的时区

mysql - 无法仅恢复 mariadb 中的数据?