我百思不得期解,在Spring2.0下可以,一到Spring2.5就不行了,请各位帮忙看看。
User.java
package spring25.ch06;
public class User {
private String id;
private String name;
private String comment;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getComment() {
return comment;
}
public void setComment(String comment) {
this.comment = comment;
}
}
UserDao.java
package spring25.ch06;
import java.util.List;
public interface UserDao {
void create(User user);
void update(User user);
public void delete(User user);
public List<User> list();
}
UserDaoImpl.java
package spring25.ch06.hibernate;
import java.util.List;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.springframework.transaction.annotation.Transactional;
import spring25.ch06.User;
import spring25.ch06.UserDao;
public class UserDaoImpl implements UserDao {
private SessionFactory sessionFactory;
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
@Override
@Transactional
public void create(User user) {
Session session = sessionFactory.getCurrentSession();
session.save(user);
}
@Override
@Transactional
public void update(User user) {
Session session = sessionFactory.getCurrentSession();
session.update(user);
}
@Override
@Transactional
public void delete(User user) {
Session session = sessionFactory.getCurrentSession();
session.delete(user);
}
@Override
@SuppressWarnings("unchecked")
@Transactional(readOnly=true)
public List<User> list() {
Session session = sessionFactory.getCurrentSession();
return session.createQuery("from User u").list();
}
}
Main.java
package spring25.ch06.hibernate;
import java.util.List;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import spring25.ch06.User;
import spring25.ch06.UserDao;
public class Main {
private static UserDao userDao;
static {
ApplicationContext ctx = new ClassPathXmlApplicationContext("spring25/ch06/hibernate/config.xml");
userDao = (UserDao) ctx.getBean("userDao");
}
public static void main(String[] args) throws Exception {
listUsers();
User user = new User();
user.setName("juggler");
user.setComment("juggler is a good boy.");
userDao.create(user);
listUsers();
user.setName("magic");
userDao.update(user);
listUsers();
user = new User();
user.setName("Kut");
user.setComment("He is a good programmer.");
userDao.create(user);
listUsers();
userDao.delete(user);
listUsers();
}
private static void listUsers() {
List<User> users = userDao.list();
for (User u : users) {
System.out.println("ID: " + u.getId());
System.out.println("Name: " + u.getName());
System.out.println("Comment: " + u.getComment());
System.out.println("---------------------------------");
}
System.out.println("\n");
}
}
hibernate.cfg.xml
<?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <property name="connection.url">jdbc:mysql://localhost/spring_study</property> <property name="connection.username">root</property> <property name="connection.password">xxxxxxx</property> <property name="dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property> <property name="current_session_context_class">thread</property> <property name="show_sql">false</property> <property name="hibernate.format_sql">true</property> <property name="hibernate.use_sql_comments">true</property> <mapping resource="spring25/ch06/User.hbm.xml" /> </session-factory> </hibernate-configuration>
User.hbm.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="spring25.ch06"> <class name="User" table="user" dynamic-update="true"> <id name="id" column="id"> <generator class="uuid" /> </id> <property name="name" type="string" column="name" /> <property name="comment" type="string" column="comment" /> </class> </hibernate-mapping>
config.xml
<?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:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd"> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="configLocation" value="classpath:spring25/ch06/hibernate/hibernate.cfg.xml" /> </bean> <bean id="userDao" class="spring25.ch06.hibernate.UserDaoImpl"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <tx:annotation-driven transaction-manager="transactionManager" /> </beans>
运行出错:
Exception in thread "main" org.hibernate.HibernateException: createQuery is not valid without active transaction
at org.hibernate.context.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadLocalSessionContext.java:297)
at $Proxy7.createQuery(Unknown Source)
at spring25.ch06.hibernate.UserDaoImpl.list(UserDaoImpl.java:45)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection(AopUtils.java:301)
at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:182)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:149)
at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:106)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:204)
at $Proxy5.list(Unknown Source)
at spring25.ch06.hibernate.Main.listUsers(Main.java:44)
at spring25.ch06.hibernate.Main.main(Main.java:20)