Rumah > Java > javaTutorial > teks badan

MyBatis出现数据库字段和实体bean中属性不一致时处理方法

Y2J
Lepaskan: 2018-05-18 17:10:18
asal
7291 orang telah melayarinya

这篇文章主要介绍了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>
Salin selepas log masuk

方法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>
Salin selepas log masuk

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>
Salin selepas log masuk

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("添加人员成功");
  }
 }
}
Salin selepas log masuk

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

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>
Salin selepas log masuk

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);
 }
Salin selepas log masuk

条件查询

根据条件查询

<!--带条件查询-->
 <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);
  }
 }
Salin selepas log masuk

【相关推荐】

1. 特别推荐“php程序员工具箱”V0.1版本下载

2. Java免费视频教程

3. JAVA初级入门视频教程

Atas ialah kandungan terperinci MyBatis出现数据库字段和实体bean中属性不一致时处理方法. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan