MyBatis帶參查詢

基礎不牢,地動山搖發表於2020-11-19

#{}佔位符

類似於jdbc中通過PreparedStatement進行操作的方式, 會將sql語句中需要引數的位置使用?進行佔位,後續由傳進來的引數進行引數的繫結。?處繫結的都是值,不能指定表的列,轉換成sql時表名會被當成字串,會出錯,防止sql注入。

select username,age,password from 'tb_user'

簡單型別引數

簡單型別指的是: 基本資料型別, 包裝型別, String, java.sql.*。當引數是簡單型別時, MyBatis會忽略SQL語句中引數的個數和佔位符的名稱, 然後將引數進行自動繫結. parameterType屬性可以定義引數的型別, 如果定義, 傳參時要求引數型別必須和指定的型別一致, 否則丟擲ClassCastException。

<select id="selBaseType" resultType="pojo.User" parameterType="java.lang.Integer">
    select  * from tb_users where id=#{id}
</select>
User user=sqlSession.selectOne("selBaseType",1);

Map型別引數

當引數是Map集合時, SQL語句中的#{}裡應該寫Map集合的key值,MyBatis會通過key只找到value然後進行引數繫結。如果key不存在, 不會報錯,會使用null進行引數繫結。

<select id="selByMap" resultType="pojo.User">
    select  * from tb_users where username=#{username} and password=#{password}
</select>
Map<String,String> map=new HashMap<>();
map.put("username","zhangsan");
map.put("password","123456");
User user=sqlSession.selectOne("selByMap",map);

物件型別引數傳遞

當引數是物件型別時,SQL語句中的#{}裡應該寫物件的getter方法對應的屬性名。當getter方法不存在時, 丟擲異常。

<select id="selByObject" resultType="pojo.User">
    select  * from tb_users where username=#{username} and password=#{password}
</select>
User user1=new User();
user1.setUsername("lisi");
user1.setPassword("123456");
User user=sqlSession.selectOne("selByObject",user1);

${}

類似於jdbc中通過Statement進行操作的方式, 會直接將傳遞的引數和SQL語句進行字串的拼接。 一般當SQL語句結構不確定時使用。
當表名不確定,條件不確定,排序規則不確定的時候,不能使用#{},應該換做${}。對於簡單資料型別,應儘量使用#{},避免錯誤。
${}需要加’'傳入的引數才能變成字串,不然會被當成列名。

select  * from tb_users where username='${username}' and password='${password}'

如果${123}會當成整型數字替換佔位,此時傳入的引數無效。

相關文章