记录:419
场景:使用MyBatis的
版本: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)查看标签使用
以
namespace CDATA #IMPLIED
>
,表示这是一个标签元素mapper.
(..| insert*| update* | delete* | select*),表示在mapper元素中可以嵌套使用的元素清单。
,表示这是一个元素标签的支持的属性。
1.2MyBatis的使用
(1)在application.yml配置文件配置mybatis映射的xml文件位置。
mybatis:
mapper-locations: classpath*:mapper/**/*.xml
(2)创建一个Java接口。在接口中添加方法。
(3)创建一个Java接口映射的xml文件。在xml中使用
(4)在
2.使用
场景:
示例功能:示例使用
2.1Java接口
@Repository
public interface Label03ForeachMapper {
List
int insertCity(List
int insertCityUnionAll(List
int updateCity(List
int deleteCity(List
}
2.2Java接口映射的xml文件
select 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 "updateTime"
from t_city
WHERE CITY_ID IN
#{cityId}
insert into t_city_01 (CITY_ID,
CITY_NAME,
LAND_AREA,
POPULATION,
GROSS,
CITY_DESCRIBE,
DATA_YEAR,
UPDATE_TIME)
values
(#{cityPO.cityId},
#{cityPO.cityName},
#{cityPO.landArea},
#{cityPO.population},
#{cityPO.gross},
#{cityPO.cityDescribe},
#{cityPO.dataYear},
#{cityPO.updateTime})
insert into t_city_01 (CITY_ID,
CITY_NAME,
LAND_AREA,
POPULATION,
GROSS,
CITY_DESCRIBE,
DATA_YEAR,
UPDATE_TIME)
select
#{cityPO.cityId},
#{cityPO.cityName},
#{cityPO.landArea},
#{cityPO.population},
#{cityPO.gross},
#{cityPO.cityDescribe},
#{cityPO.dataYear},
#{cityPO.updateTime}
from dual
update
t_city_01
set CITY_DESCRIBE='杭州是一个发达城市'
WHERE CITY_ID IN
#{cityPO.cityId}
delete from t_city_01 where 1=1
AND CITY_ID IN
#{cityPO.cityId}
3.测试
3.1测试代码
@Slf4j
@RestController
@RequestMapping("/hub/example/cityLabel")
public class CityLabelController {
@Autowired
private Label03ForeachMapper label03ForeachMapper;
@GetMapping("/load03")
public Object load03() {
log.info("测试开始...");
// 生成查询参数
List
// 1.查询时,使用
List
// 2.1插入时,使用
label03ForeachMapper.insertCity(list01);
// 2.2插入时,使用
paraList = Arrays.asList(4L, 5L, 6L);
List
label03ForeachMapper.insertCityUnionAll(list02);
// 3.更新时,使用
label03ForeachMapper.updateCity(list01);
// 4.删除时,使用
label03ForeachMapper.deleteCity(list01);
log.info("测试结束...");
return "执行成功";
}
}
3.2测试请求
URL:http://127.0.0.1:18080/hub-example/hub/example/cityLabel/load03
3.3执行SQL
示例使用
示例一,查询时,使用
SELECT
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 "updateTime"
FROM
t_city
WHERE CITY_ID IN (?, ?, ?)
示例二,插入时,使用
INSERT INTO t_city_01 (
CITY_ID,
CITY_NAME,
LAND_AREA,
POPULATION,
GROSS,
CITY_DESCRIBE,
DATA_YEAR,
UPDATE_TIME
)
VALUES
(?, ?, ?, ?, ?, ?, ?, ?),
(?, ?, ?, ?, ?, ?, ?, ?),
(?, ?, ?, ?, ?, ?, ?, ?)
示例三,插入时,使用
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
示例四,更新时,使用
UPDATE
t_city_01
SET
CITY_DESCRIBE = '杭州是一个发达城市'
WHERE CITY_ID IN (?, ?, ?)
示例五,删除时,使用
DELETE
FROM
t_city_01
WHERE 1 = 1
AND 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 '更新时间'
) ENGINE=INNODB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='城市信息表';
以上,感谢。
2023年4月23日
相关链接
发表评论