spring加载外部属性文件进行数据库连接

意义

进行软编码,对spring配置中需要经常变动的属性提取到外部属性文件中,减少对配置文件的改动,方便环境部署。如数据库连接的用户名、密码等。注意:这时不能使用byName进行自动注入。

连接数据库方法

  • 新建外部属性文件db.properties(xxx.properties)

jdbc.xxx是为了防止与计算机名冲突
属性后面不能写空格

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssm
jdbc.password=密码
jdbc.username=root
  • 添加属性命名空间xmlns:context

  • 加载属性文件

<context:property-placeholder location=”classpath:db.properties”/>
加载多个:location=”classpath:,classpath: 。。。。”

在类被spring管理后<bean id=”people”>,可以获取到属性文件内容
@Value(“jdbc.driver”)(String driver)不过需要扫描注解:
<context:component-scan base-pachage=””>(配置文件中)
注意:@Value不能写到servlet中,因为servlet不被spring容器管理

  • 设置连接
<!--数据源-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
	    <property name="driverClassName" value="${jdbc.driver}"></property>
	    <property name="url" value="${jdbc.url}"></property>
	    <property name="username" value="${jdbc.username}"></property>
	    <property name="password" value="${jdbc.password}"></property>
</bean>

<!--sqlSessionFactory对象-->
<bean id="factory" class="org.mybatis.spring.SqlSessionFactoryBean">
	<property name="dataSource" ref="dataSource"></property>
</bean>

<!--扫描包-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
	    <!-- 要扫描哪个包 -->
	    <property name="basePackage" value="mapper包名"></property>
	    <!-- 和factory产生关系 -->
	    <property name="sqlSessionFactoryBeanName" value="factory"></property>
</bean>

注意:这时扫描包,和factory产生关系时,用的是value,而不是ref,且name也不一样。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值