java - Spring hibernate : Values not inserting into database

标签 java spring hibernate database-management

我似乎无法向我的表添加值。没有错误,但值没有插入到我的数据库中。提交表单后,不会出现任何错误。

查看控制台后,显示:

Hibernate: 
    insert 
    into
        referral
        (address, doctor_contact_no, doctor_name, facility_contact_no, facility_type, referral_no, referring_from, referring_to) 
    values
        (?, ?, ?, ?, ?, ?, ?, ?)

我已经尝试过记录,以防万一我的 Controller 无法读取我提交的表单。

我正在保存的实体/模型的代码片段

@Entity
@Table(name="referral")
public class Referrals {
    @Id
    @Column
    @GeneratedValue(strategy=GenerationType.AUTO)
    private Integer id;

    @Column
    private String referral_no;
    @Column
    private String facility_contact_no;
    @Column
    private String referring_from;
    @Column
    private String referring_to;
    @Column
    private String facility_type;
    @Column
    private String address;
    @Column
    private String doctor_name;
    @Column
    private String doctor_contact_no;' 

我的服务类的代码片段

@Service
@Transactional
public class ReferralServicesImpl implements ReferralServices{
    @Autowired
    private ReferralDao referralDao;

    public List<Referrals> list(){
        return referralDao.list();
    }
    public boolean saveReferral(Referrals referral){

        if(referralDao.saveReferral(referral))
            return true;
        else
            return false;
    }
}

Controller 方法的代码片段

@RequestMapping(value = "/teleaudiology/referral", method = RequestMethod.GET)
        public ModelAndView showForm() {
            return new ModelAndView("referrals", "referrals", new Referrals());
        }

        @RequestMapping(value = "/teleaudiology/referrals", method = RequestMethod.POST)
        public String submit(@Valid @ModelAttribute("referrals")Referrals referral, 
          BindingResult result, ModelMap model) {
            if (result.hasErrors()) {
                return "error";
            }
            System.out.println("referral: "+referral.getDoctor_name());
            if(referralServices.saveReferral(referral))
                return "redirect:../teleaudiology";
            else 
                return "redirect:../teleaudiology";
        }

这是 ReferralDao 类

public interface ReferralDao {
    public boolean saveReferral(Referrals referral);
    public List<Referrals> list();
}

ReferralDao 实现

@Repository
@Transactional
public class ReferralDaoImpl implements ReferralDao {
    @Autowired
    SessionFactory session;
    Transaction trans;

    public boolean saveReferral(Referrals referral) {
        // TODO Auto-generated method stub
        //System.out.println("Saving..."+referral.getReferring_to_address());

        trans=session.getCurrentSession().beginTransaction();
        session.getCurrentSession().saveOrUpdate(referral);
        return true;
    }

    public List<Referrals> list() {
        // TODO Auto-generated method stub
        return session.getCurrentSession().createQuery("from Referrals").list();
    }

}

我尝试使用

trans=session.getCurrentSession().getTransaction();

但导致了这个错误

`saveOrUpdate is not valid without active transaction`

servlet-context.xml 的片段

<tx:annotation-driven transaction-manager="transactionManager" />
    <beans:bean id="transactionManager"  class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <beans:property name="sessionFactory" ref="sessionFactory" />
    </beans:bean>

最佳答案

尝试使用下面的代码

 Session s = sessionFactory.getCurrentSession();
 s.save(object);

关于java - Spring hibernate : Values not inserting into database,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43027001/

相关文章:

java - hibernate ,按 id 或唯一列选择

Java cucumber : creating scenario outlines with dynamic examples

java - 日历对象时区转换

java - 如何修复在 Spring Boot 中运行 sql 查询?

java - Spring Data MongoDB - 保存 LocalDate/LocalDateTime 时,值被设置为昨天

hibernate - @Temporal(TemporalType.DATE) 的问题

java - 正则表达式删除除特定格式之外的所有内容

java - 我无法正确编译此代码。我究竟做错了什么?

java - 为什么请求会发送到 Struts Dispatcher?

hibernate - 如何将@添加到postgres hibernate方言?