1.当实体类中的属性名和表中的字段名不一样


解决办法①: 

通过在查询的sql语句中定义字段名的别名,让字段名的别名和实体类的属性名一致 

<select id=”selectorder” parametertype=”int” resultetype=”me.gacl.domain.order”> 
 select order_id id, order_no orderno ,order_price price form orders where order_id=#{id}; 
 </select>

解决办法②: 

通过<resultMap>来映射字段名和实体类属性名的一一对应的关系 

<resultMap type=”me.gacl.domain.order” id=”orderresultmap”> 
 <!–用id属性来映射主键字段–> 
 <id property=”id” column=”order_id”> 
 <!–用result属性来映射非主键字段–> 
 <result property = “orderno” column =”order_no”/> 
 <result property=”price” column=”order_price” /> 
 </reslutMap>

2、 要使用like语句该怎么写? 有两种使用like的方法。(推荐使用)第一种方法是,在Java代码中添加sql通配符。


示例一: 

01.string wildcardname = “%smi%”; 
 02.list<name> names = mapper.selectlike(wildcardname); 
01.<select id=”selectlike”> 
 02. select * from foo where bar like #{value} 
 03.</select>第二种方式是在sql语句中拼接通配符。 
 这种方法相对来说安全性要低一些,因为可能会被sql注入攻击。 
 示例二: 
 01.string wildcardname = “smi”; 
 02.list<name> names = mapper.selectlike(wildcardname);01.<select id=”selectlike”> 
 02. select * from foo where bar like ‘%’ || ‘${value}’ || ‘%’ 
 03.</select>

重要提示: 请注意两种方式中 $ 和 # 的使用!

3、如何执行批量插入?

首先,创建一个简单的insert语句: 

01.<insert id=”insertname”> 
 02. insert into names (name) values (#{value}) 
 03.</insert>然后在java代码中像下面这样执行批处理插入: 
 01.list<string> names = new arraylist(); 
 02.names.add(“fred”); 
 03.names.add(“barney”); 
 04.names.add(“betty”); 
 05.names.add(“wilma”); 
 06. 
 07.// 注意这里 executortype.batch 
 08.sqlsession sqlsession = sqlsessionfactory.opensession(executortype.batch); 
 09.try { 
 10. namemapper mapper = sqlsession.getmapper(namemapper.class); 
 11. for (string name : names) { 
 12. mapper.insertname(name); 
 13. } 
 14. sqlsession.commit(); 
 15.} finally { 
 16. sqlsession.close(); 
 17.}

4、如何获取自动生成的(主)键值?

insert 方法总是返回一个int值 - 这个值代表的是插入的行数。 
而自动生成的键值在 insert 方法执行完后可以被设置到传入的参数对象中。 
示例: 

01.<insert id=”insertname” usegeneratedkeys=”true” keyproperty=”id”> 
 02. insert into names (name) values (#{name}) 
 03.</insert>01.name name = new name(); 
 02.name.setname(“fred”); 
 03. 
 04.int rows = mapper.insertname(name); 
 05.// 完成后,id已经被设置到对象中 
 06.system.out.println(“rows inserted = ” + rows); 
 07.system.out.println(“generated key value = ” + name.getid());

5、在mapper中如何传递多个参数?

java的反射机制并不能让框架获取到参数的名字(方法签名中只有参数类型, 
可以说是为了优化,也可以说设计就是如此,总之名字无意义), 所以mybatis默认的命名为: param1,param2…… 
如果想给他们指定名称,可以使用 @param 注解: 

01.import org.apache.ibatis.annotations.param; 
 02.public interface usermapper { 
 03. user selectuser(@param(“username”) string username, 
 04. @param(“hashedpassword”) string hashedpassword); 
 05.}然后,就可以在xml像下面这样使用(推荐封装为一个map,作为单个参数传递给mapper): 
 01.<select id=”selectuser” resulttype=”user”> 
 02. select id, username, hashedpassword 
 03. from some_table 
 04. where username = #{username} 
 05. and hashedpassword = #{hashedpassword} 
 06.</select>

6.mybatis基础: #{…} 和 ${…} 的区别


a)mybatis将 #{…} 解释为jdbc prepared statement 的一个参数标记。 

而将 ${…} 解释为字符串替换。 

比如,我们不能在表名(table name)的位置使用参数标记。 

b)假设有下面的代码: 

01.map<string, object> parms = new hashmap<string, object>(); 
 02.parms.put(“table”, “foo”); // 表名 
 03.parms.put(“criteria”, 37); // 查询过滤条件 
 04.list<object> rows = mapper.generalselect(parms); 
01.<select id=”generalselect” parametertype=”map”> 
 02. select * from ${table} where col1 = #{criteria} 
 3. 03.</select> mybatis生成的sql语句(prepared statement)如下所示: 01.select * from foo where col1 = ?


重要提示: 请注意,使用$ {…} (字符串替换)时可能会有sql注入攻击的风险。 
另外,字符串替换在处理复杂类型也可能常常发生问题,如日期类型。

由于这些因素,我们建议您尽可能地使用 #{…} 这种方式。