• Spring框架(中)


    1、Bean实例化的方式:

            Spring为Bean提供了多种实例化方式,通常包括4种方式。(也就是说在Spring中为Bean对象的创建准备了多种方案,目的是:更加灵活)

    • 第一种:通过构造方法实例化
    • 第二种:通过简单工厂模式实例化
    • 第三种:通过factory-bean实例化
    • 第四种:通过FactoryBean接口实例化

    配置文件:

    1. "1.0" encoding="UTF-8"?>
    2. <beans xmlns="http://www.springframework.org/schema/beans"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
    5. <bean id="springBean" class="com.songzhishu.spring6.bean.SpringBean"/>
    6. <bean id="starBean" class="com.songzhishu.spring6.bean.StarFactory" factory-method="get"/>
    7. <bean id="gunFactoryBean" class="com.songzhishu.spring6.bean.GunFactory"/>
    8. <bean id="gunBean" factory-method="get" factory-bean="gunFactoryBean"/>
    9. <bean id="personBean" class="com.songzhishu.spring6.bean.PersonFactoryBean" />
    10. beans>

    测试的程序就不写啦,因为博客的字数太多后面写笔记的时候很卡很卡!

    1、BeanFactory和FactoryBean的区别

            BeanFactorySpring: IoC容器的顶级对象,BeanFactory被翻译为“Bean工厂”,在Spring的IoC容器中,“Bean工厂”负责创建Bean对象。BeanFactory是工厂。

            FactoryBean:它是一个Bean,是一个能够辅助Spring实例化其它Bean对象的一个Bean。

    在Spring中,Bean可以分为两类:

    • 第一类:普通Bean
    • 第二类:工厂Bean(记住:工厂Bean也是一种Bean,只不过这种Bean比较特殊,它可以辅助Spring实例化其它Bean对象。)

            FactoryBean是Spring提供的一种整合第三方框架的常用机制。和普通的bean不同,配置一个FactoryBean类型的bean,在获取bean的时候得到的并不是class属性中配置的这个类的对象,而是getObject()方法的返回值。通过这种机制,Spring可以帮我们把复杂组件创建的详细过程和繁琐细节都屏蔽起来,只把最简洁的使用界面展示给我们。

    2、bean的生命周期:

            Spring其实就是一个管理Bean对象的工厂。它负责对象的创建,对象的销毁等。所谓的生命周期就是:对象从创建开始到最终销毁的整个过程。

            通过了解生命周期可以知道在哪个时间节点上调用了哪个类的哪个方法。然后我们可以根据自己的需求在特定的节点上添加功能。

    user:

    1. package com.songzhishu.spring6.bean;
    2. public class User {
    3. private String name;
    4. public String getName() {
    5. return name;
    6. }
    7. public void setName(String name) {
    8. System.out.println("第二步:属性赋值");
    9. this.name = name;
    10. }
    11. public User() {
    12. System.out.println("第一步:创建");
    13. }
    14. public void initBean(){
    15. System.out.println("第四步:初始化bean");
    16. }
    17. public void destroyBean(){
    18. System.out.println("第七步:销毁bean");
    19. }
    20. }

     bean的后置处理器:

    1. package com.songzhishu.spring6.bean;
    2. import org.springframework.beans.BeansException;
    3. import org.springframework.beans.factory.config.BeanPostProcessor;
    4. public class BeanPost implements BeanPostProcessor {
    5. @Override
    6. public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
    7. System.out.println("第三步:执行bean后处理器的before方法");
    8. return BeanPostProcessor.super.postProcessBeforeInitialization(bean, beanName);
    9. }
    10. @Override
    11. public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
    12. System.out.println("第五步:执行bean后处理器的after方法");
    13. return BeanPostProcessor.super.postProcessAfterInitialization(bean, beanName);
    14. }
    15. }

     配置文件:

    1. "1.0" encoding="UTF-8"?>
    2. <beans xmlns="http://www.springframework.org/schema/beans"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
    5. <bean class="com.songzhishu.spring6.bean.BeanPost">bean>
    6. <bean id="userBean" class="com.songzhishu.spring6.bean.User" init-method="initBean" destroy-method="destroyBean">
    7. <property name="name" value="张胜男">property>
    8. bean>
    9. beans>

    测试类:

    1. @Test
    2. public void test5(){
    3. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("springbean.xml");
    4. User userBean = applicationContext.getBean("userBean", User.class);
    5. System.out.println("第五步:使用bean"+ userBean);
    6. //关闭spring的容器,然后才能执行销毁方法 转型的快捷指令 castvar
    7. ClassPathXmlApplicationContext context = (ClassPathXmlApplicationContext) applicationContext;
    8. context.close();
    9. }

    测试结果:

    1、Bean的作用域不同,管理方式不同

    Spring 根据Bean的作用域来选择管理方式。

    • 对于singleton作用域的Bean,Spring 能够精确地知道该Bean何时被创建,何时初始化完成,以及何时被销毁;
    • 而对于 prototype 作用域的 Bean,Spring 只负责创建,当容器创建了 Bean 的实例后,Bean 的实例就交给客户端代码管理,Spring 容器将不再跟踪其生命周期。

    2、自己new的对象如何让Spring管理

    1. @Test
    2. public void testBeanRegister(){
    3. // 自己new的对象
    4. User user = new User();
    5. System.out.println(user);
    6. // 创建 默认可列表BeanFactory 对象
    7. DefaultListableBeanFactory factory = new DefaultListableBeanFactory();
    8. // 注册Bean
    9. factory.registerSingleton("userBean", user);
    10. // 从spring容器中获取bean
    11. User userBean = factory.getBean("userBean", User.class);
    12. System.out.println(userBean);
    13. }

    3、Bean的循环依赖问题:

    A对象中有B属性。B对象中有A属性。这就是循环依赖。我依赖你,你也依赖我。

    比如:丈夫类Husband,妻子类Wife。Husband中有Wife的引用。Wife中有Husband的引用。

    1、singleton+setter的模式下产生的循环依赖:

    1. "1.0" encoding="UTF-8"?>
    2. <beans xmlns="http://www.springframework.org/schema/beans"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
    5. <bean id="husbandBean" class="com.powernode.spring6.bean.Husband" scope="singleton">
    6. <property name="name" value="张三"/>
    7. <property name="wife" ref="wifeBean"/>
    8. bean>
    9. <bean id="wifeBean" class="com.powernode.spring6.bean.Wife" scope="singleton">
    10. <property name="name" value="小花"/>
    11. <property name="husband" ref="husbandBean"/>
    12. bean>
    13. beans>

            首先要明白的是singleton是单实例,也就是说在整个Spring的容器的中的这对象是唯一的,所以在Spring容器的加载的时候就会创建bean,而不是像多实例在调用getbean的时候进行实例化,所以在创建完毕后直接进行 曝光(就是先不赋值,直接曝光,就是告诉别人我创建好啦可以使用啦),然后是调用set方法进行属性的复制!如果两个bean的scope的都是prototype,同样的代码然后执行的话,会一直创建对方的,这不就是死循环!但是一个是单实列一个是多实列的就是没问题的。

            如果使用的是构造方式来进行解决循环依赖的问题会怎么样? 然后我们参照使用setter+singleton时候是将注入分成两个部分,所以如果使用的是构造方式的话,实例化和属性赋值是在一起的,所以没有办法分开,就会导致出现和上面一样的问题!

    4、基于注解管理Bean:

            注解相当于一个标记,有这个标记的会执行相应的设置,如果没有那么就不执行!

    1、开启组件扫描:

            Spring 默认不使用注解装配 Bean,因此我们需要在 Spring 的 XML 配置中,通过 context:component-scan 元素开启 Spring Beans的自动扫描功能。开启此功能后,Spring 会自动从扫描指定的包(base-package 属性设置)及其子包下的所有类,如果类上使用了 @Component 注解,就将该类装配到容器中。

    1. "1.0" encoding="UTF-8"?>
    2. <beans xmlns="http://www.springframework.org/schema/beans"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. xmlns:context="http://www.springframework.org/schema/context"
    5. xsi:schemaLocation="http://www.springframework.org/schema/beans
    6. http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
    7. http://www.springframework.org/schema/context
    8. http://www.springframework.org/schema/context/spring-context.xsd">
    9. <context:component-scan base-package="com.atguigu.spring6">context:component-scan>
    10. beans>

            注意:在使用 context:component-scan 元素开启自动扫描功能前,首先需要在 XML 配置的一级标签 中添加 context 相关的约束。

    情况一:最基本的扫描方式

    1. <context:component-scan base-package="com.atguigu.spring6">
    2. context:component-scan>

    方法一:可以扫描多个包,不同的包用逗号分隔

    <context:component-scan base-package="com.songzhishu.spring6.bean,com.songzhishu.spring6.pojo,com.songzhishu.spring6.domain"/>
    

    方法二:找到多个包的父包,然后扫描父包,但是这跟这种方式的效率会大大的降低,所以不建议! 

    情况二:指定要排除的组件

    1. <context:component-scan base-package="com.atguigu.spring6">
    2. <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    3. context:component-scan>

     情况三:仅扫描指定组件

    1. <context:component-scan base-package="com.atguigu" use-default-filters="false">
    2. <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    3. context:component-scan>

     2、使用注解定义 Bean

    Spring 提供了以下多个注解,这些注解可以直接标注在 Java 类上,将它们定义成 Spring Bean。

    注解说明
    @Component该注解用于描述 Spring 中的 Bean,它是一个泛化的概念,仅仅表示容器中的一个组件(Bean),并且可以作用在应用的任何层次,例如 Service 层、Dao 层等。 使用时只需将该注解标注在相应类上即可。
    @Repository该注解用于将数据访问层(Dao 层)的类标识为 Spring 中的 Bean,其功能与 @Component 相同。
    @Service该注解通常作用在业务层(Service 层),用于将业务层的类标识为 Spring 中的 Bean,其功能与 @Component 相同。
    @Controller该注解通常作用在控制层(如SpringMVC 的 Controller),用于将控制层的类标识为 Spring 中的 Bean,其功能与 @Component 相同。

            实际他们的作用是一样的,只不过是我们做啦一定的规范。

    测试类:

    1. //@Component(value ="user") //相当于
    2. //@Repository //不写默认就是类名首字母小写
    3. //@Service
    4. @Controller
    5. public class User {
    6. }

    基于不同的注解,他们实现的功能是一样的,但是为了开发规范我们一般对于普通的类使用的是component的注解。

    3、使用注解完成注入:

    (1)@value:(简单类型)

            当属性的类型是简单类型时,可以使用@Value注解进行注入。可以用在属性上,然后不提供set方法也可以,然后value的注解可以写在属性上,也可以setter方法上,更可以写在构造方法的形参上!

    goods类:

    1. @Component
    2. public class Goods {
    3. @Value(value = "铅笔")
    4. private String name;
    5. @Value("20")
    6. private double price;
    7. @Override
    8. public String toString() {
    9. return "Goods{" +
    10. "name='" + name + '\'' +
    11. ", price=" + price +
    12. '}';
    13. }
    14. }

    (2)@Autowired注入:(不简单类型)

    单独使用@Autowired注解,默认根据类型装配。【默认是byType】

     controller:

    1. package com.songzhishu.autowired.controller;
    2. import com.songzhishu.autowired.service.UserService;
    3. import org.springframework.beans.factory.annotation.Autowired;
    4. import org.springframework.stereotype.Controller;
    5. import java.sql.SQLOutput;
    6. /**
    7. * @BelongsProject: Spring6
    8. * @BelongsPackage: com.songzhishu.autowired
    9. * @Author: 斗痘侠
    10. * @CreateTime: 2023-10-08 16:05
    11. * @Description: TODO
    12. * @Version: 1.0
    13. */
    14. @Controller//创建bean对象
    15. public class UserController {
    16. /*//第一种方式属性注入
    17. @Autowired //根据类型找到对应的对象完成注入
    18. private UserService userService;*/
    19. private UserService userService;
    20. //第二种方式 setter方法
    21. /*@Autowired //注解写在setter方法上
    22. public void setUserService(UserService userService) {
    23. this.userService = userService;
    24. }*/
    25. //第三种方式 构造器方式
    26. /* @Autowired //基于构造器注入
    27. public UserController(UserService userService) {
    28. this.userService = userService;
    29. }*/
    30. //第四种方式 形参上注入
    31. /*public UserController(@Autowired UserService userService) {
    32. this.userService = userService;
    33. }*/
    34. /*//第五种 特殊情况 只有一个有参构造函数 可以不加注解
    35. public UserController(UserService userService) {
    36. this.userService = userService;
    37. }*/
    38. //由@Autowired和Qualifier注解联合起来 根据名称进行匹配
    39. public UserController(UserService userService) {
    40. this.userService = userService;
    41. }
    42. public void add(){
    43. System.out.println("controller");
    44. userService.add();
    45. }
    46. }

     Service:(实现类)

    1. package com.songzhishu.autowired.service;
    2. import com.songzhishu.User;
    3. import com.songzhishu.autowired.dao.UserDao;
    4. import com.songzhishu.autowired.dao.UserDaoImpl;
    5. import com.songzhishu.autowired.dao.UserRedisDaoImpl;
    6. import org.springframework.beans.factory.annotation.Autowired;
    7. import org.springframework.beans.factory.annotation.Qualifier;
    8. import org.springframework.stereotype.Service;
    9. /**
    10. * @BelongsProject: Spring6
    11. * @BelongsPackage: com.songzhishu.autowired.service
    12. * @Author: 斗痘侠
    13. * @CreateTime: 2023-10-08 16:07
    14. * @Description: TODO
    15. * @Version: 1.0
    16. */
    17. @Service
    18. public class UserServiceImpl implements UserService {
    19. /*@Autowired//属性注入
    20. private UserDao userDao;*/
    21. @Autowired //自动注入
    22. @Qualifier(value = "userRedisDaoImpl")//名字---id
    23. private UserDao userDao;
    24. /*@Autowired //setter
    25. public void setUserDao(UserDao userDao) {
    26. this.userDao = userDao;
    27. }*/
    28. /*@Autowired
    29. public UserServiceImpl(UserDao userDao) {
    30. this.userDao = userDao;
    31. }*/
    32. /*public UserServiceImpl(@Autowired UserDao userDao) {
    33. this.userDao = userDao;
    34. }*/
    35. //当一个类型有多个bean的时候只依赖类型的话是完成不了注入的 使用两个是注解完成注入
    36. /*public UserServiceImpl(UserDao userDao) {
    37. this.userDao = userDao;
    38. }*/
    39. @Override
    40. public void add() {
    41. System.out.println("service");
    42. userDao.add();
    43. }
    44. }

     dao:

    1. package com.songzhishu.autowired.dao;
    2. import org.springframework.stereotype.Controller;
    3. import org.springframework.stereotype.Repository;
    4. /**
    5. * @BelongsProject: Spring6
    6. * @BelongsPackage: com.songzhishu.autowired.dao
    7. * @Author: 斗痘侠
    8. * @CreateTime: 2023-10-08 16:07
    9. * @Description: TODO
    10. * @Version: 1.0
    11. */
    12. @Repository
    13. public class UserDaoImpl implements UserDao{
    14. @Override
    15. public void add() {
    16. System.out.println("dao");
    17. }
    18. }
    1. package com.songzhishu.autowired.dao;
    2. import org.springframework.stereotype.Repository;
    3. /**
    4. * @BelongsProject: Spring6
    5. * @BelongsPackage: com.songzhishu.autowired.dao
    6. * @Author: 斗痘侠
    7. * @CreateTime: 2023-10-08 16:47
    8. * @Description: TODO
    9. * @Version: 1.0
    10. */
    11. @Repository
    12. public class UserRedisDaoImpl implements UserDao{
    13. @Override
    14. public void add() {
    15. System.out.println("redis...dao");
    16. }
    17. }

    总结

    • @Autowired注解可以出现在:属性上、构造方法上、构造方法的参数上、setter方法上。

    • 当带参数的构造方法只有一个,@Autowired注解可以省略。()

    • @Autowired注解默认根据类型注入。如果要根据名称注入的话,需要配合@Qualifier注解一起使用。(为了解决一个类型有多个bean的情况)

    (3)@Resource注入:

    @Resource注解也可以完成属性注入。那它和@Autowired注解有什么区别?

    • @Resource注解是JDK扩展包中的,也就是说属于JDK的一部分。所以该注解是标准注解,更加具有通用性。(JSR-250标准中制定的注解类型。JSR是Java规范提案。)

    • @Autowired注解是Spring框架自己的。

    • @Resource注解默认根据名称装配byName,未指定name时,使用属性名作为name。通过name找不到的话会自动启动通过类型byType装配。

    • @Autowired注解默认根据类型装配byType,如果想根据名称装配,需要配合@Qualifier注解一起用。

    • @Resource注解用在属性上、setter方法上。

    • @Autowired注解用在属性上、setter方法上、构造方法上、构造方法参数上。

    @Resource注解属于JDK扩展包,所以不在JDK当中,需要额外引入以下依赖:【如果是JDK8的话不需要额外引入依赖。高于JDK11或低于JDK8需要引入以下依赖。

    1. <dependency>
    2. <groupId>jakarta.annotationgroupId>
    3. <artifactId>jakarta.annotation-apiartifactId>
    4. <version>2.1.1version>
    5. dependency>

    @Resource注解:默认byName注入,没有指定name时把属性名当做name,根据name找不到时,才会byType注入。byType注入时,某种类型的Bean只能有一个。

    (4)Spring全注解开发:

            所谓的全注解开发就是不再使用spring配置文件了。写一个配置类来代替配置文件。

    配置类:

    1. import org.springframework.context.annotation.ComponentScan;
    2. import org.springframework.context.annotation.Configuration;
    3. @Configuration
    4. //扫描多个包
    5. //@ComponentScan({"com.atguigu.spring6.controller", "com.atguigu.spring6.service","com.atguigu.spring6.dao"})
    6. @ComponentScan("com.atguigu.spring6")
    7. public class Spring6Config {
    8. }

     不再new ClassPathXmlApplicationContext()对象了。

    1. @Test
    2. public void testNoXml(){
    3. ApplicationContext applicationContext = new AnnotationConfigApplicationContext(Spring6Configuration.class);
    4. UserService userService = applicationContext.getBean("userService", UserService.class);
    5. userService.save();
    6. }

    5、jdbcTemplate:

            JdbcTemplate是Spring提供的一个JDBC模板类,是对JDBC的封装,简化JDBC代码。

    也可以让Spring集成其它的ORM框架,例如:MyBatis、Hibernate等。

    1. package com.songzhishu.spring6.test;
    2. import com.songzhishu.spring6.bean.User;
    3. import org.junit.jupiter.api.Test;
    4. import org.springframework.context.ApplicationContext;
    5. import org.springframework.context.support.ClassPathXmlApplicationContext;
    6. import org.springframework.jdbc.core.BeanPropertyRowMapper;
    7. import org.springframework.jdbc.core.JdbcTemplate;
    8. import java.util.ArrayList;
    9. import java.util.Arrays;
    10. import java.util.Collections;
    11. import java.util.List;
    12. /**
    13. * @BelongsProject: Spring6
    14. * @BelongsPackage: com.songzhishu.spring6.test
    15. * @Author: 斗痘侠
    16. * @CreateTime: 2023-10-16 22:03
    17. * @Description: TODO
    18. * @Version: 1.0
    19. */
    20. public class TestJdbcTemplate {
    21. @Test
    22. public void test(){
    23. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    24. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    25. System.out.println(jdbcTemplate);
    26. }
    27. //添加
    28. @Test
    29. public void test1(){
    30. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    31. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    32. //添加
    33. String sql ="insert into t_user(real_name,age) values (?,?)";
    34. /*只要是在jdbcTemplate中,增删改都是 调用update方法*/
    35. int count = jdbcTemplate.update(sql, "赵六", 26);
    36. System.out.println(count);
    37. }
    38. //修改
    39. @Test
    40. public void test2(){
    41. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    42. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    43. String sql="update t_user set real_name =? ,age=? where id=?";
    44. int count = jdbcTemplate.update(sql, "张三丰", 103, 1);
    45. System.out.println(count);
    46. }
    47. //删除
    48. @Test
    49. public void test3(){
    50. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    51. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    52. String sql = "delete from t_user where id=?";
    53. int count = jdbcTemplate.update(sql, 5);
    54. System.out.println(count);
    55. }
    56. //查找一个
    57. @Test
    58. public void test4(){
    59. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    60. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    61. String sql="select * from t_user where id=?";
    62. User user = jdbcTemplate.queryForObject(sql, new BeanPropertyRowMapper<>(User.class), 1);
    63. System.out.println(user);
    64. }
    65. //查找所有
    66. @Test
    67. public void test5(){
    68. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    69. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    70. String sql="select * from t_user ";
    71. List query = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(User.class));
    72. query.forEach(System.out::println);
    73. }
    74. //查总数
    75. @Test
    76. public void test6(){
    77. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    78. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    79. String sql="select count(*) from t_user ";
    80. Integer integer = jdbcTemplate.queryForObject(sql, Integer.class);
    81. System.out.println(integer);
    82. }
    83. //查特定值
    84. @Test
    85. public void test7(){
    86. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    87. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    88. String sql="select real_name from t_user where id=?";
    89. String name = jdbcTemplate.queryForObject(sql, String.class, 2);
    90. System.out.println(name);
    91. }
    92. //批量添加
    93. @Test
    94. public void test8(){
    95. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    96. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    97. String sql ="insert into t_user(real_name,age) values (?,?)";
    98. List userList=new ArrayList<>();
    99. Object[] user1={"小医仙",23};
    100. Object[] user2={"美杜莎",25};
    101. Object[] user3={"赵灵儿",26};
    102. Collections.addAll(userList,user1,user2,user3);
    103. int[] ints = jdbcTemplate.batchUpdate(sql, userList);
    104. System.out.println(Arrays.toString(ints));
    105. }
    106. //批量删除
    107. @Test
    108. public void test9(){
    109. ApplicationContext applicationContext=new ClassPathXmlApplicationContext("spring.xml");
    110. JdbcTemplate jdbcTemplate = applicationContext.getBean("jdbcTemplate", JdbcTemplate.class);
    111. String sql ="delete from t_user where id=?";
    112. List userList=new ArrayList<>();
    113. Object[] user1={12};
    114. Object[] user2={13};
    115. Object[] user3={14};
    116. Object[] user4={15};
    117. Collections.addAll(userList,user1,user2,user3,user4);
    118. int[] ints = jdbcTemplate.batchUpdate(sql, userList);
    119. System.out.println(Arrays.toString(ints));
    120. }
    121. }

  • 相关阅读:
    【Kubernetes部署】通过Kubeadm部署Kubernetes高可用集群
    软件测试什么样的技术才能拿20K薪资?
    系统设计 - 我们如何通俗的理解那些技术的运行原理 - 第一部分:通信协议(1)
    SpringMvc请求流程源码解析
    AI学习指南数学工具篇-PCA基础知识
    【数据架构】什么是运营报告?
    Spring Boot : ORM 框架 JPA 与连接池 Hikari
    【智能可视化---01】揭示Python AI中Matplotlib的魅力,提升数据洞察力!探索AI 中的Matplotlib,这一篇就够了!
    使用并查集解决的相关问题
    ucore实验二
  • 原文地址:https://blog.csdn.net/keleID/article/details/133678923