文件路徑轉義符引發的問題
需求問題描述:文件路徑在存儲到數據庫時‘\’就變沒了,比如:“D:\abc\123.jpg”,經過C++語言的轉義就變成“D:\abc\123.jpg”,在存到數據庫裏,這個過程mysql又會進行一次轉義,結果‘\’就變沒了。
- 解決方案
1.將’\’轉換成”\\”
C++的string提供了replace方法來實現字符串的替換,但是對於將字符串中某個字符串全部替換這個功能,string並沒有實現,我們今天來做的就是這件事。
首先明白一個概念,即string替換所有字符串,將”12212”這個字符串的所有”12”都替換成”21”,結果是什麼?
可以是22211,也可以是21221,有時候應用的場景不同,就會希望得到不同的結果,所以這兩種答案都做了實現,代碼如下:
`#include <string>
#include <iostream>
using namespace std;
string& replace_all(string& str,const string& old_value,const string& new_value)
{
while(true)
string::size_type pos(0);
if( (pos=str.find(old_value))!=string::npos )
str.replace(pos,old_value.length(),new_value);
else break;
}
return str;
}
string& replace_all_distinct(string& str,const string& old_value,const string& new_value)
{
for(string::size_type pos(0); pos!=string::npos; pos+=new_value.length()) {
if( (pos=str.find(old_value,pos))!=string::npos )
str.replace(pos,old_value.length(),new_value);
else break;
}
return str;
}
int main()
{
cout << replace_all(string(“12212”),”12”,”21”) << endl;
cout << replace_all_distinct(string(“12212”),”12”,”21”) << endl;
}
`
mysql關鍵字escape語法
like mode escape char
select ‘/’ like ‘//’ escape ‘/’
查詢結果爲1
將字符作爲表中的字段的值,查詢方式如下
select name like ‘//’ escape ‘/’
當name=‘/‘時結果也是0。
後來發現,當在mysql執行查詢時,如果自己定義了escape字符,那麼就應該注意幾點
1、查詢之前應當對like特殊字符及sql特殊字符進行轉義(_%?’”“)。
2、如果轉義後的mode中存在兩個連續的轉義字符,那麼還應該在mode前面再次添加一個轉義字符(在like特殊字符之後),如果添加後開頭爲兩個連續的轉義字符,那麼還應該再加上一個特殊字符進行轉義。
即上面改爲select name like ‘///’ escape ‘/’查詢結果就滿足。
當然如果匹配模式爲‘/’,立刻後面就會變成‘/////’了。