一、动态SQL主要使用以下标签:
1、if判断
2、choose(when otherwise):
分支选择;带了break的swtich-case
如果带了id就用id查,如果带了lastName就用lastName查;只会进入其中一个。3、trim 字符串截取(where(封装查询条件), set(封装修改条件))
4、foreach 遍历集合
二、案列
1、<where if结合>
说明:如果where 后面紧跟着and,<where>标签会自动去掉紧跟在后面的第一个and。
2、
3、
4、
update tbl_employee where id=#{id} last_name=#{lastName}, email=#{email}, gender=#{gender}
5、
6、
employee_id,last_name,email last_name,email,gender,d_id
insert into tbl_employee( ) values (#{emp.lastName},#{emp.email},#{emp.gender},#{emp.dept.id})
7、
insert into tbl_employee(last_name,email,gender,d_id) values(#{emp.lastName},#{emp.email},#{emp.gender},#{emp.dept.id})
说明:separator:分隔符。foreach中间的语句使用“;”分隔。
8、Oracle数据库批量保存:
Oracle不支持values(),(),()
Oracle支持的批量方式
1、多个insert放在begin - end里面 begin insert into employees(employee_id,last_name,email) values(employees_seq.nextval,'test_001','test_001@atguigu.com'); insert into employees(employee_id,last_name,email) values(employees_seq.nextval,'test_002','test_002@atguigu.com'); end; 2、利用中间表: insert into employees(employee_id,last_name,email) select employees_seq.nextval,lastName,email from( select 'test_a_01' lastName,'test_a_e01' email from dual union select 'test_a_02' lastName,'test_a_e02' email from dual union select 'test_a_03' lastName,'test_a_e03' email from dual )insert into employees( ) select #{emp.lastName} lastName,#{emp.email} email from dual
9、Mybatis两个内置参数
_parameter:代表整个参数
单个参数:_parameter就是这个参数
多个参数:参数会被封装为一个map;_parameter就是代表这个map_databaseId:如果配置了databaseIdProvider标签。
_databaseId就是代表当前数据库的别名oracle
bind:可以将OGNL表达式的值绑定到一个变量中,方便后来引用这个变量的值 10、抽取可重用的sql片段。方便后面引用
1、sql抽取:经常将要查询的列名,或者插入用的列名抽取出来方便引用
2、include来引用已经抽取的sql: 3、include还可以自定义一些property,sql标签内部就能使用自定义的属性 include-property:取值的正确方式${prop}, #{不能使用这种方式}
employee_id,last_name,email last_name,email,gender,d_id