mybatis的一些标签和属性

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
  		  -->





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值