zoukankan      html  css  js  c++  java
  • MyBatis入门2_增删改查+数据库字段和实体字段不一致情况

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用.

    转载请注明 出自 : luogg的博客园 谢谢配合!

    当数据库字段和实体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);
            }
        }
        
    

    这里写图片描述

  • 相关阅读:
    rabbitmq安装详解
    linux下安装rabbitmq的rpm包问题记录
    在 CentOS 6.4上安装Erlang
    redis配置认证密码(转)
    Redis单台的安装部署及主备、哨兵部署
    查看linux系统版本的命令
    Js 实现ajax
    json的相关操作
    Diango思维图
    服务系统 server端
  • 原文地址:https://www.cnblogs.com/luogg/p/6815882.html
Copyright © 2011-2022 走看看