使用MyBatis时数据库字段和实体字段不同如何解决
这期内容当中小编将会给大家带来有关使用MyBatis时数据库字段和实体字段不同如何解决,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
创新互联是专业的聊城网站建设公司,聊城接单;提供成都网站制作、成都做网站、外贸营销网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行聊城网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
当数据库字段和实体bean中属性不一致时
之前数据库Person名字字段是name,PersonBean中属性也是name,但是之后数据库中修改为了user_name,
方法1:通过sql语句的字段起别名,别名和实体中的对象属性一致
SELECT id,user_name as name,sex,age from person
方法2: mybatis最强大的地方 : reslutMap对象
添加一个中介reslutMap标签,并将select标签中的resultType改为resultMap,并对应resultMap标签的id.
结果集:resultType 基础类型,int,string,Person,
resultMap 针对中介标签resultMap而存在.
mybatis的增删改查
新增人员信息
首先在PersonMapper.xml中添加insert标签,我们的数据库字段user_name,Person实体属性为name,不一致,区别开来.然后在TestMybatis中写入代码.
INSERT INTO person(id,user_name,age,sex) VALUES(#{id},#{name},#{age},#{sex})
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 Listlist = 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 person SET user_name=#{name},age=#{age} WHERE id=#{id}
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); }
条件查询
根据条件查询
@Test //带条 件查询 public void selByL(){ SqlSession session = factory.openSession(); Mapmap = new HashMap (); map.put("name","luo%"); map.put("sex",1); List list = session.selectList("com.luogg.mapper.PersonMapper.selByL",map); System.out.println(list.size()); for(Person p : list){ System.out.println(p); } }
上述就是小编为大家分享的使用MyBatis时数据库字段和实体字段不同如何解决了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。
本文题目:使用MyBatis时数据库字段和实体字段不同如何解决
新闻来源:http://hbruida.cn/article/jphjss.html