这期内容当中小编将会给大家带来有关MyBatis中出现列名与属性名不匹配如何解决,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
创新互联专注为客户提供全方位的互联网综合服务,包含不限于网站设计、成都做网站、乐山网络推广、重庆小程序开发、乐山网络营销、乐山企业策划、乐山品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们大的嘉奖;创新互联为所有大学生创业者提供乐山建站搭建服务,24小时服务热线:13518219792,官方网址:www.cdcxhl.commybatis配置文件:
上面配置了别名,那么对象与映射文件中就可以直接使用别名,而不需要使用全限定名称
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中出现列名与属性名不匹配如何解决了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。