在传参与接收返回结果的时候,咱们一直是使用的全限定名。但是MyBatis自己在使用很多类型的时候(如Integer,Boolean)却可以直接使用别名。那么,咱们自己的写的类能不能使用别名呢?可以。需要配置。
mybatis配置文件:
<&#63;xml version="1.0" encoding="UTF-8"&#63;>
上面配置了别名,那么对象与映射文件中就可以直接使用别名,而不需要使用全限定名称
<&#63;xml version="1.0" encoding="UTF-8"&#63;>insert into product (productName,dir_id,salePrice,supplier,brand,cutoff,costPrice) values(#{productName},#{dir_id},#{salePrice},#{supplier},#{brand},#{cutoff},#{costPrice}) delete from product where id = #{id} update product set productName=#{productName},dir_id=#{dir_id}, salePrice=#{salePrice},supplier=#{supplier},brand=#{brand},cutoff=#{cutoff},costPrice=#{costPrice} where id = #{id}
列名与属性名不对应的解决方案(截图不完整)
做映射文件的时候,只做了表与对象之间的联系。并没有做列与字段之间的联系。那么它们之间是怎么联系上的呢?
由于之前咱们的列名与属性名是一样的,因此框架进行了自动的识别。
那么,如果咱们的列名与属性名不一致了(对应不上),这时候应该怎么办呢?这时候需要把哪些列名与属性名对应上。
在MyBatis中,提供了一个resultMap的标签,就是让咱们来完成返回结果的关系对应的,使用方式如下:
注意:主键设置需要单独配置 如:
补充知识:MyBatis - 实体类的属性名和数据库列名不一致时的两种解决办法!
问题:两者不一致时 , 查询结果无法封装到实体!(也就无法查询出来)
① 查询的sql语句中使用别名进行查询.
但要注意: 字段名的别名 要和 实体类的属性名一致!
UserMapper.xml
注: 如果使用别名 , 每一个sql语句都需要加别名 (很麻烦)
故: 一般都使用第二种.
② 使用resultMap ★
UserMapper.xml
注: select中resultMap的属性值 要和 resultMap中id的属性值一样.
测试类: UserMapper.java
@Test public void queryAll() throws IOException { // 1.创建工厂类. InputStream in = Resources.getResourceAsStream("mybatis-config.xml"); SqlSessionFactory sqlSessiOnFactory= new SqlSessionFactoryBuilder().build(in); // 2.创建sql对象. SqlSession sqlSession = sqlSessionFactory.openSession(); // 3.创建接口的实现类对象. UserMapper mapper = sqlSession.getMapper(UserMapper.class); // 4.调用接口中的方法 (代理) Listusers = mapper.queryAll(); for (User user : users) { System.out.println(user); } sqlSession.close(); in.close(); }
以上这篇解决MyBatis中为类配置别名,列名与属性名不对应的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。