SRPING02_配置数据源、原始注解开发、新注解开发、集成Junit代码实现(三)

简介: SRPING02_配置数据源、原始注解开发、新注解开发、集成Junit代码实现(三)

⑤. @Autowired:是按照数据类型从spring容器中进行匹配的


说明:


(1). 自动按照类型注入。只要有唯一类型匹配就能注入成功


(2). 如果注入的bean在容器里不唯一时,它会把变量名称作为bean的id在容器里查找,也能查找成功。如果没有找到一致的bean的id,则报错。当我们使用注解注入时,set方法就不是必须的


微信图片_20220108212845.png


⑥. @Qualifier:是按照id值从容器中进行匹配的,但是此处 @Qualifier要结合@Autowired使用


  @Autowired
  @Qualifier("fooFormatter")
  private Formatter formatter;


image.png


⑦. @Resource


找到@Resource注解以后,判断该注解name的属性是否为""(name没有写)


如果没有写name属性,则会让属性的名称的值和spring中ID的值做匹配,如果匹配成功则赋值,如果匹配不成功,则会按照类型进行匹配,如果匹配不成功,则报错


如果有name属性,则会按照name属性的值和spring的bean中ID进行匹配,匹配成功,则赋值,不成功则报错


③. Spring新注解


  • ①. Spring新注解集合


微信图片_20220108213010.png


②. 代码展示


//标志该类是Spring的核心配置类
@Configuration
/*<!--配置组件扫描-->
<context:component-scan base-package="com.xiaozhi"></context:component-scan>*/
@ComponentScan("com.xiaozhi")
/*<!--加载外部的properties文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>*/
@PropertySource("classpath:jdbc.properties")
public class SpringConfiguration {
    @Value("${jdbc.driverClassName}")
    private String driverClassName;
    @Value("${jdbc.url}")
    private String url;
    @Value("${jdbc.username}")
    private String username;
    @Value("${jdbc.password}")
    private String password;
    //Spring会将当前方法的返回值以指定名称存储到Spring容器当中
    @Bean("druidDataSource")
    public DataSource getDataSource(){
        DruidDataSource druidDataSource= new DruidDataSource();
        druidDataSource.setDriverClassName(driverClassName);
        druidDataSource.setUrl(url);
        druidDataSource.setUsername(username);
        druidDataSource.setPassword(password);
        return druidDataSource;
    }
}
    @Test
    public void test2() throws SQLException {
        ApplicationContext app=new
                AnnotationConfigApplicationContext(SpringConfiguration.class);
        DruidDataSource bean = app.getBean(DruidDataSource.class);
        System.out.println(bean.getConnection());
    }
相关文章
|
5月前
|
Java 开发工具 git
spring boot 集成 ctrip apollo 实现动态配置更新
spring boot 集成 ctrip apollo 实现动态配置更新
55 1
|
13天前
|
分布式计算 DataWorks 关系型数据库
DataWorks操作报错合集之DataWorks集成实例绑定到同一个vpc下面,也添加了RDS的IP白名单报错:数据源配置有误,请检查,该怎么处理
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
27 0
|
14天前
|
存储 分布式计算 DataWorks
MaxCompute产品使用合集之大数据计算MaxCompute dataworks可以批量修改数据集成任务的数据源配置信息吗
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
2月前
|
Devops 开发工具 数据安全/隐私保护
Docker Swarm总结+CI/CD Devops、gitlab、sonarqube以及harbor的安装集成配置(3/5)
Docker Swarm总结+CI/CD Devops、gitlab、sonarqube以及harbor的安装集成配置(3/5)
79 0
|
4月前
|
IDE 前端开发 JavaScript
【C#】C# 开发环境配置(Rider 一个.NET 跨平台集成开发环境)
【1月更文挑战第26天】【C#】C# 开发环境配置(Rider 一个.NET 跨平台集成开发环境)
|
5月前
|
安全 架构师 Java
SpringBoot【集成 jasypt】实现配置信息自定义加解密(自定义的属性探测和密码解析器)
SpringBoot【集成 jasypt】实现配置信息自定义加解密(自定义的属性探测和密码解析器)
163 0
|
5月前
|
监控 关系型数据库 Java
SpringBoot【集成 01】Druid+Dynamic+Greenplum(实际上用的是PostgreSQL的驱动)及 dbType not support 问题处理(附hikari相关配置)
SpringBoot【集成 01】Druid+Dynamic+Greenplum(实际上用的是PostgreSQL的驱动)及 dbType not support 问题处理(附hikari相关配置)
107 0
|
5月前
|
NoSQL Java API
SpringBoot【ElasticSearch集成 02】Java HTTP Rest client for ElasticSearch Jest 客户端集成(依赖+配置+增删改查测试源码)推荐使用
SpringBoot【ElasticSearch集成 02】Java HTTP Rest client for ElasticSearch Jest 客户端集成(依赖+配置+增删改查测试源码)推荐使用
61 0
|
5月前
|
Java API
SpringBoot【集成ElasticSearch 01】2种方式的高级客户端 RestHighLevelClient 使用(依赖+配置+客户端API测试源码)
SpringBoot【集成ElasticSearch 01】2种方式的高级客户端 RestHighLevelClient 使用(依赖+配置+客户端API测试源码)
91 0
|
5月前
|
SQL 前端开发 Java
Hasor【环境搭建 01】SpringBoot集成Dataway接口配置服务(依赖+配置+数据库数据源初始化+注解添加+demo验证测试)
Hasor【环境搭建 01】SpringBoot集成Dataway接口配置服务(依赖+配置+数据库数据源初始化+注解添加+demo验证测试)
85 0