文件路徑中轉義符的問題

文件路徑轉義符引發的問題

需求問題描述:文件路徑在存儲到數據庫時‘\’就變沒了,比如:“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 ‘/’查詢結果就滿足。

當然如果匹配模式爲‘/’,立刻後面就會變成‘/////’了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章