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