Spring Hibernate save无法插入到数据库中(上网搜过了,但是没有找到解决的办法)

Jesse_____ 2011-12-15 04:45:05
我的Spring配置文件如下:


<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
destroy-method="close">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>

<property name="url">
<value>jdbc:mysql://localhost:3306/store?useUnicode=true&characterEncoding=UTF-8</value>
</property>

<property name="username">
<value>root</value>
</property>

<property name="password">
<value>****</value>
</property>
</bean>


<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="dataSource" />
</property>

<property name="mappingResources">
<list>
<value>com/**/bean/ReceUnit.hbm.xml</value>
</list>
</property>

<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>

<prop key="hibernate.show_sql">
true
</prop>
</props>
</property>
</bean>


<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>


<bean id="ReceUnitDAO" class="com.**.dao.impl.ReceUnitDAOImpl"
scope="singleton">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>


<bean id="receUnitServiceTarger" class="com.**.service.impl.ReceUnitServiceImpl">
<property name="receUnitDAO">
<ref bean="ReceUnitDAO" />
</property>
</bean>

<bean id="receUnitService"
class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="target" ref="receUnitServiceTarger"></property>
<property name="transactionManager" ref="transactionManager"></property>
<property name="transactionAttributes">
<props>
<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop><!-- PROPAGATION_REQUIRED:如果存在一个事务就使用这个事务,否则开启新的事务 -->
<prop key="*">PROPAGATION_REQUIRED</prop>
</props>
</property>
</bean>

<bean id="addReceUnit" class="com.**.action.receunit.AddReceUnit">
<property name="service" ref="receUnitService"></property>
</bean>

Bean如下:
public class ReceUnit {
private Integer id;
private String index;
private String name;
setter()&&getter();
}



Action(属性驱动)如下:

public class AddReceUnit extends ActionSupport {
private String index;
private String name;
private ReceUnitService service;
setter()&&getter();

@Override
public String execute() throws Exception {

ReceUnit ru = new ReceUnit();
//主键id在hbm中设置为自增类型
ru.setIndex(index);
ru.setName(name);
this.service.insert(ru);
return SUCCESS;
}

中间的ReceUnitService、ReceUnitServiceImpl和ReceUnitDAO就省略了。

DAOImpl代码如下:

public class ReceUnitDAOImpl extends HavenDAOImpl implements ReceUnitDAO {

@Override
public void insert(ReceUnit ru) {
this.getHibernateTemplate().save(ru);
}

}

hbm如下:
<hibernate-mapping>
<class name="com.fanghongyu.bean.ReceUnit" table="rece_unit">
<id name="id" column="id" type="integer">
<generator class="increment">
<!-- 主键设置为自增类型 -->
</generator>
</id>
<property name="index" column="index" type="string"></property>
<property name="name" column="name" type="string"></property>
</class>
</hibernate-mapping>





执行代码时,控制台有如下的现实:
Hibernate: select max(id) from rece_unit
Hibernate: insert into rece_unit (index, name, id) values (?, ?, ?)
但是看数据库中没有插入成功,请问为什么?


另外我是异步提交的就是:
$.ajax({
type : "GET",
url : "addReceUnit.action",
dateType : "html",
data : {"index" : $("#rece_unit_index").val(), "name" : content},
success : function(returnedData){
}
});
不知是不是这里出了问题,但是插入前通过控制台可以看到值是拿到了。
...全文
418 22 打赏 收藏 转发到动态 举报
写回复
用AI写文章
22 条回复
切换为时间正序
请发表友善的回复…
发表回复
Jesse_____ 2011-12-22
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 soli11722984 的回复:]

应该url : "addReceUnit.action",不对

你可以用DEBUG看看,有没有进入ACTION里面去
[/Quote]
我找到错误了,数据库中的字段名起了“index”这个关键字,在hbm文件中映射时index对应的column应加反引号(笔记本键盘上1左边的符号)。由于用可视化界面建的表,建表时自动加上了反引号,所以没有注意到用了关键字。谢谢了!
Jesse_____ 2011-12-22
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 soli11722984 的回复:]

应该url : "addReceUnit.action",不对

你可以用DEBUG看看,有没有进入ACTION里面去
[/Quote]
我找到错误了,数据库中的字段名起了“index”这个关键字,在hbm文件中映射时index对应的column应加反引号(笔记本键盘上1左边的符号)。由于用可视化界面建的表,建表时自动加上了反引号,所以没有注意到用了关键字。谢谢了!
computerclass 2011-12-17
  • 打赏
  • 举报
回复
你将事务加在dao中,
this.getHibernateTemplate().save(ru);
桃园闲人 2011-12-17
  • 打赏
  • 举报
回复
以前有人提到过这种问题,基本都是事务配置的问题:
<property name="transactionAttributes">
<props>
<prop key="find*">PROPAGATION_REQUIRED,readOnly</prop><!-- PROPAGATION_REQUIRED:如果存在一个事务就使用这个事务,否则开启新的事务 -->
<prop key="*">PROPAGATION_REQUIRED</prop>
</props>
</property>
你这个不觉的涵盖面太广了吗?你想把红色部分的这一句去掉试试看可以不/
Jesse_____ 2011-12-17
  • 打赏
  • 举报
回复
[Quote=引用 16 楼 wsm106 的回复:]

<!-- 自动提交 -->
<prop key="hibernate.connection.autocommit">true</prop>
[/Quote]
加了,但是也不行
Jesse_____ 2011-12-17
  • 打赏
  • 举报
回复
[Quote=引用 15 楼 hellcomer 的回复:]

你的错误信息是什么啊。。 错误提示。。
[/Quote]
没有错误信息,控制台上打印了insert了,但是数据库中没有插入
effort1020 2011-12-16
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 jesse_____ 的回复:]
引用 2 楼 soli11722984 的回复:

应该url : "addReceUnit.action",不对

你可以用DEBUG看看,有没有进入ACTION里面去

都打印出了:
Hibernate: select max(id) from rece_unit
Hibernate: insert into rece_unit (index, name, id) values……
[/Quote]

看看service层,估计有异常回滚了撒,在service层,执行操作后,打印条信心看看有没有啊
Jesse_____ 2011-12-16
  • 打赏
  • 举报
回复
[Quote=引用 10 楼 hollin1988 的回复:]
你是不是映射错了表或者数据库,然后你看原先的表没数据,可能是插错到其他表中了。
[/Quote]
谢谢,不是啊.如果在这张表中查找数据可以正常执行,就是插入不行。映射没有问题。
一板砖夯死你 2011-12-16
  • 打赏
  • 举报
回复
<!-- 自动提交 -->
<prop key="hibernate.connection.autocommit">true</prop>
hellcomer 2011-12-16
  • 打赏
  • 举报
回复
你的错误信息是什么啊。。 错误提示。。
pop_ret 2011-12-16
  • 打赏
  • 举报
回复
看看你的数据表是不是有什么非空的设置,而你传进去的值有null
hollin1988 2011-12-15
  • 打赏
  • 举报
回复
你是不是映射错了表或者数据库,然后你看原先的表没数据,可能是插错到其他表中了。
hellcomer 2011-12-15
  • 打赏
  • 举报
回复
说错了 不是web.xml里的是applicationContext.xml里面的。
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource" />
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>school/model/User.hbm.xml</value>
<value>school/model/Teacher.hbm.xml</value>
<value>school/model/BookCase.hbm.xml</value>
<value>school/model/Program.hbm.xml</value>
<value>school/model/Award.hbm.xml</value>
</list>
</property>
</bean>
就像这个样子有个注入。你把错误提示信息贴出来。
y_0715 2011-12-15
  • 打赏
  • 举报
回复
是所有的添加方法都这样还是只有这个方法不行。所有的都不行看看是不是驱动或少包 。只有这个的话 建议你写个mian方法测试一下
老9 2011-12-15
  • 打赏
  • 举报
回复
你debug的时候有没有值?然后就是把你保存的那段代码贴出来。
Jesse_____ 2011-12-15
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 hellcomer 的回复:]

将dao重新生成下吧,这个错误应该是指跟数据库连接的问题,还有你的web.xml里面的list加了么?
[/Quote]
web.xml只写了
<filter>
<filter-name>store</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>

<filter-mapping>
<filter-name>store</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
请问list是什么,原来没有加过也可以插入啊

我的DAO如下:
public interface ReceUnitDAO {
public void insert(ReceUnit ru);
}

我觉得数据库已经连上了,其他页面都可以正常的对数据库进行增删查改
hellcomer 2011-12-15
  • 打赏
  • 举报
回复
将dao重新生成下吧,这个错误应该是指跟数据库连接的问题,还有你的web.xml里面的list加了么?
Jesse_____ 2011-12-15
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 soli11722984 的回复:]

应该url : "addReceUnit.action",不对

你可以用DEBUG看看,有没有进入ACTION里面去
[/Quote]
都打印出了:
Hibernate: select max(id) from rece_unit
Hibernate: insert into rece_unit (index, name, id) values (?, ?, ?)
都进入了DAOImpl了
hellcomer 2011-12-15
  • 打赏
  • 举报
回复
设置断点调试下吧,首先看到action没 ,然后看到service没有,在就是dao方法调用的时候。
soli11722984 2011-12-15
  • 打赏
  • 举报
回复
应该url : "addReceUnit.action",不对

你可以用DEBUG看看,有没有进入ACTION里面去
加载更多回复(1)

67,515

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧