欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-02-23 10:25:58
当数据库字段和实体bean中属性不一致时 之前数据库person名字字段是name,personbean中属性也是name,但是之后数据库中修改为了user_name,...

当数据库字段和实体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入门之增删改查+数据库字段和实体字段不一致问题处理方法,希望对大家有所帮助