本文介绍: 上面的示例中,@Qualifier注解用于指定需要注入的Bean的名称为“userServiceImpl”。需要注意的是,@Qualifier注解通常与@Autowired或@Inject注解一起使用,用于在多个匹配的Bean中进行选择。当容器中有多个类型相同的Bean时,可以使用@Qualifier注解来指定需要注入的Bean。如果没有指定@Qualifier注解,Spring框架将使用默认的自动装配策略,即按照类型进行匹配。因此,使用@Qualifier注解可以有效地解决这个问题。

1.@Qualifier:通常与@Autowired搭配使用,通过指定具体的beanName来注入相应的bean

当容器中有多个类型相同的Bean时,可以使用@Qualifier注解来指定需要注入的Bean。@Qualifier注解可以用于字段、方法参数、构造函数参数等位置

@Service
public class UserService {

    @Autowired
    @Qualifier("userServiceImpl")
    private UserMapper userMapper ;

    public User getUserById(Int id) {
        return userRepository.findById(id).orElse(null);
    }

    // Other business methods...
}

上面的示例中,@Qualifier注解用于指定需要注入的Bean的名称为“userServiceImpl”。需要注意的是,@Qualifier注解通常与@Autowired或@Inject注解一起使用,用于在多个匹配的Bean中进行选择。

如果没有指定@Qualifier注解,Spring框架将使用默认的自动装配策略,即按照类型进行匹配。如果有多个类型相同的Bean,Spring框架将抛出异常。

因此,使用@Qualifier注解可以有效地解决这个问题。

2.@Bean是一个注解,用于告诉 Spring 框架将标注的方法返回的对象注册为一个 Bean(组件)

具体的作用:

①.使用 @Bean 注解可以将方法返回的对象注册为一个 Bean,并且该 Bean 会被 Spring 容器管理

②.依赖注入:当其他组件需要使用这个 Bean 时,Spring 框架会自动将该 Bean 注入到相应的位置,实现依赖注入

③.自定义组件配置:通过 @Bean 注解可以对 Bean 进行自定义配置,例如设置属性值、初始化方法、销毁方法等

④.替代 XML 配置:需要通过 XML 配置文件来定义和配置 Bean,而现在通过 @Bean 注解可以在 Java 代码中实现同样的功能,避免了繁琐的 XML 配置

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.cloud.bus.auto.mapper.IUserMapper">
  <resultMap id="BaseResultMap" type="com.cloud.bus.common.entity.TUser">
    <id column="ID" jdbcType="VARCHAR" property="id" />
    <result column="ACCT_SCOPE" jdbcType="VARCHAR" property="acctScope" />
    <result column="CONFIG_STATUS" jdbcType="VARCHAR" property="configStatus" />
    <result column="IS_MERGE" jdbcType="VARCHAR" property="isMerge" />
    <result column="LAST_ACCT_DATE" jdbcType="DATE" property="lastAcctDate" />
    <result column="HAPPENED_YEAR" jdbcType="VARCHAR" property="happenedYear" />
  </resultMap>
  <sql id="Base_Column_List">
    ID, HOSPITAL_ID, ACCT_SCOPE, CONFIG_STATUS, IS_MERGE, SCHEDULE_ACCT_DATE,
    LAST_ACCT_DATE,LAST_OPERATE_DATE,HAPPENED_YEAR
  </sql>

  <update id="updateUser">
    update T_User
    <set>
      <if test="hospitalId != null and hospitalId != ''">
        HOSPITAL_ID = #{hospitalId,jdbcType=VARCHAR},
      </if>
     //.......
       <if test="runAcctDate != null and runAcctDate != ''">
        RUN_ACCT_DATE = #{runAcctDate,jdbcType=VARCHAR},
      </if>
    </set>
    where ID = #{id,jdbcType=VARCHAR}
  </update>
  <select id="queryUserList" resultType="com.cloud.bus.common.vo.UserVO">
      select
      <include refid="Base_Column_List"/>
      from T_User
      <include refid="Example_Where_Clause"/>
  </select>
  <sql id="Example_Where_Clause">
    <trim prefix="where" prefixOverrides="and|or">
      <if test="hospitalId != null and hospitalId != ''">
        and HOSPITAL_ID = #{hospitalId,jdbcType=VARCHAR}
      </if>
      <if test="operatorType != null and operatorType != ''">
        and OPERATOR_TYPE = #{operatorType,jdbcType=VARCHAR}
      </if>
      <if test="acctScope != null and acctScope != ''">
        and ACCT_SCOPE = #{acctScope,jdbcType=VARCHAR}
      </if>     
    </trim>
  </sql>
</mapper>

3.@Configuration 注解的主要作用是指示Spring容器,该类是一个配置类,它包含了一个或多个Spring容器所需的bean定义。

这意味着@Configuration 注解用于定义Spring应用程序的配置信息,通常在Java类中进行配置而不是在XML文件中

@Configuration 注解的作用包括

①.定义Bean:在@Configuration 注解的类中,您可以使用@Bean 注解来定义一个或多个bean。这些bean将被Spring容器托管,可以在应用程序中使用

②.组织配置@Configuration 注解使您能够将应用程序的配置集中到一个或多个Java类中,以便更好地组织和管理配置信息。这有助于提高代码的可维护性和可读性

③.替代XML配置@Configuration 注解可以用来替代传统的XML配置文件。通过使用Java类来配置应用程序,您可以获得更强的类型安全性,并且可以利用Java的特性,如条件化配置、注解等

④.支持自动装配:@Configuration 注解通常与@Autowired 注解一起使用,以实现自动装配(依赖注入)。当一个配置类被Spring容器扫描到时,其中的@Bean 方法将被调用,创建bean实例,并自动装配它们的依赖关系。

⑤.集成外部配置:通过@Configuration 注解,您可以将外部配置(如属性文件或环境变量)与应用程序的配置进行集成。Spring提供了@PropertySource 注解来加载外部属性文件,以及@Value 注解来注入属性值


@Configuration
public class ApplicationConfig {
    
    @Bean
    public UserService userService() {
        return new UserServiceImpl();
    } 
}

原文地址:https://blog.csdn.net/juanmiao/article/details/136043585

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_68099.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注