全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法

当数据库字段和实体bean中属性不一致时

之前数据库Person名字字段是name,PersonBean中属性也是name,但是之后数据库中修改为了user_name,

方法1:通过sql语句的字段起别名,别名和实体中的对象属性一致

SELECT id,user_name as name,sex,age from person
<select id="find" resultType="com.luogg.domain.Person">
  SELECT id,user_name as name,sex,age from person
</select>

方法2: mybatis最强大的地方 : reslutMap对象

添加一个中介reslutMap标签,并将select标签中的resultType改为resultMap,并对应resultMap标签的id.

结果集:resultType 基础类型,int,string,Person,

resultMap 针对中介标签resultMap而存在.

<!--配置命名空间,命名空间+ .id 是唯一的sql语句标示符-->
<mapper namespace="com.luogg.mapper.PersonMapper">
 <!--中介,当数据库字段和实体bean对象属性不一致时,做一个对应关系-->
 <resultMap id="personRM" type="com.luogg.domain.Person">
  <!--主键映射-->
  <id property="id" column="ID"></id>
  <!--普通字段,property指实体属性,column结果集的字段名称,一致的字段可以不写-->
  <result property="name" column="USER_NAME"></result>
 </resultMap>
 <!--查询所有数据,参数有id,resultType结果集,parameterType参数-->
 <!--注意 : sql语句中如果有要填写集合的,比如查询所有数据,返回一个Person的结果集,那么resultType参数直接写 路径+集合的类型
  比如: 返回一个Person集合,那么就填写Person Bean所在的路径+Person-->
 <select id="find" resultMap="personRM">
  SELECT * from person
 </select>
 <!--通过ID查询数据,当有查询条件时,需要写parameterType,返回结果集仍然是Person, #{id}或者${id}都可以-->
 <select id="selById" parameterType="int" resultType="com.luogg.domain.Person">
  SELECT * FROM person WHERE id = #{id}
 </select>
</mapper>

    mybatis的增删改查

新增人员信息

首先在PersonMapper.xml中添加insert标签,我们的数据库字段user_name,Person实体属性为name,不一致,区别开来.然后在TestMybatis中写入代码.

<!--添加人员-->
 <insert id="insert" parameterType="com.luogg.domain.Person">
  INSERT INTO person(id,user_name,age,sex) VALUES(#{id},#{name},#{age},#{sex})
 </insert>

package test;

import com.luogg.domain.Person;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Before;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.util.List;
/**
 * Created by luogg on 2017/2/17.
 */
public class TestMybatis {
 //SqlSessionFactory为线程安全的
 private SqlSessionFactory factory;
 @Before
 public void init() throws IOException {
  String resource = "sqlMapConfig.xml";
  InputStream is = Resources.getResourceAsStream(resource);
  factory = new SqlSessionFactoryBuilder().build(is);
 }
 @Test //查询所有
 public void findAll() throws IOException {
  /**
   * 测试数据库的连接
   * 1.定义一个String类型的变量resource,指向刚才配置的连接数据库的xml文件
   * 2.创建一个输入流,来读取我们的数据库配置文件
   * 3.输入流创建工厂.
   * 4.有了工厂之后open工厂
   * 5.通过session访问配置文件中的sql语句
   */
  SqlSession session = factory.openSession();
  //如何访问PersonMapper.xml中的sql语句呢? 命名空间+ .id
  List<Person> list = session.selectList("com.luogg.mapper.PersonMapper.find");
  System.out.println(list.size());
  for(Person p : list){
   System.out.println(p);
  }
 }
 @Test //通过ID查询人员信息
 public void selById(){
  SqlSession session = factory.openSession();
  Person p = session.selectOne("com.luogg.mapper.PersonMapper.selById",1);
  System.out.println(p);
 }
 @Test //添加人员信息
 public void add(){
  SqlSession session = factory.openSession();
  Person p = new Person();
  p.setId(4);
  p.setName("luogg");
  p.setAge(22);
  p.setSex(1);
  int i = session.insert("com.luogg.mapper.PersonMapper.insert",p);
  session.commit();
  if(i==1){
   System.out.print("添加人员成功");
  }
 }
}

修改人员信息 , 查询总的记录条数

prsonMapper.xml文件

<!--修改成员信息-->
 <update id="update" parameterType="com.luogg.domain.Person">
  UPDATE person SET user_name=#{name},age=#{age} WHERE id=#{id}
 </update>
 <!--查询总的记录-->
 <select id="count" resultType="int">
  SELECT COUNT(*) FROM person
 </select>

TestMybatis.java文件

@Test //修改人员信息
 public void updatePer(){
  SqlSession session = factory.openSession();
  Person p = new Person();
  p.setId(4);
  p.setName("luoggg");
  //p.setSex(1);
  p.setAge(23);
  int i = session.update("com.luogg.mapper.PersonMapper.update",p);
  session.commit();
  if(i==1){
   System.out.print("修改信息成功");
  }
 }
 @Test //查询总的记录条数
 public void selCount(){
  SqlSession session = factory.openSession();
  int i = session.selectOne("com.luogg.mapper.PersonMapper.count");
  System.out.println(i);
 }

条件查询

根据条件查询

<!--带条件查询-->
 <select id="selByL" parameterType="map" resultMap="personRM">
  SELECT <include refid="cols"/> FROM person
  where user_name like #{name}
  AND sex=#{sex}
 </select>
@Test //带条 件查询
 public void selByL(){
  SqlSession session = factory.openSession();
  Map<String,Object> map = new HashMap<String, Object>();
  map.put("name","luo%");
  map.put("sex",1);
  List<Person> list = session.selectList("com.luogg.mapper.PersonMapper.selByL",map);
  System.out.println(list.size());
  for(Person p : list){
   System.out.println(p);
  }
 }

以上所述是小编给大家介绍的MyBatis入门之增删改查+数据库字段和实体字段不一致问题处理方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!


# mybatis增删改查  # mybatis  # 数据库字段  # Mybatis实现增删改查及分页查询的方法  # Mybatis实现数据的增删改查实例(CRUD)  # Mybatis实现增删改查  # Mybatis实现自动生成增删改查代码  # 简述Mybatis增删改查实例代码  # MyBatis最常用的增删改查操作详解  # 小编  # 配置文件  # 条数  # 给大家  # 并将  # 做一个  # 仍然是  # 数据库中  # 所述  # 创建一个  # 给我留言  # 不写  # 主键  # 有任何  # 连接数据库  # 是唯一  # Bean  # parameterType  # SqlSessionFactoryBuilder  # SqlSession 


相关文章: 高端智能建站公司优选:品牌定制与SEO优化一站式服务  建站主机如何安装配置?新手必看操作指南  高防服务器租用首荐平台,企业级优惠套餐快速部署  公众号网站制作网页,微信公众号怎么制作?  高端云建站费用究竟需要多少预算?  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  青浦网站制作公司有哪些,苹果官网发货地是哪里?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  制作农业网站的软件,比较好的农业网站推荐一下?  建站之星如何配置系统实现高效建站?  如何在IIS中新建站点并配置端口与物理路径?  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  如何在阿里云高效完成企业建站全流程?  如何确保西部建站助手FTP传输的安全性?  外贸公司网站制作哪家好,maersk船公司官网?  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  如何在Windows服务器上快速搭建网站?  网站企业制作流程,用什么语言做企业网站比较好?  韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐  如何选择域名并搭建高效网站?  建站之星后台密码遗忘?如何快速找回?  建站之星2.7模板快速切换与批量管理功能操作指南  c# 在ASP.NET Core中管理和取消后台任务  如何在万网自助建站中设置域名及备案?  北京制作网站的公司,北京铁路集团官方网站?  制作销售网站教学视频,销售网站有哪些?  宝塔新建站点为何无法访问?如何排查?  临沂网站制作企业,临沂第三中学官方网站?  贸易公司网站制作流程,出口贸易网站设计怎么做?  如何挑选高效建站主机与优质域名?  如何基于PHP生成高效IDC网络公司建站源码?  如何制作网站标识牌,动态网站如何制作(教程)?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  湖南网站制作公司,湖南上善若水科技有限公司做什么的?  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  创业网站制作流程,创业网站可靠吗?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  建站168自助建站系统:快速模板定制与SEO优化指南  建站之星CMS五站合一模板配置与SEO优化指南  建站之星安装步骤有哪些常见问题?  建站之星安装后如何配置SEO及设计样式?  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  微信小程序制作网站有哪些,微信小程序需要做网站吗?  建站主机解析:虚拟主机配置与服务器选择指南  大同网页,大同瑞慈医院官网?  建站之星代理平台如何选择最佳方案?  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。