Я не могу добавить значения в свою таблицу. Ошибки нет, но значения не вставляются в мою базу данных. После отправки формы никаких ошибок не появлялось.
Глядя на консоль, это показывает:
Hibernate:
insert
into
referral
(address, doctor_contact_no, doctor_name, facility_contact_no, facility_type, referral_no, referring_from, referring_to)
values
(?, ?, ?, ?, ?, ?, ?, ?)
Я уже пробовал вести журнал на случай, если мой контроллер не сможет прочитать форму, которую я отправляю.
Фрагмент кода объекта/модели, который я сохраняю
@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;
}
}
Фрагмент кода методов контроллера
@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>
trans=session.getCurrentSession().getTransaction();
, но это привело к этой ошибкеsaveOrUpdate is not valid without active transaction
@JBNizet - person jayjay-arphie   schedule 26.03.2017<tx:annotation-driven transaction-manager="transactionManager" /> <beans:bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager"> <beans:property name="sessionFactory" ref="sessionFactory" /> </beans:bean>
- person jayjay-arphie   schedule 26.03.2017@EnableTransactionManagement
- person jayjay-arphie   schedule 26.03.2017