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: 查出的数据的返回值类型