在Spring中初始化输出JdbcTemplate对象正在使用的数据源信息

首先是配置JdbcTemplate

<!-- 为IOC容器配置一个JdbcTemplate -->
<bean class="org.springframework.jdbc.core.JdbcTemplate" id="jdbcTemplate">
     <property name="dataSource" ref="myDateSource"/>
</bean>

引用数据库

<bean class="com.jdbcTemplate_datasource_test.datasource.MyDataSource" id="myDateSource"scope="singleton">
	   	<property name="driverClassName"value="${jdbc.driverClassName}"/>
	   	<property name="url" value="${jdbc.url}"/>
	   	<property name="username" value="${jdbc.username}"/>
	   	<property name="password" value="${jdbc.password}"/>
</bean> 

其次在Dao的实现层调用方法getDataSource()

   @PostConstruct
   public void dataSourceInit() {
	System.out.println("Dao中正在使用DataSource属性,对象是"+jdbcTemplate.getDataSource());
	}

可以使用@PostConstruct注释的方法进行初始化输出,不可以使用静态代码块,因为其执行先于Bean的注入,故无法使用到IOC容器的对象。

如果是自己编写的类可以重写toString方法

public class MyDataSource implements DataSource{


	private String url;
	private String username;
	private String password;

	/**
	 * 设置DriverClassName
	 * @param driverClassName
	 */
	public void setDriverClassName(String driverClassName) {
		Assert.hasText(driverClassName, "Property 'driverClassName' must not be empty");
		String driverClassNameToUse = driverClassName.trim();
		try {
			Class.forName(driverClassNameToUse, true, ClassUtils.getDefaultClassLoader());
		}
		catch (ClassNotFoundException ex) {
			throw new IllegalStateException("Could not load JDBC driver class [" + driverClassNameToUse + "]", ex);
		}
	}

	public void setUrl(String url) {
		this.url = url;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	public void setPassword(String password) {
		this.password = password;
	}

	@Override
	public PrintWriter getLogWriter() throws SQLException {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public void setLogWriter(PrintWriter out) throws SQLException {
		// TODO Auto-generated method stub
		
	}

	@Override
	public void setLoginTimeout(int seconds) throws SQLException {
		// TODO Auto-generated method stub
		
	}

	@Override
	public int getLoginTimeout() throws SQLException {
		// TODO Auto-generated method stub
		return 0;
	}

	@Override
	public Logger getParentLogger() throws SQLFeatureNotSupportedException {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public <T> T unwrap(Class<T> iface) throws SQLException {
		// TODO Auto-generated method stub
		return null;
	}

	@Override
	public boolean isWrapperFor(Class<?> iface) throws SQLException {
		// TODO Auto-generated method stub
		return false;
	}
	
	
	@Override
	public Connection getConnection() throws SQLException {
		// TODO Auto-generated method stub
		return DriverManager.getConnection(url, username, password);
	}

	
	@Override
	public Connection getConnection(String username, String password) throws SQLException {
		// TODO Auto-generated method stub
		return DriverManager.getConnection(url, username, password);
	}

	@Override
	public String toString() {
		return "MyDataSource [url=" + url + ", username=" + username + ", password=" + password + "]";
	}
	
}

现在我们用控制台输出一下结果

Dao中正在使用DataSource属性,对象是MyDataSource [url=jdbc:mysql:///carcheck?serverTimezone=GMT%2B8&charsetEncoding=utf-8, username=root, password=root]
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring容器初始化JdbcTemplate对象,你可以按照以下步骤进行操作: 1. 首先,在你的Spring配置文件(通常是applicationContext.xml),配置数据源(DataSource)。你可以使用Spring提供的内置数据源,如BasicDataSource,或者使用其他第三方库提供的数据源。 ```xml <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> <property name="driverClassName" value="com.mysql.jdbc.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/mydatabase" /> <property name="username" value="username" /> <property name="password" value="password" /> </bean> ``` 2. 接下来,配置JdbcTemplate对象并将其与数据源关联。可以使用`org.springframework.jdbc.core.JdbcTemplate`类来创建JdbcTemplate对象,并通过构造函数或setter方法注入数据源。 ```xml <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"> <property name="dataSource" ref="dataSource" /> </bean> ``` 3. 确保你已经导入了Spring的JDBC相关依赖,以及数据库驱动程序的相关依赖。例如,如果你使用MySQL数据库,需要导入MySQL驱动程序的依赖。 ```xml <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>5.3.9</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.26</version> </dependency> ``` 完成以上步骤后,Spring容器会在应用程序启动时自动初始化JdbcTemplate对象,并将其注入到需要使用的地方,例如DAO类。你可以在需要的地方通过依赖注入(DI)来获取JdbcTemplate对象,然后使用它执行数据库操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值