当前位置: 首页 > news >正文

迁安市住房和城乡建设局网站深圳创业故事

迁安市住房和城乡建设局网站,深圳创业故事,企业网站建设的开发方式有,四川网站营销seo费用记录#xff1a;419 场景#xff1a;使用MyBatis的foreach/foreach标签的循环遍历List类型的入参。使用collection属性指定List#xff0c;item指定List中存放的对象#xff0c;separator指定分割符号#xff0c;open指定开始字符#xff0c;close指定结…记录419 场景使用MyBatis的foreach/foreach标签的循环遍历List类型的入参。使用collection属性指定Listitem指定List中存放的对象separator指定分割符号open指定开始字符close指定结束字符。 版本JDK 1.8,Spring Boot 2.6.3,mybatis-3.5.9。 1.基础知识 1.1MyBatis的标签 (1)查看MyBatis支持的标签 地址http://mybatis.org/dtd/mybatis-3-mapper.dtd (2)查看标签使用 以mapper/mapper标签元素为例在mybatis-3-mapper.dtd中如下 !ELEMENT mapper (cache-ref | cache | resultMap* | parameterMap* | sql* | insert* | update* | delete* | select* ) !ATTLIST mapper namespace CDATA #IMPLIED!ELEMENT mapper(...)表示这是一个标签元素mapper. (..| insert*| update* | delete* | select*),表示在mapper元素中可以嵌套使用的元素清单。 !ATTLIST mapper表示这是一个元素标签的支持的属性。 1.2MyBatis的使用 (1)在application.yml配置文件配置mybatis映射的xml文件位置。 mybatis:mapper-locations: classpath*:mapper/**/*.xml (2)创建一个Java接口。在接口中添加方法。 (3)创建一个Java接口映射的xml文件。在xml中使用mapper/mapper标签的namespace属性指定Java接口的全路径。Java接口和xml映射文件就完成了绑定关系。 (4)在mapper/mapper标签内使用insertupdatedeleteselect等标签的id属性指定Java的方法名称。Java接口的方法和xml映射文件的mapper/mapper内部的标签就完成了绑定关系。 2.使用foreach/foreach标签元素 场景foreach/foreach标签元素在insertupdatedeleteselect等标签元素内使用。 示例功能示例使用foreach/foreach标签在insertupdatedeleteselect标签内遍历输入的List类型入参。 2.1Java接口 Repository public interface Label03ForeachMapper {ListCityLabelPO queryCity(ListLong paraList);int insertCity(ListCityLabelPO cityList);int insertCityUnionAll(ListCityLabelPO cityList);int updateCity(ListCityLabelPO cityList);int deleteCity(ListCityLabelPO cityList); } 2.2Java接口映射的xml文件 ?xml version1.0 encodingUTF-8 ? !DOCTYPE mapper PUBLIC -//mybatis.org//DTD Mapper 3.0//EN http://mybatis.org/dtd/mybatis-3-mapper.dtd mapper namespacecom.hub.example.mapper.Label03ForeachMapper!-- 1.查询时,使用foreach/foreach标签--select idqueryCity resultTypecom.hub.example.domain.CityLabelPOselect CITY_ID AS cityId,CITY_NAME AS cityName,LAND_AREA AS landArea,POPULATION AS population,GROSS AS gross,CITY_DESCRIBE AS cityDescribe,DATA_YEAR AS dataYear,UPDATE_TIME AS updateTimefrom t_cityWHERE CITY_ID INforeach collectionlist itemcityId open( separator, close)#{cityId}/foreach/select!-- 2.1插入时,使用foreach/foreach标签,使用逗号分割--insert idinsertCity parameterTypejava.util.Listinsert into t_city_01 (CITY_ID,CITY_NAME,LAND_AREA,POPULATION,GROSS,CITY_DESCRIBE,DATA_YEAR,UPDATE_TIME)valuesforeach collectionlist itemcityPO open separator, close(#{cityPO.cityId},#{cityPO.cityName},#{cityPO.landArea},#{cityPO.population},#{cityPO.gross},#{cityPO.cityDescribe},#{cityPO.dataYear},#{cityPO.updateTime})/foreach/insert!-- 2.2插入时,使用foreach/foreach标签,使用union all分割--insert idinsertCityUnionAll parameterTypejava.util.Listinsert into t_city_01 (CITY_ID,CITY_NAME,LAND_AREA,POPULATION,GROSS,CITY_DESCRIBE,DATA_YEAR,UPDATE_TIME)foreach collectionlist itemcityPO open separatorUNION ALL closeselect#{cityPO.cityId},#{cityPO.cityName},#{cityPO.landArea},#{cityPO.population},#{cityPO.gross},#{cityPO.cityDescribe},#{cityPO.dataYear},#{cityPO.updateTime}from dual/foreach/insert!-- 3.更新时,使用foreach/foreach标签--update idupdateCity parameterTypejava.util.Listupdatet_city_01set CITY_DESCRIBE杭州是一个发达城市WHERE CITY_ID INforeach collectionlist itemcityPO open( separator, close)#{cityPO.cityId}/foreach/update!-- 4.删除时,使用foreach/foreach标签--delete iddeleteCity parameterTypejava.util.Listdelete from t_city_01 where 11if testlist.size()0AND CITY_ID INforeach collectionlist itemcityPO open( separator, close)#{cityPO.cityId}/foreach/if/delete /mapper 3.测试 3.1测试代码 Slf4j RestController RequestMapping(/hub/example/cityLabel) public class CityLabelController {Autowiredprivate Label03ForeachMapper label03ForeachMapper;GetMapping(/load03)public Object load03() {log.info(测试开始...);// 生成查询参数ListLong paraList Arrays.asList(1L, 2L, 3L);// 1.查询时,使用foreach/foreach标签ListCityLabelPO list01 label03ForeachMapper.queryCity(paraList);// 2.1插入时,使用foreach/foreach标签,使用逗号分割label03ForeachMapper.insertCity(list01);// 2.2插入时,使用foreach/foreach标签,使用union all分割paraList Arrays.asList(4L, 5L, 6L);ListCityLabelPO list02 label03ForeachMapper.queryCity(paraList);label03ForeachMapper.insertCityUnionAll(list02);// 3.更新时,使用foreach/foreach标签label03ForeachMapper.updateCity(list01);// 4.删除时,使用foreach/foreach标签label03ForeachMapper.deleteCity(list01);log.info(测试结束...);return 执行成功;} } 3.2测试请求 URLhttp://127.0.0.1:18080/hub-example/hub/example/cityLabel/load03 3.3执行SQL 示例使用foreach/foreach标签后遍历List类型入参从具体对象中取值。 示例一查询时,使用foreach/foreach标签。 SELECTCITY_ID AS cityId,CITY_NAME AS cityName,LAND_AREA AS landArea,POPULATION AS population,GROSS AS gross,CITY_DESCRIBE AS cityDescribe,DATA_YEAR AS dataYear,UPDATE_TIME AS updateTime FROMt_city WHERE CITY_ID IN (?, ?, ?) 示例二,插入时,使用foreach/foreach标签,使用逗号分割。 INSERT INTO t_city_01 (CITY_ID,CITY_NAME,LAND_AREA,POPULATION,GROSS,CITY_DESCRIBE,DATA_YEAR,UPDATE_TIME ) VALUES(?, ?, ?, ?, ?, ?, ?, ?),(?, ?, ?, ?, ?, ?, ?, ?),(?, ?, ?, ?, ?, ?, ?, ?) 示例三,插入时,使用foreach/foreach标签,使用union all分割。 INSERT INTO t_city_01 (CITY_ID, CITY_NAME, LAND_AREA, POPULATION, GROSS, CITY_DESCRIBE, DATA_YEAR, UPDATE_TIME) SELECT ?, ?, ?, ?, ?, ?, ?, ? FROM DUAL UNION ALL SELECT ?, ?, ?, ?, ?, ?, ?, ? FROM DUAL UNION ALL SELECT ?, ?, ?, ?, ?, ?, ?, ? FROM DUAL 示例四,更新时,使用foreach/foreach标签。 UPDATEt_city_01 SETCITY_DESCRIBE 杭州是一个发达城市 WHERE CITY_ID IN (?, ?, ?) 示例五,删除时,使用foreach/foreach标签。 DELETE FROMt_city_01 WHERE 1 1AND CITY_ID IN (?, ?, ?) 4.支撑 4.1实体对象 (1)封装结果对象CityLabelPO Data Builder NoArgsConstructor AllArgsConstructor public class CityLabelPO {private Long cityId;private String cityName;private Double landArea;private Long population;private Double gross;private String cityDescribe;private String dataYear;private Date updateTime; } 4.2建表语句 CREATE TABLE t_city (CITY_ID BIGINT(16) NOT NULL COMMENT 唯一标识,CITY_NAME VARCHAR(64) COLLATE utf8_bin NOT NULL COMMENT 城市名,LAND_AREA DOUBLE DEFAULT NULL COMMENT 城市面积,POPULATION BIGINT(16) DEFAULT NULL COMMENT 城市人口,GROSS DOUBLE DEFAULT NULL COMMENT 生产总值,CITY_DESCRIBE VARCHAR(512) COLLATE utf8_bin DEFAULT NULL COMMENT 城市描述,DATA_YEAR VARCHAR(16) COLLATE utf8_bin DEFAULT NULL COMMENT 数据年份,UPDATE_TIME DATETIME DEFAULT NULL COMMENT 更新时间 ) ENGINEINNODB DEFAULT CHARSETutf8 COLLATEutf8_bin COMMENT城市信息表; 以上感谢。 2023年4月23日
http://www.sczhlp.com/news/188902/

相关文章:

  • 网站制作需要网站制作免费做英文网站
  • 设计公司网站页面设计龙岩兼职
  • 网站建设哪里比较好wordpress缩略图裁剪
  • 外贸推广免费网站如何自己制作微网站
  • 安贞做网站公司遵义网站建设方案
  • 建设电子商务网站的花费小程序是做什么的
  • 万网虚拟云空间怎么建设网站编程培训费用
  • 中国五码一级做爰网站电子商务设计网站建设
  • 与狗狗做网站如何选择网站开发语言
  • 朝阳免费网站制作深圳专业的网站制作公司
  • 中国门户网站seo资料站
  • 泰兴城乡建设局网站今天晚上19点新闻联播直播回放
  • 网站每年费用做外贸现在一般都通过哪些网站
  • 提供常州微信网站建设网站建设需要的技能有哪些
  • 门户网站个人可以做wordpress默认模版在哪
  • 专业的顺的网站建设如何做自适应网站
  • 网站漂浮二维码淘客插件wordpress
  • 最优的锦州网站建设网站如何绑定域名
  • 网站备案迁移网站改版什么意思
  • 珠海建站联系方式做网站效果图
  • 移动建站平台有哪些上海松江做网站公司
  • 如何将百度云做成网站文件服务器网站建设具体工作总结
  • 论坛网站建设规划书大型软件公司有哪些
  • 中国做网站的公司牛商网
  • 建站服务外贸网站建设购买
  • 酒水食品做的好网站网站备案查询是什么意思
  • 饭店网站模板wordpress 分享文章标题
  • 茶网站建设需要多少钱安徽省级建设主管部门网站
  • 湖南网络营销深圳网站优化最好的方法
  • 浙江网站推广公司nginx网站301重定向怎么做