Mybatis智能标签
一、ProviderDao层
//智能标签案例
//智能标签多条件查询
public List<Provider> providerTest(@Param("proCode") String proCode, @Param("proName") String proName);
//智能标签进行修改
public int updatePro(Provider provider);
//查询范围(数组)
public List<Provider> getProInData(String [] proCodes);
//查询范围(集合)
public List<Provider> getProList(List<String> list);
//查询范围(多个集合)
public List<Provider> getProObject(@Param("proCodeList") List<Provider> proCodeList,@Param("proNameList") List<Provider> proNameList);
二、ProviderDao.xml小配置文件
<!--智能标签案例-->
<!--智能标签多条件查询-->
<select id="providerTest" resultType="com.marketsys.entity.Provider">
select * from smbms.smbms_provider
<where>
<if test="proCode!=null and proCode!=''">
and proCode like concat ('%',#{proCode},'%')
</if>
<if test="proName!=null and proName!=''">
and proName like concat ('%',#{proName},'%')
</if>
</where>
</select>
<!--智能标签进行修改-->
<update id="updatePro">
update smbms_provider
<trim prefix="SET" suffixOverrides=",">
<!--<set>-->
<if test="proCode!=null and proCode!=''">
proCode=#{proCode},
</if>
<if test="proName!=null and proName!=''">
proName=#{proName},
</if>
<!--</set>-->
</trim>
where id=#{id}
</update>
<!--查询范围(数组)-->
<select id="getProInData" resultType="com.marketsys.entity.Provider">
<!--select * from smbms.smbms_provider where proCode in ( ? , ? )-->
select * from smbms.smbms_provider where proCode in
<!--colletion 代表参数类型 open代表开头 close代表结尾 separator每一项数据分隔符 item代表每一项-->
<foreach collection="array" open="(" close=")" separator="," item="proCode">
#{proCode}
</foreach>
</select>
<!--查询范围(集合)-->
<select id="getProList" resultType="com.marketsys.entity.Provider">
select * from smbms.smbms_provider
<if test="list.size>0">
where proCode in
<!--colletion 代表参数类型 open代表开头 close代表结尾 separator每一项数据分隔符 item代表每一项-->
<foreach collection="list" open="(" close=")" separator="," item="proCode">
#{proCode}
</foreach>
</if>
</select>
<!--查询范围(多个集合)-->
<select id="getProObject" resultType="com.marketsys.entity.Provider">
select * from smbms.smbms_provider where proCode in
<!--colletion 代表参数类型 open代表开头 close代表结尾 separator每一项数据分隔符 item代表每一项-->
<foreach collection="proCodeList" open="(" close=")" separator="," item="proCode">
#{proCode.proCode}
</foreach>
and proName in
<foreach collection="proNameList" open="(" close=")" separator="," item="proName">
#{proName.proName}
</foreach>
</select>
三、test类
public class providerTest {
SqlSession sqlSession=MybatisUtil.getSqlSession();
ProviderDao mapper = sqlSession.getMapper(ProviderDao.class);
//智能标签多条件查询
@Test
public void getAllPro(){
List<Provider> providers = mapper.providerTest("GZ", "深圳");
for (Provider pro:providers) {
System.out.println(pro.getProName());
}
}
//智能标签进行修改
@Test
public void updatePro(){
Provider provider=new Provider();
provider.setId(10);
provider.setProCode("JS_GYS012");
provider.setProName("小南京火头军信息技术有限公司");
int count=mapper.updatePro(provider);
sqlSession.commit();
System.out.println(count);
}
//查询范围(数组)
@Test
public void getInPro(){
List<Provider> providers = mapper.getProInData(new String[]{"BJ_GYS001","BJ_GYS002"});
for (Provider pro:providers) {
System.out.println(pro.getProName());
}
}
//查询范围(集合)
@Test
public void getProList(){
List<String> list=new ArrayList<>();
list.add("BJ_GYS002");
list.add("BJ_GYS001");
List<Provider> providerData=mapper.getProList(list);
for (Provider pro:providerData) {
System.out.println(pro.getProName());
}
}
//查询范围(多个集合)
@Test
public void getProObject(){
List<Provider> list =new ArrayList<Provider>();
Provider provider=new Provider();
provider.setProCode("BJ_GYS002");
list.add(provider);
List<Provider> list2 =new ArrayList<Provider>();
Provider provider2=new Provider();
provider2.setProName("北京纳福尔食用油有限公司");
list2.add(provider2);
List<Provider> providerData=mapper.getProObject(list,list2);
for (Provider pro:providerData) {
System.out.println(pro.getProName());
}
}
}
Mybatis智能标签的更多相关文章
- MyBatis 智能标签
使用Where 只能标签 检索部门Y2162Dept 数据库已存在表Y2162Dept 实现动态查询 Deptno Deptname 赋值 不赋值 不赋值 赋值 赋值 赋值 不赋值 不赋值 <! ...
- MyBatis智能标签!
if 语句 <select id="getOne" resultType="com.mybatis.entity.SmbmsProviderEntity" ...
- MyBatis的一系列问题的处理(遍历Map集合和智能标签和属性和字段不一样的解决办法 和sql片段)(三)
一.字段名与属性名(数据库的名字)不一样怎么办? 方案一:在小配置中配置一个resultMapper <!--方案一:resultMapper 字段名与属性名不一致 --> <res ...
- mybatis高级(2)_数据库中的列和实体类不匹配时的两种解决方法_模糊查询_智能标签
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "- ...
- MyBatis系列四 之 智能标签进行查询语句的拼接
MyBatis系列四 之 智能标签进行查询语句的拼接 使用Foreach进行多条件查询 1.1 foreach使用数组进行多条件查询 在MyBatis的映射文件中进行如下配置 <!--根据数组进 ...
- SSM-MyBatis-14:Mybatis中智能标签
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 谈论到智能,有什么要想的没有? 我下面放张图 相信都见过这个吧,你在之前没有学习过框架的时候怎么写的,动态sq ...
- 【Java EE 学习 79 下】【动态SQL】【mybatis和spring的整合】
一.动态SQL 什么是动态SQL,就是在不同的条件下,sql语句不相同的意思,曾经在“酒店会员管理系统”中写过大量的多条件查询,那是在SSH的环境中,所以只能在代码中进行判断,以下是其中一个多条件查询 ...
- MyBatis初学者配置
小配置 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC &qu ...
- mybatis大框架
MyBatis 开源的数据持久化层框架 实体类与SQL语句之间建立映射关系 一:MyBatis前身是IBatis,本是Apache的一个开源的项目, 基于SQL语法,简单易学 ,是耦合度降低,方便 ...
随机推荐
- robotframework框架 - 利用RequestsLibrary关键字轻松实现接口自动化!
robotframework(后续简称为robot)是一款自动化测试框架,可能做各种类型的自动化测试. 本文介绍通过robotframework来做接口测试. 第一步:安装第三方库,提供接口测试的关键 ...
- echarts 在 vue-awesome-swiper中无法点击
回退vue-awesome-swiper版本到2.6.7 即可npm install vue-awesome-swiper@2.6.7 --save
- 第04组 Beta冲刺(3/4)
队名:斗地组 组长博客:地址 作业博客:Beta冲刺(3/4) 各组员情况 林涛(组长) 过去两天完成了哪些任务: 1.分配展示任务 2.收集各个组员的进度 3.写博客 展示GitHub当日代码/文档 ...
- C 语言输出不同颜色字体
C 语言输出不同颜色字体 \033是8进制,它就是unix下终端转义符ESC(16进制1A,10进制27) ESC[xm 是unix下改变终端输出颜色的命令 所以,如果是红色,则我们定义为\033[0 ...
- node 升级版本
1.安装 更新node.js版本 命令 [root@node ~]# npm install -g n /home/meisapp/node/node-v6.10.0-linux-x64/bin/n ...
- 深入selenium模块基础操作
selenium模块的基本操作 一.模拟浏览器 谷歌.Firefox.Safari等浏览器 browser=webdriver.Chrome() browser=webdriver.Firefox ...
- Add an Item to the Navigation Control 将项目添加到导航控件
In this lesson, you will learn how to add an item to the navigation control. For this purpose, the N ...
- [browser navigator],写了个检测游览器版本
前些天胃不舒服打吊针了,真得准时吃饭各种啊,然后就是懒,就没在复习了,这次复习的内容是navigator //未知效果 // console.log('浏览器的次要版本' + navigator.ap ...
- [转]Workbook.SaveAs method (Excel) Password
本文转自:https://docs.microsoft.com/en-us/office/vba/api/excel.workbook.saveas Saves changes to the work ...
- JS 简介
JS 简介 JavaScript 是世界上最流行的编程语言. 这门语言可用于 HTML 和 web,更可广泛用于服务器.PC.笔记本电脑.平板电脑和智能手机等设备. avaScript 是脚本语言 J ...