1. 程式人生 > >mybatis中傳遞引數時,會加上單引號

mybatis中傳遞引數時,會加上單引號

1) 使用#{引數}傳入會加上單引號,sql語句解析是會加上"",

比如  select * from table where name = #{name} ,傳入的name為小李,那麼最後打印出來的就是

 select * from table where name = ‘小李’,就是會當成字串來解析,這樣相比於$的好處是比較明顯對的吧,#{}傳參能防止sql注入,如果你傳入的引數為 單引號',那麼如果使用${},這種方式 那麼是會報錯的,

2)${}

另外一種場景是,如果你要做動態的排序,比如  order by   column,這個時候務必要用${},

因為如果你使用了#{},那麼打印出來的將會是  select * from table order by  'name'  ,這樣是沒用,