MyBatis-SELECT基本查询

1、返回一个 LIST

    <!-- public List<Employee> getEmpsByLastNameLike(String lastName); -->
    <!--resultType:如果返回的是一个集合,要写集合中元素的类型  -->
    <select id="getEmpsByLastNameLike" resultType="com.atguigu.mybatis.bean.Employee">
        select * from tbl_employee where last_name like #{lastName}
    </select>

2、将查询记录封装为一个 Map

     <!--public Map<String, Object> getEmpByIdReturnMap(Integer id);  -->
     <select id="getEmpByIdReturnMap" resultType="map">
         select * from tbl_employee where id=#{id}
     </select>

  返回一条记录的 map;key 就是列名,值就是对应的值。

3、多条记录封装为一个 map

    @MapKey("id")
    public Map<Integer, Employee> getEmpByLastNameLikeReturnMap(String lastName);
     <select id="getEmpByLastNameLikeReturnMap" resultType="com.atguigu.mybatis.bean.Employee">
         select * from tbl_employee where last_name like #{lastName}
     </select>

  Map<Integer,Employee>: 键是这条记录的主键,值是记录封装后的 javaBean。

  @MapKey: 告诉 mybatis 封装这个 map 的时候使用哪个属性作为 map 的 key。

4、多条件查询  

    public Employee getEmpByIdAndLastName(@Param("id")Integer id,@Param("lastName")String lastName);
     <select id="getEmpByIdAndLastName" resultType="com.atguigu.mybatis.bean.Employee">
         select * from tbl_employee where id = #{id} and last_name=#{lastName}
     </select>

   @Param("id") 标注查询条件的 key,查询条件都会封装为 map。id 为 key,value 为参数所对应的值。

5、插入操作(自增主键 mysql)

<insert id="addEmp" parameterType="com.atguigu.mybatis.bean.Employee"
        useGeneratedKeys="true" keyProperty="id" databaseId="mysql">
        insert into tbl_employee(last_name,email,gender) 
        values(#{lastName},#{email},#{gender})
</insert>

    获取自增主键的值:

    mysql 支持自增主键,自增主键值的获取,mybatis 也是利用 statement.getGenreatedKeys();
    useGeneratedKeys="true";使用自增主键获取主键值策略
    keyProperty;指定对应的主键属性,也就是 mybatis 获取到主键值以后,将这个值封装给 javaBean 的哪个属性。

6、插入操作(非自增主键 oracle)

  ①非自增主键 oracle BEFORE 格式推荐 

<!-- public void addEmp(Employee employee); -->
<
insert id="addEmp" databaseId="oracle"> <selectKey keyProperty="id" order="BEFORE" resultType="Integer"> select EMPLOYEES_SEQ.nextval from dual </selectKey> insert into employees(EMPLOYEE_ID,LAST_NAME,EMAIL) values(#{id},#{lastName},#{email) </insert>

   ②非自增主键 oracle AFTER 存在并发有可能不准确,不推荐

<!-- public void addEmp(Employee employee); -->
<
insert id="addEmp" databaseId="oracle"> <selectKey keyProperty="id" order="AFTER" resultType="Integer"> select EMPLOYEES_SEQ.currval from dual </selectKey> insert into employees(EMPLOYEE_ID,LAST_NAME,EMAIL) values(#{id},#{lastName},#{email}) </insert>

   Oracle 不支持自增;Oracle 使用序列来模拟自增;每次插入的数据的主键是从序列中拿到的值;如何获取到这个值;

    使用 selectKey:

      keyProperty: 查出的主键值封装给 javaBean 的哪个属性

      order="BEFORE": 当前 sql 在插入 sql 之前运行
          AFTER:当前 sql 在插入 sql 之后运行
      resultType: 查出的数据的返回值类型