【Spring】使用数据源连接池访问数据库

Spring并没有提供数据源连接池实现,但是可以选择其他开源的实现:

这些连接池中得大多数都能配置为Spring的数据源,在一定程度上与Spring自带的DriverManagerDataSource或SingleConnectionDataSource很类似。如下是配置DBCP BasicDataSource的方式:

也可以用Java来配置:

上面两种方式配置的四个属性是BasicDataSource所必需的。属性driverClassName指定了JDBC驱动类的全限定类名。在这里我配置的时MySql数据库的数据源  。属性url用于设置数据库的JDBC URL。最后,username和password用于在连接数据库时进行认证。

【Spring】bean的作用域

在默认情况下,Spring应用上下文中所有bean都是作为以单例(singleton)的形式创建的。也就是说,不管给定的一个bean被注入到其他bean多少次,每次所注入的都是同一个实例。

在大多数情况下,单例bean是很理想的方法。初始化和垃圾回收对象实例所带来的成本只留给一些小规模任务,在这些任务中,让对象保持无状态并且在应用中反复重用这些对象可能并不合理。

有写时候,我们所使用的类是易变的(mutable),它们会保持一些状态,因此重用是不安全的。在这种情况下将class声明为单例的bean就不是很好了,因为对象会被污染

Spring定义了多种作用域,可以基于这些作用域创建bean,包括:

  • 单例(singleton):在整个应用中,只创建bean的一个实例。
  • 原型(Prototype):每次注入或者通过Spring应用上下文获取的时候,都会创建一个新的bean实例。
  • 会话(Session):在Web应用中,为每个会话创建一个bean实例。
  • 请求(Request):在Web应用中,为每个请求创建一个bean实例。

单例是默认的作用域,但是对于易变的类型这是不合适的。如果选择其他的作用域,要使用@Scope注解,它可以与@Component或@Bean一起使用。

如下是分别对@Component和@Bean使用@Scope注解