namespace:隔离SQL映射文件的,是一个SQL映射文件的唯一标识
在oracle中不支持自增用序列来获取
运行顺序:先执行查询empno自增后的值将主键值给empno,在执行插入语句
<insert id="addEmp">
<!--keyProperty="id"将获取到的主键值给id
before/after 当前sql在插入语sql之前执行 ,最好使用before,after有问题
resultType:查出数据的返回值类型
-->
<selectKey keyProperty="empno" order="BEFORE" resultType="Integer">
select empseq.nextval from dual
<!-- select empseq.currval from dual -->
</selectKey>
insert into emp (empno,ename,deptno)values(#{empno},#{ename},#{deptno})
</insert>
mysql支持自增主键值的获取statement.getGeneratedKeys() useGeneratedKeys:在标签中配置属性useGeneratedKeys=”true“;
keyProperty:将主键值获取到之后将这个值给javaBean的那个属性
keyProperty = "id“将获取到的值给id
<!--自定义某个javaBean的封装规则
type="" 自定义规则的java类型
id:唯一id方便引用
-->
<resultMap type="com.array.bean.Emp" id="MyEmp">
<!-- 指定主键列的封装规则
id:定义主键底层有优化
column:制定哪一列
property:指定对应的JavaBean属性
-->
<id column="empno" property="empno"/>
<!-- result
定义普通列规则 ,不定义会自动封装,建议将所有的封装规则都写出-->
<result column="ename" property="name"/>
</resultMap>
<resultMap type="com.array.bean.Emp" id="MyEmp2">
<id column="empno" property="empno"/>
<!-- result
定义普通列规则 ,不定义会自动封装,建议将所有的封装规则都写出-->
<result column="ename" property="name"/>
<!--association 定义关联的单个对象的定义规则
可以指定联合的javaBean对象
property 指定哪个对象是级联对象
javaType:指定属性对象的类型(不可省略)-->
<association property="dept" javaType="com.array.bean.Dept">
<id column="deptno" property="deptno"/>
<result column="dname" property="dname"/>
<result column="loc" property="loc"/>
</association>
<!--联合查询采用级联属性查询dept.deptno -->
</resultMap>
两张表的关联查询emp与dept一同被查询出来想要的状态是,当需要部门信息自己去查询出来,节约性能
在分布查询的基础上加上两个配置(加在全局中)
<setting name="lazyLoadingEnabled" value="true"/>
<setting name="aggressiveLazyLoading" value="false"/>
<!-- 鉴别器:可以判断某一列的值,然后根据某列的值去改变封装行为这里的例子有点不合逻辑只是为了使用这个标签
<discriminator javaType="" column="" javaType="" >
0:代表的性别是女生,resultType=""制定封装结果类型
<case value="0" resultType="com.array.bean.Emp">
<association property="dept" fetchType="lazy" select="com.array.dao.IdeptMapper.getDeptById" column="deptno">
</association>
</case>
如果是男生就把name赋值给部门号
<case value="1" resultType="com.array.bean.Emp">
<id column="empno" property="empno"/>
<result column="ename" property="deptno"/>
<result column="ename" property="name"/>
</case>
</discriminator>
column=""要判断那一列
javaType=""该列对应的java类型
场景:封装emp,如果封装的是女生就把信息查询出来,否则不查询
如果是男生,就把name赋值给job
-->