ibatis SQLmap mysql模糊查詢字串拼的三種方法

來源:互聯網
上載者:User

標籤:ar   使用   sp   on   問題   bs   as   sql   應用   

在通常情況下iBATIS的參數在sqlmap中使用#param#的形式,參數名以’#’包著,但當使用sql的LIKE語句時就發生了問題,在單引號中無法使用#param#這種形式,下面列舉出了3種方法來實現:

當應用SELECT * FROM TABLE WHERE COL LIKE ’value%’時如果要把’value’以參數代替,可以把整個LIKE後面的字串全改為參數,即 SELECT * FROM TABLE WHERE COL LIKE #param#,此時參數param的值為字串"value%"。但有時上面這種情況會使程式變複雜,所以用參數只代替’value’時就要碰到在單引號內使用參數的問題。這時是使用’$’將參數名包起來,即SELECT * FROM TABLE WHERE COL LIKE ’$param$%’,此時參數param的值就是字串"value"。

在網上看到另一種方法,就是SELECT * FROM TABLE WHERE COL LIKE #param#||’%’。這個方法我試過了,是無效的的,mysql中"||"代表程式中的OR,無法正常運行。但是可以通過mysql的字串了串連函數:contat來實現,將字串串連起來,這樣就可以了,SELECT * FROM TABLE WHERE COL LIKE contat(#param#,’%’)

方法三:在通常情況下iBATIS的參數在sqlmap中使用#param#的形式,參數名以’#’包著,但當使用sql的LIKE語句時就發生了問題,在單引號中無法使用#param#這種形式當應用SELECT * FROM TABLE WHERE COL LIKE ’value%’時如果要把’value’以參數代替,可以把整個LIKE後面的字串全改為參數,即 SELECT * FROM TABLE WHERE COL LIKE #param#,此時參數param的值為字串"value%"。

ibatis SQLmap mysql模糊查詢字串拼的三種方法

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.