微前端架构如何改变企业的开发模式与效率提升
435
2023-03-06
解决MyBatis中为类配置别名,列名与属性名不对应的问题
在传参与接收返回结果的时候,咱们一直是使用的全限定名。但是MyBatis自己在使用很多类型的时候(如Integer,Boolean)却可以直接使用别名。那么,咱们自己的写的类能不能使用别名呢?可以。需要配置。
mybatis配置文件:
"http://mybatis.org/dtd/mybatis-3-config.dtd">
上面配置了别名,那么对象与映射文件中就可以直接使用别名,而不需要使用全限定名称
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
select * from product where id = #{id}
select * from Product
useGeneratedKeys="true" keyColumn="id" keyProperty="id"> insert into product (productName,dir_id,salePrice,supplier,brand,cutoff,costPrice) values(#{productName},#{dir_id},#{salePrice},#{supplier},#{brand},#{cutoff},#{costPrice})
useGeneratedKeys="true" keyColumn="id" keyProperty="id">
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的标签,就是让咱们来完成返回结果的关系对应的,使用方式如下:
注意:主键设置需要单独配置 如:
select * from product where id = #{id}
补充知识:MyBatis - 实体类的属性名和数据库列名不一致时的两种解决办法!
问题:两者不一致时 , 查询结果无法封装到实体!(也就无法查询出来)
① 查询的sql语句中使用别名进行查询.
但要注意: 字段名的别名 要和 实体类的属性名一致!
UserMapper.xml
select
id as userId,
username as userName,
address as userAddress,
sex as userSex,
birthday as userBirthday
from user;
注: 如果使用别名 , 每一个sql语句都需要加别名 (很麻烦)
故: 一般都使用第二种.
② 使用resultMap ★
UserMapper.xml
select * from user
注: 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.调用接口中的方法 (代理)
List
for (User user : users) {
System.out.println(ushttp://er);
}
sqlSession.close();
in.close();
}
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~