我在具有特殊字符的mysql表中有varchar
字段。我想使用MYSQL QUERY刪除該字符串中的所有特殊字符。SQL查詢刪除特殊字符
3
A
回答
2
MySQL不支持這樣的查詢。 MySQL查詢中你最好的拍攝是一個很大如下:
update TABLENAME
set FIELDNAME = replace(FIELDNAME,'_','')
+0
偉大的答案。真的很有幫助。謝謝。繼續努力吧... –
1
使用
update table_name set field_name = REPLACE(field_name,'/','')
+0
非常感謝你..它的工作 –
0
替換以下字符
~ ! @ # $ %^& * () _ +
` - =
{ } |
[ ] \
: "
; '
< > ?
, .
這個SQL
SELECT note as note_original,
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(
REPLACE(note, '"', ''),
'.', ''),
'?', ''),
'`', ''),
'<', ''),
'=', ''),
'{', ''),
'}', ''),
'[', ''),
']', ''),
'|', ''),
'\'', ''),
':', ''),
';', ''),
'~', ''),
'!', ''),
'@', ''),
'#', ''),
'$', ''),
'%', ''),
'^', ''),
'&', ''),
'*', ''),
'_', ''),
'+', ''),
',', ''),
'/', ''),
'(', ''),
')', ''),
'-', ''),
'>', ''),
' ', '-'),
'--', '-') as note_changed FROM invheader
2
您可以使用以下功能
DROP FUNCTION IF EXISTS `stripSpeciaChars`;
DELIMITER ;;
CREATE FUNCTION `stripSpeciaChars`(`dirty_string` varchar(2048),allow_space TINYINT,allow_number TINYINT,allow_alphabets TINYINT,no_trim TINYINT) RETURNS varchar(2048) CHARSET utf8
BEGIN
/**
* MySQL function to remove Special characters, Non-ASCII,hidden characters leads to spaces, accents etc
* Downloaded from http://DevZone.co.in
* @param VARCHAR dirty_string : dirty string as input
* @param VARCHAR allow_space : allow spaces between string in output; takes 0-1 as parameter
* @param VARCHAR allow_number : allow numbers in output; takes 0-1 as parameter
* @param VARCHAR allow_alphabets : allow alphabets in output; takes 0-1 as parameter
* @param VARCHAR no_trim : don't trim the output; takes 0-1 as parameter
* @return VARCHAR clean_string : clean string as output
*
* Usage Syntax: stripSpeciaChars(string,allow_space,allow_number,allow_alphabets,no_trim);
* Usage SQL> SELECT stripSpeciaChars("sdfa7987*&^&*ÂÃ ÄÅÆÇÈÉÊ sd sdfgËÌÍÎÏÑ ÒÓÔÕÖØÙÚàáâã sdkarkhru",0,0,1,0);
* result : sdfasdsdfgsdkarkhru
*/
DECLARE clean_string VARCHAR(2048) DEFAULT '';
DECLARE c VARCHAR(2048) DEFAULT '';
DECLARE counter INT DEFAULT 1;
DECLARE has_space TINYINT DEFAULT 0; -- let spaces in result string
DECLARE chk_cse TINYINT DEFAULT 0;
DECLARE adv_trim TINYINT DEFAULT 1; -- trim extra spaces along with hidden characters, new line characters etc.
if allow_number=0 and allow_alphabets=0 then
RETURN NULL;
elseif allow_number=1 and allow_alphabets=0 then
set chk_cse =1;
elseif allow_number=0 and allow_alphabets=1 then
set chk_cse =2;
end if;
if allow_space=1 then
set has_space =1;
end if;
if no_trim=1 then
set adv_trim =0;
end if;
IF ISNULL(dirty_string) THEN
RETURN NULL;
ELSE
CASE chk_cse
WHEN 1 THEN
-- return only Numbers in result
WHILE counter <= LENGTH(dirty_string) DO
SET c = MID(dirty_string, counter, 1);
IF ASCII(c) = 32 OR ASCII(c) >= 48 AND ASCII(c) <= 57 THEN
SET clean_string = CONCAT(clean_string, c);
END IF;
SET counter = counter + 1;
END WHILE;
WHEN 2 THEN
-- return only Alphabets in result
WHILE counter <= LENGTH(dirty_string) DO
SET c = MID(dirty_string, counter, 1);
IF ASCII(c) = 32 OR ASCII(c) >= 65 AND ASCII(c) <= 90 OR ASCII(c) >= 97 AND ASCII(c) <= 122 THEN
SET clean_string = CONCAT(clean_string, c);
END IF;
SET counter = counter + 1;
END WHILE;
ELSE
-- return numbers and Alphabets in result
WHILE counter <= LENGTH(dirty_string) DO
SET c = MID(dirty_string, counter, 1);
IF ASCII(c) = 32 OR ASCII(c) >= 48 AND ASCII(c) <= 57 OR ASCII(c) >= 65 AND ASCII(c) <= 90 OR ASCII(c) >= 97 AND ASCII(c) <= 122 THEN
SET clean_string = CONCAT(clean_string, c);
END IF;
SET counter = counter + 1;
END WHILE;
END CASE;
END IF;
-- remove spaces from result
if has_space=0 then
SET clean_string =REPLACE(clean_string,' ','');
end if;
-- remove extra spaces, newline,tabs. from result
if adv_trim=1 then
SET clean_string =TRIM(Replace(Replace(Replace(clean_string,'\t',''),'\n',''),'\r',''));
end if;
RETURN clean_string;
END
;;
DELIMITER ;
SELECT stripSpeciaChars("foo79ÒÓÔÕÖØÙÚàáâã 87*&bÄÅÆÇÈÉÊar",1,0,1,1); -- result foo bar
相關問題
- 1. 刪除特殊字符SQL
- 2. 特殊刪除查詢
- 3. 在.htaccess中刪除查詢字符串中的特殊字符
- 4. 刪除SQL中的特殊字符
- 5. 刪除特殊字符?
- 6. 刪除特殊字符
- 7. JSON刪除特殊字符
- 8. 刪除特殊字符php
- 9. Mawk - 刪除特殊字符
- 10. 特殊字符刪除'sed'
- 11. 刪除特殊字符
- 12. 刪除特殊字符\
- 13. SQL查詢和特殊字符
- 14. SQL查詢列有特殊字符
- 15. oracle sql - 查詢特殊字符
- 16. SQL查詢的特殊字符只有
- 17. 特殊字符在SQL查詢
- 18. Mysql刪除特殊字符後出現特定特殊字符
- 19. lucene查詢特殊字符
- 20. 查詢的特殊字符
- 21. mysql查詢特殊字符
- 22. 試圖刪除特殊的查詢字符串
- 23. 從電話號碼查詢%刪除特殊字符,如%
- 24. 刪除字典中的特殊字符
- 25. 在sql表字段中刪除特殊字符和數字
- 26. SQL特殊字符
- 27. 從URL中刪除特殊字符
- 28. 從Retrofit2響應刪除特殊字符
- 29. 無寬度特殊字符刪除
- 30. 如何刪除特殊字符?
那些特殊字符是什麼? –
特殊字符,如'_',' - ','\'等,我也想刪除空格 –
@ramkumar我認爲你需要比「等」更具體。也許這更容易告訴你想要保持哪些字符_keep_? –