1、去掉mysql數(shù)據庫中某字段的換行符和回車符:replace函數(shù)
目前創(chuàng)新互聯(lián)已為數(shù)千家的企業(yè)提供了網站建設、域名、雅安服務器托管、網站改版維護、企業(yè)網站設計、莊浪網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
UPDATE student SET name = REPLACE(REPLACE(title,CHAR(10),''),CHAR(13),'') WHERE ID = xxxxxx;
注解:CHAR(10),'':將換行符CHAR(10)替換成空串,可理解為刪除換行符
CHAR(13),'':將回車符CHAR(13)替換成空串,可理解為刪除回車符
2、往mysql某個字段中插入換行符和回車符:concat函數(shù)
concat函數(shù)可以連接一個或者多個字符串,若其中一個為null,則返回null
UPDATE student SET name = concat('字符串1',CHAR(10),CHAR(13),'字符串2') WHERE ID = xxxxx;
注解:這樣就將 字符串1 和 換行符 和 回車符 和字符串2 拼接在一起了
后記:查詢某個字段是否含有換行符和回車符
select *from student where name like '% \n\r %'
import_table(importTable) 的延申功能:可定制化行輸入。
import_table(importTable) 我們之前有介紹過,是一款并行導入各種格式文本的工具,封裝了 MySQL 語句?load data local infile。
比如說要導入一個以 TAB 為分隔符的文本數(shù)據文件:/tmp/sample_ytt.txt?到表:ytt_new.t1,可以執(zhí)行下面語句:
上面結果是?load data infile?語句的導入結果。如果改用 import_table 方法來做同樣的事情,基于 Python 語法,使用方法如下:
那接下來看另外一個需求:在導入文本文件時對每行做預處理(例如在導入數(shù)據之前更改列 r2 的值為 mod(r1,10),列 r5 的值為 abs(r4-46) ),這樣可以減少導入后再次處理的時間開銷。
這個需求用?load data infile?語句非常容易實現(xiàn):(導入時更改列 r2 和 r5 的數(shù)據,類似 UPDATE 語法)
那如果要用 util.import_table(importTable) 來實現(xiàn)上面的需求,在 MySQL 8.0.22 之前是沒辦法的。
隨著 MySQL 8.0.22 的發(fā)布,MySQL 對 import_table 方法做了些擴充功能,其中增加了一個選項 “decodeColumns” 可以實現(xiàn)字段的預先輸入定制化功能,并且還可以更加豐富。
接下來用 import_table 來實現(xiàn)上面的需求,定制化字段 r2 和 r5:
以上 Options 選項,見下圖:
我來具體解釋下上圖的含義:藍色字體 columns 對應的數(shù)組分別指定數(shù)據文件中的每行字段,也就是默認的 TAB 分隔符所分割的每列值,1 和 2 代表占位符,1 代表數(shù)據文件中每行的第一個列,2 代表數(shù)據文件中每行的第四列,decodeColumns 字典分別對需要預先輸入的字段做處理。比如 r1 字段保留為變量 @1,r2 字段對應 mod(r1,10) 等。
如果還是不太理解變換規(guī)則,可以臨時打開 general log, 上面 import_table(importTable)對應的 MySQL 日志為:
以上日志寫的很清楚,內部轉換為最基本的load data infile語法。
那這里我簡單解讀了下 MySQL 8.0.22 對 MySQL Shell 的一項定制化輸入文本文件的新特性,更多的新特性可以繼續(xù)關注。
題主你好,關于你的問題,如何表達換行,可以使用以下的代碼條件,僅供參考。
java類中寫sql語句,查詢條件包含換行
detachedCriteria.add(Restrictions.or(
Restrictions.like("chengBanDanWeiIds", rForm.getChengBanDanWeiIds()+(char)13, MatchMode.START),
Restrictions.or(
Restrictions.like("chengBanDanWeiIds", rForm.getChengBanDanWeiIds()+ (char)13, MatchMode.END),
Restrictions.eq("chengBanDanWeiIds", rForm.getChengBanDanWeiIds())
)));
換行不用CHAR(13),用(char)13
解決辦法是存到數(shù)據庫里面的時候做一次轉換,在從數(shù)據庫里讀取數(shù)據的時候再做一次轉換,這個轉換數(shù)據庫有函數(shù)可以自己轉,不知道你用的什么數(shù)據庫,一般都會有字符替換函數(shù)的。
解決方法:
UPDATE tablename SET field = REPLACE(REPLACE(field, CHAR(10), ''), CHAR(13), '');
char(10): 換行符
char(13): 回車符
MySQL的trim函數(shù)沒辦法去掉回車和換行,只能去掉多余的空格,可以用MySQL的replace函數(shù),解決掉這個問題,具體解決辦法如下:
假設想要審核數(shù)據庫中內容為“我愛你
”的短信息(注意內容后有換行)通過(status改變成1)
之前的SQL語句是不起作用的
UPDATE `tran`
SET `status` = '1'
WHERE `msg` = '我愛你';
修改之后的語句
UPDATE `tran`
SET `status` = '1'
WHERE trim( replace( `msg`, '\r\n', ' ' ) ) = '我愛你';
把數(shù)據中的回車換行等替換成空格之后再trim掉,就達到目的了,雖然不是特別完美,但是由于沒辦法在用戶錄入的時候控制,所以只能出此下策,好在MySQL內置函數(shù)的效率還是很有保證的。
UPDATE `tran`
SET `status` = '1'
WHERE trim( trim(
BOTH '\r\n'
FROM content ) ) = '我愛你'
用了兩個trim,這樣的好處是不會替換內容中間的換行和回車,只會處理頭尾的空格換行回車,相當于php中trim函數(shù)的作用了。
@echo off
mysql -uroot -pabc mydatabase --execute="create table a(id int(10))"
mysql -uroot -pabc mydatabase --execute="create table b(id int(10))"
或者把后面的語句寫到cretab.sql里
mysql -uroot -pabc mydatabasecretab.sql