在save()前打印了一下实体类,save()后也打印了一下实体类,都是有值,但是数据库里就是插入不进数据,我把Student.hbm.xml中的assigned改成native,就能插入进数据。。。
Dao层
public class UserDaoImpl implements UserDao {
private SessionFactory sessionFactory;
@Autowired
public void setSessionFactoryOverride(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
public void addStudent(Student student) {
System.out.println(sessionFactory);
System.out.println("添加前:" + student);
sessionFactory.getCurrentSession().save(student);
}
}
Student.hbm.xml
<hibernate-mapping>
<class name="com.zlm.entity.Student" table="student">
<id name="studentId" type="java.lang.Integer" >
<column name="studentId" />
<generator class="assigned" />
</id>
<property name="password" type="java.lang.String">
<column name="password" />
</property>
<property name="identify" type="java.lang.Integer">
<column name="identify" />
</property>
</class>
</hibernate-mapping>
实体类就是
private int studentId;
get
set
applicationContext.xml
<beans>
<context:component-scan base-package="com.zlm"
use-default-filters="false" />
<context:property-placeholder location="classpath:config/db.properties" />
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="${jdbc.driverClass}"></property>
<property name="url" value="${jdbc.jdbcUrl}"></property>
<property name="username" value="${jdbc.user}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
<bean id="sessionFactory"
class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect </prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.temp.use_jdbc_metadata_defaults">false</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/zlm/entity/Student.hbm.xml</value>
</list>
</property>
</bean>
<bean id="transactionManager"
class="org.springframework.orm.hibernate5.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
</beans>
assigned数据库主键增长方式,主键必须是手动分配的,如果不分配,就出错了。
要这样user.setId("01");
assigned是自己生成的,比如用UUID,然后复制给对象,再save,native是自动选择的。你现在代码是怎么实现的,传递到dao层的时候ID是有值的?
贴上controller层代码
@RequestMapping(value = "register.do")
public String register(HttpServletRequest request) {
String usernameStr = request.getParameter("username");
String password = request.getParameter("password");
String identifyStr = request.getParameter("identify");
int username = Integer.parseInt(usernameStr);
int identify = Integer.parseInt(identifyStr);
Student student = new Student();
student.setStudentId(username);
student.setPassword(password);
student.setIdentify(identify);
userService.addStudent(student);
System.out.println("添加后:" + student);
return "success";
}
解决了,还是自己hibernate学的太笼统了。在DaoImpl类中,把插入代码改成就好了,assigned不像native一样能支持事物自动提交。
public void addStudent(Student student) {
Session session = sessionFactory.openSession();
session.beginTransaction();
session.save(student);
session.getTransaction().commit();
session.close();
}