spring配置文件中配置数据源的问题
在spring配置文件中一定要配置了数据源吗?这个数据源是什么?指的是hibernate中的映射文件吗?什么时候配置事务?怎么配置事务?...
在spring配置文件中一定要配置了数据源吗?这个数据源是什么?指的是hibernate中的映射文件吗?什么时候配置事务?怎么配置事务?
展开
推荐于2018-05-09 · 知道合伙人数码行家
关注
展开全部
action中添加属性UsersDAO 为其添加方法,private UsersDAO UsersDAO = null;
添加setter方法,代码中就可以用UsersDAO
访问UsersDAO 类中的方法:
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="net.sourceforge.jtds.jdbc.Driver" />
<property name="url" value="jdbc:jtds:sqlserver://localhost:1433/database" />
<property name="username" value="sa" />
<property name="password" value="admin" />
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource"></ref>
</property>
</bean>
<bean id="UsersDAO" class="bysj.qyq.dao.impl.UsersDAO">
<property name="sessionFactory">
<ref bean="sessionFactory"></ref>
</property>
</bean>
展开全部
数据源指
任何实现了 javax.sql.DataSource 接口的,用来获取数据库连接的东东,一般有很多实现可以选,入dbcp,c3p0,bonecp等
spring配置文件中不一定要配置数据源,不过你不需要数据库操作的话
任何实现了 javax.sql.DataSource 接口的,用来获取数据库连接的东东,一般有很多实现可以选,入dbcp,c3p0,bonecp等
spring配置文件中不一定要配置数据源,不过你不需要数据库操作的话
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<bean id="Manager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<tx:advice id="tadvice" transaction-manager="Manager">
<tx:attributes>
<tx:method name="get*" read-only="true" />
<tx:method name="*" read-only="false" propagation="REQUIRED" />
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut expression="execution(public * com.veryedu.serivce.impl.*.*(..))" id="piontcut" />
<aop:advisor advice-ref="tadvice" pointcut-ref="piontcut" />
</aop:config>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"></property>
<property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:orcl">
</property>
<property name="username" value="weicheng"></property>
<property name="password" value="weicheng"></property>
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.Oracle9Dialect
</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/veryedu/model/BasDict.hbm.xml</value>
<value>com/veryedu/model/CstCustomer.hbm.xml</value>
<value>com/veryedu/model/CstActivity.hbm.xml</value>
<value>com/veryedu/model/CstService.hbm.xml</value>
<value>com/veryedu/model/CstLost.hbm.xml</value>
<value>com/veryedu/model/CstLinkman.hbm.xml</value>
<value>com/veryedu/model/Storage.hbm.xml</value>
<value>com/veryedu/model/Orders.hbm.xml</value>
<value>com/veryedu/model/OrdersLine.hbm.xml</value>
<value>com/veryedu/model/Product.hbm.xml</value>
<value>com/veryedu/model/SysRole.hbm.xml</value>
<value>com/veryedu/model/SysUser.hbm.xml</value>
<value>com/veryedu/model/SysRoleRight.hbm.xml</value>
<value>com/veryedu/model/SysRight.hbm.xml</value>
<value>com/veryedu/model/SalPlan.hbm.xml</value>
<value>com/veryedu/model/SalChance.hbm.xml</value>
</list>
</property>
</bean>
</beans>
这个是ssh整合Spring配置文件的配置
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<bean id="Manager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<tx:advice id="tadvice" transaction-manager="Manager">
<tx:attributes>
<tx:method name="get*" read-only="true" />
<tx:method name="*" read-only="false" propagation="REQUIRED" />
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut expression="execution(public * com.veryedu.serivce.impl.*.*(..))" id="piontcut" />
<aop:advisor advice-ref="tadvice" pointcut-ref="piontcut" />
</aop:config>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"></property>
<property name="url" value="jdbc:oracle:thin:@127.0.0.1:1521:orcl">
</property>
<property name="username" value="weicheng"></property>
<property name="password" value="weicheng"></property>
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.Oracle9Dialect
</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/veryedu/model/BasDict.hbm.xml</value>
<value>com/veryedu/model/CstCustomer.hbm.xml</value>
<value>com/veryedu/model/CstActivity.hbm.xml</value>
<value>com/veryedu/model/CstService.hbm.xml</value>
<value>com/veryedu/model/CstLost.hbm.xml</value>
<value>com/veryedu/model/CstLinkman.hbm.xml</value>
<value>com/veryedu/model/Storage.hbm.xml</value>
<value>com/veryedu/model/Orders.hbm.xml</value>
<value>com/veryedu/model/OrdersLine.hbm.xml</value>
<value>com/veryedu/model/Product.hbm.xml</value>
<value>com/veryedu/model/SysRole.hbm.xml</value>
<value>com/veryedu/model/SysUser.hbm.xml</value>
<value>com/veryedu/model/SysRoleRight.hbm.xml</value>
<value>com/veryedu/model/SysRight.hbm.xml</value>
<value>com/veryedu/model/SalPlan.hbm.xml</value>
<value>com/veryedu/model/SalChance.hbm.xml</value>
</list>
</property>
</bean>
</beans>
这个是ssh整合Spring配置文件的配置
更多追问追答
追问
你给的配置我都懂。 这是我问的问题,数据源是什么?ssh整合的时候一定要配置数据源吗?数据源指的是hibernate中的映射文件吗?什么时候配置事务?怎么配置事务?
追答
数据源就是链接数据库的那部分:
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
......
</bean>
这个是连接数据库必须的,这里第一个是jdbc驱动,第二个是url,第三个和第四个是数据库的帐号和密码
下面这个是事物:
<tx:advice id="tadvice" transaction-manager="Manager">
....
</tx:advice>
事物你如果配置了的话,在写sql语句或者,条件查询的时候,就不需要创建事物,关闭事物。我这里配置的就是dao实现类里面的所有的get开头的方法为只读事物。SSH整合中的事物这样配置就可以了。
这个是事物管理:它所要管理的就是数据源(datasource)所对应的事物。
<bean id="Manager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
而数据源最终要交给sessionFactory,所以把他作为sessionFactory的一个属性。
我的这个配置文件你看的懂的话你就招这样配置就行了。
pop是动态代理,你也应该明白
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询