<!-- 查询学生,根据id -->
<select id="getStudent" parameterType="String" resultMap="studentResultMap">
SELECT ST.STUDENT_ID,
ST.STUDENT_NAME,
ST.STUDENT_SEX,
ST.STUDENT_BIRTHDAY,
ST.CLASS_ID
FROM STUDENT_TBL ST
WHERE ST.STUDENT_ID = #{studentID}
</select>
|
属性
|
描述
|
取值
|
默认
|
|
id
|
在这个模式下唯一的标识符,可被其它语句引用
|
|
|
|
parameterType
|
传给此语句的参数的完整类名或别名
|
|
|
|
resultType
|
语句返回值类型的整类名或别名。注意,如果是集合,那么这里填写的是集合的项的整类名或别名,而不是集合本身的类名。(resultType 与resultMap 不能并用)
|
|
|
|
resultMap
|
引用的外部resultMap 名。结果集映射是MyBatis 中最强大的特性。许多复杂的映射都可以轻松解决。(resultType 与resultMap 不能并用)
|
|
|
|
flushCache
|
如果设为true,则会在每次语句调用的时候就会清空缓存。select 语句默认设为false
|
true|false
|
false
|
|
useCache
|
如果设为true,则语句的结果集将被缓存。select 语句默认设为false true|false false
timeout 设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定
|
true|false
|
false
|
|
timeout
|
设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定
|
正整数
|
未设置
|
|
fetchSize
|
设置一个值后,驱动器会在结果集数目达到此数值后,激发返回,默认为不设值,由驱动器自己决定
|
正整数
|
驱动器决定
|
|
statementType
|
statement,preparedstatement,callablestatement。
预准备语句、可调用语句
|
STATEMENT
PREPARED
CALLABLE
|
PREPARED
|
|
resultSetType
|
forward_only,scroll_sensitive,scroll_insensitive
只转发,滚动敏感,不区分大小写的滚动
|
FORWARD_ONLY
SCROLL_SENSITIVE
SCROLL_INSENSITIVE
|
驱动器决定
|
<!-- 插入学生 -->
<insert id="insertStudent" parameterType="StudentEntity">
INSERT INTO STUDENT_TBL (STUDENT_ID,
STUDENT_NAME,
STUDENT_SEX,
STUDENT_BIRTHDAY,
CLASS_ID)
VALUES (#{studentID},
#{studentName},
#{studentSex},
#{studentBirthday},
#{classEntityclassID})
</insert>
<!-- 插入学生 自动主键-->
<insert id="insertStudentAutoKey" parameterType="StudentEntity">
<selectKey keyProperty="studentID" resultType="String" order="BEFORE">
select nextval('student')
</selectKey>
INSERT INTO STUDENT_TBL (STUDENT_ID,
STUDENT_NAME,
STUDENT_SEX,
STUDENT_BIRTHDAY,
CLASS_ID)
VALUES (#{studentID},
#{studentName},
#{studentSex},
#{studentBirthday},
#{classEntityclassID})
</insert>
|
属性
|
描述
|
取值
|
默认
|
|
id
|
在这个模式下唯一的标识符,可被其它语句引用
|
|
|
|
parameterType
|
传给此语句的参数的完整类名或别名
|
|
|
|
flushCache
|
如果设为true,则会在每次语句调用的时候就会清空缓存。select 语句默认设为false
|
true|false
|
false
|
|
useCache
|
如果设为true,则语句的结果集将被缓存。select 语句默认设为false true|false false
timeout 设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定
|
true|false
|
false
|
|
timeout
|
设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定
|
正整数
|
未设置
|
|
fetchSize
|
设置一个值后,驱动器会在结果集数目达到此数值后,激发返回,默认为不设值,由驱动器自己决定
|
正整数
|
驱动器决定
|
|
statementType
|
statement,preparedstatement,callablestatement。
预准备语句、可调用语句
|
STATEMENT
PREPARED
CALLABLE
|
PREPARED
|
|
useGeneratedKeys
|
告诉MyBatis 使用JDBC 的getGeneratedKeys 方法来获取数据库自己生成的主键(MySQL、SQLSERVER 等
关系型数据库会有自动生成的字段)。默认:false
|
true|false
|
false
|
|
keyProperty
|
标识一个将要被MyBatis 设置进getGeneratedKeys 的key 所返回的值,或者为insert 语句使用一个selectKey
子元素。
|
|
|
属性
|
描述
|
取值
|
|
keyProperty
|
selectKey 语句生成结果需要设置的属性。
|
|
|
resultType
|
生成结果类型,MyBatis 允许使用基本的数据类型,包括String 、int类型。
|
|
|
order
|
可以设成BEFORE 或者AFTER,如果设为BEFORE,那它会先选择主键,然后设置keyProperty,再执行insert语句;如果设为AFTER,它就先运行insert 语句再运行selectKey 语句,通常是insert 语句中内部调用数据库(像Oracle)内嵌的序列机制。
|
BEFORE
AFTER
|
|
statementType
|
像上面的那样, MyBatis 支持STATEMENT,PREPARED和CALLABLE 的语句形式, 对应Statement ,PreparedStatement 和CallableStatement 响应
|
STATEMENT
PREPARED
CALLABLE
|
<!-- 更新学生信息 -->
<update id="updateStudent" parameterType="StudentEntity">
UPDATE STUDENT_TBL
SET STUDENT_TBL.STUDENT_NAME = #{studentName},
STUDENT_TBL.STUDENT_SEX = #{studentSex},
STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday},
STUDENT_TBL.CLASS_ID = #{classEntity.classID}
WHERE STUDENT_TBL.STUDENT_ID = #{studentID};
</update>
<!-- 删除学生 -->
<delete id="deleteStudent" parameterType="StudentEntity">
DELETE FROM STUDENT_TBL WHERE STUDENT_ID = #{studentID}
</delete>
|
属性
|
描述
|
取值
|
默认
|
|
id
|
在这个模式下唯一的标识符,可被其它语句引用
|
|
|
|
parameterType
|
传给此语句的参数的完整类名或别名
|
|
|
|
flushCache
|
如果设为true,则会在每次语句调用的时候就会清空缓存。select 语句默认设为false
|
true|false
|
false
|
|
useCache
|
如果设为true,则语句的结果集将被缓存。select 语句默认设为false true|false false
timeout 设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定
|
true|false
|
false
|
|
timeout
|
设置驱动器在抛出异常前等待回应的最长时间,默认为不设值,由驱动器自己决定
|
正整数
|
未设置
|
|
fetchSize
|
设置一个值后,驱动器会在结果集数目达到此数值后,激发返回,默认为不设值,由驱动器自己决定
|
正整数
|
驱动器决定
|
|
statementType
|
statement,preparedstatement,callablestatement。
预准备语句、可调用语句
|
STATEMENT
PREPARED
CALLABLE
|
PREPARED
|
<!-- 复用sql语句 查询student表所有字段 -->
<sql id="selectStudentAll">
SELECT ST.STUDENT_ID,
ST.STUDENT_NAME,
ST.STUDENT_SEX,
ST.STUDENT_BIRTHDAY,
ST.CLASS_ID
FROM STUDENT_TBL ST
</sql>
<!-- 查询学生,根据id -->
<select id="getStudent" parameterType="String" resultMap="studentResultMap">
<include refid="selectStudentAll"/>
WHERE ST.STUDENT_ID = #{studentID}
</select>
<!-- 查询学生list,根据入学时间 -->
<select id="getStudentListByDate" parameterType="Date" resultMap="studentResultMap">
SELECT *
FROM STUDENT_TBL ST LEFT JOIN CLASS_TBL CT ON ST.CLASS_ID = CT.CLASS_ID
WHERE CT.CLASS_YEAR = #{classYear};
</select>
List<StudentEntity> studentList = studentMapper.getStudentListByClassYear(StringUtil.parse("2007-9-1"));
for (StudentEntity entityTemp : studentList) {
System.out.println(entityTemp.toString());
}
<!-- 查询学生list,like姓名、=性别,参数entity类型 -->
<select id="getStudentListWhereEntity" parameterType="StudentEntity" resultMap="studentResultMap">
SELECT * from STUDENT_TBL ST
WHERE ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%')
AND ST.STUDENT_SEX = #{studentSex}
</select>
StudentEntity entity = new StudentEntity();
entity.setStudentName("李");
entity.setStudentSex("男");
List<StudentEntity> studentList = studentMapper.getStudentListWhereEntity(entity);
for (StudentEntity entityTemp : studentList) {
System.out.println(entityTemp.toString());
}
<!-- 查询学生list,=性别,参数map类型 -->
<select id="getStudentListWhereMap" parameterType="Map" resultMap="studentResultMap">
SELECT * from STUDENT_TBL ST
WHERE ST.STUDENT_SEX = #{sex}
AND ST.STUDENT_SEX = #{sex}
</select>
Map<String, String> map = new HashMap<String, String>();
map.put("sex", "女");
map.put("name", "李");
List<StudentEntity> studentList = studentMapper.getStudentListWhereMap(map);
for (StudentEntity entityTemp : studentList) {
System.out.println(entityTemp.toString());
}
<!-- 查询学生list,like姓名、=性别、=生日、=班级,多参数方式 -->
<select id="getStudentListWhereParam" resultMap="studentResultMap">
SELECT * from STUDENT_TBL ST
<where>
<if test="name!=null and name!='' ">
ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{name}),'%')
</if>
<if test="sex!= null and sex!= '' ">
AND ST.STUDENT_SEX = #{sex}
</if>
<if test="birthday!=null">
AND ST.STUDENT_BIRTHDAY = #{birthday}
</if>
<if test="classEntity!=null and classEntityclassID !=null and classEntityclassID!='' ">
AND ST.CLASS_ID = #{classEntity.classID}
</if>
</where>
</select>
List<StudentEntity> studentList = studentMapper.getStudentListWhereParam("", "",StringUtil.parse("1985-05-28"), classMapper.getClassByID("20000002"));
for (StudentEntity entityTemp : studentList) {
System.out.println(entityTemp.toString());
}
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"> </cache>
<cache-ref namespace="com.liming.manager.data.StudentMapper"/>
|
属性
|
说明
|
取值
|
默认值
|
|
eviction
|
缓存策略:
LRU - 最近最少使用法:移出最近较长周期内都没有被使用的对象。
FIFI- 先进先出:移出队列里较早的对象
SOFT - 软引用:基于软引用规则,使用垃圾回收机制来移出对象
WEAK - 弱引用:基于弱引用规则,使用垃圾回收机制来强制性地移出对象
|
LRU
FIFI
SOFT
WEAK
|
LRU
|
|
flushInterval
|
代表一个合理的毫秒总计时间。默认是不设置,因此使用无间隔清空即只能调用语句来清空。
|
正整数
|
不设置
|
|
size
|
缓存的对象的大小
|
正整数
|
1024
|
|
readOnly
|
只读缓存将对所有调用者返回同一个实例。因此都不能被修改,这可以极大的提高性能。可写的缓存将通过序列
化来返回一个缓存对象的拷贝。这会比较慢,但是比较安全。所以默认值是false。
|
true|false
|
false
|
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有