解决MyBatis中为类配置别名,列名与属性名不对应的问题

网友投稿 435 2023-03-06

解决MyBatis中为类配置别名,列名与属性名不对应的问题

解决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 users = mapper.queryAll();

for (User user : users) {

System.out.println(ushttp://er);

}

sqlSession.close();

in.close();

}

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:vue 小程序开发 教程(vue做微信小程序开发)
下一篇:MybatisPlus:使用SQL保留字(关键字)的操作
相关文章

 发表评论

暂时没有评论,来抢沙发吧~