当我试图在数据库中添加和显示元素时,我得到以下错误。这是详细的错误消息:

时间:2017-08-07 16:43:01

标签: mysql hibernate jsp dao

ÉtatHTTP500 - 内部服务器错误

输入Rapport d''例外

message org.hibernate.exception.ConstraintViolationException: could not execute statement

description Le serveur a rencontré une erreur interne qui l''a empêché de satisfaire la requête.

exception

javax.persistence.PersistenceException: org.hibernate.exception.ConstraintViolationException: could not execute statement
    org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:147)
    org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:155)
    org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:162)
    org.hibernate.internal.SessionImpl.firePersist(SessionImpl.java:780)
    org.hibernate.internal.SessionImpl.persist(SessionImpl.java:758)
    ma.axa.HibernateDAO.TachesDAO.saveData(TachesDAO.java:26)
    ma.axa.Servlets.FrontServlet.doPost(FrontServlet.java:50)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
cause mère

org.hibernate.exception.ConstraintViolationException: could not execute statement
    org.hibernate.exception.internal.SQLExceptionTypeDelegate.convert(SQLExceptionTypeDelegate.java:59)
    org.hibernate.exception.internal.StandardSQLExceptionConverter.convert(StandardSQLExceptionConverter.java:42)
    org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:111)
    org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:97)
    org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:207)
    org.hibernate.dialect.identity.GetGeneratedKeysDelegate.executeAndExtract(GetGeneratedKeysDelegate.java:57)
    org.hibernate.id.insert.AbstractReturningDelegate.performInsert(AbstractReturningDelegate.java:42)
    org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2907)
    org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3478)
    org.hibernate.action.internal.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:81)
    org.hibernate.engine.spi.ActionQueue.execute(ActionQueue.java:623)
    org.hibernate.engine.spi.ActionQueue.addResolvedEntityInsertAction(ActionQueue.java:277)
    org.hibernate.engine.spi.ActionQueue.addInsertAction(ActionQueue.java:258)
    org.hibernate.engine.spi.ActionQueue.addAction(ActionQueue.java:303)
    org.hibernate.event.internal.AbstractSaveEventListener.addInsertAction(AbstractSaveEventListener.java:318)
    org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:275)
    org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:182)
    org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:113)
    org.hibernate.event.internal.DefaultPersistEventListener.entityIsTransient(DefaultPersistEventListener.java:189)
    org.hibernate.event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:132)
    org.hibernate.event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:58)
    org.hibernate.internal.SessionImpl.firePersist(SessionImpl.java:773)
    org.hibernate.internal.SessionImpl.persist(SessionImpl.java:758)
    ma.axa.HibernateDAO.TachesDAO.saveData(TachesDAO.java:26)
    ma.axa.Servlets.FrontServlet.doPost(FrontServlet.java:50)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
cause mère

com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Column 'nom_tache' cannot be null
    sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    java.lang.reflect.Constructor.newInstance(Constructor.java:423)
    com.mysql.jdbc.Util.handleNewInstance(Util.java:404)
    com.mysql.jdbc.Util.getInstance(Util.java:387)
    com.mysql.jdbc.SQLError.createSQLException(SQLError.java:934)
    com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3966)
    com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3902)
    com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2526)
    com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2673)
    com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2549)
    com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1861)
    com.mysql.jdbc.PreparedStatement.executeUpdateInternal(PreparedStatement.java:2073)
    com.mysql.jdbc.PreparedStatement.executeUpdateInternal(PreparedStatement.java:2009)
    com.mysql.jdbc.PreparedStatement.executeLargeUpdate(PreparedStatement.java:5098)
    com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:1994)
    org.hibernate.engine.jdbc.internal.ResultSetReturnImpl.executeUpdate(ResultSetReturnImpl.java:204)
    org.hibernate.dialect.identity.GetGeneratedKeysDelegate.executeAndExtract(GetGeneratedKeysDelegate.java:57)
    org.hibernate.id.insert.AbstractReturningDelegate.performInsert(AbstractReturningDelegate.java:42)
    org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:2907)
    org.hibernate.persister.entity.AbstractEntityPersister.insert(AbstractEntityPersister.java:3478)
    org.hibernate.action.internal.EntityIdentityInsertAction.execute(EntityIdentityInsertAction.java:81)
    org.hibernate.engine.spi.ActionQueue.execute(ActionQueue.java:623)
    org.hibernate.engine.spi.ActionQueue.addResolvedEntityInsertAction(ActionQueue.java:277)
    org.hibernate.engine.spi.ActionQueue.addInsertAction(ActionQueue.java:258)
    org.hibernate.engine.spi.ActionQueue.addAction(ActionQueue.java:303)
    org.hibernate.event.internal.AbstractSaveEventListener.addInsertAction(AbstractSaveEventListener.java:318)
    org.hibernate.event.internal.AbstractSaveEventListener.performSaveOrReplicate(AbstractSaveEventListener.java:275)
    org.hibernate.event.internal.AbstractSaveEventListener.performSave(AbstractSaveEventListener.java:182)
    org.hibernate.event.internal.AbstractSaveEventListener.saveWithGeneratedId(AbstractSaveEventListener.java:113)
    org.hibernate.event.internal.DefaultPersistEventListener.entityIsTransient(DefaultPersistEventListener.java:189)
    org.hibernate.event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:132)
    org.hibernate.event.internal.DefaultPersistEventListener.onPersist(DefaultPersistEventListener.java:58)
    org.hibernate.internal.SessionImpl.firePersist(SessionImpl.java:773)
    org.hibernate.internal.SessionImpl.persist(SessionImpl.java:758)
    ma.axa.HibernateDAO.TachesDAO.saveData(TachesDAO.java:26)
    ma.axa.Servlets.FrontServlet.doPost(FrontServlet.java:50)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:661)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:742)
    org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
note La trace complète de la cause mère de cette erreur est disponible dans les fichiers journaux de ce serveur.

Apache Tomcat / 8.5.16

项目的结构是:

这是Taches.java类

public class Taches {

private Integer id_tache;
private String nom_tache;
private String description_tache;

//les constructeurs

public Taches() 
{
    super();
}

public Taches(Integer id_tache, String nom_tache, String description_tache) {
    super();
    this.id_tache = id_tache;
    this.nom_tache = nom_tache;
    this.description_tache = description_tache;
}

//getters and setters
public Integer getId_tache() {
    return id_tache;
}

public void setId_tache(Integer id_tache) {
    this.id_tache = id_tache;
}
public String getNom_tache() {
    return nom_tache;
}
public void setNom_tache(String nom_tache) {
    this.nom_tache = nom_tache;
}
public String getDescription_tache() {
    return description_tache;
}
public void setDescription_tache(String description_tache) {
    this.description_tache = description_tache;
}

这是TacheDAO.java类

public class TachesDAO {

Session session;
private Session setSession(){
    Session session=HibernateUtil.getSessionFactory().openSession();
    return session;
}
//enregistrer des donnees dans la table categories
public void saveData(Taches tache){
    session=setSession();
    try{
        session.beginTransaction();
        session.persist(tache);
        session.getTransaction().commit();
    }catch(HibernateException he){
        he.printStackTrace();
        if(session.getTransaction()!=null){
            session.getTransaction().rollback();
        }
    }finally{
        if(session!=null){
            session.close();
        }
    }
}

//selectionner la liste des donnees
public List<Taches> selectAllData(){
    List<Taches> ltaches=new ArrayList();

    session=setSession();
    try{
        session.beginTransaction();

        Query<Taches> query=session.createQuery("From Taches");
        ltaches=query.list();
        session.getTransaction().commit();

        return ltaches;
    }catch(HibernateException he){

        he.printStackTrace();
        if(session.getTransaction()!=null){
            session.getTransaction().rollback();
        }

        return null;
    }finally{
        if(session!=null){
            session.close();
        }
    }


}
public Taches getTachesById(Integer id){
    Taches tache=null;
    Session session=setSession();
    try{
        session.beginTransaction();
        tache=(Taches)session.get(Taches.class, id);
        session.getTransaction().commit();

    }catch(HibernateException he){
        he.printStackTrace();
        if(session.getTransaction()!=null){
            session.getTransaction().rollback();
        }
    }finally{
        if(session!=null){
            session.close();
        }
    }

    return tache;
}

这个文件是hibernateUtil.java

public class HibernateUtil {


private static final SessionFactory sessionFactory=buildSessionFactory();
private static SessionFactory buildSessionFactory(){

    try {
                      // Create SessionFactory with hibernate.cfg.xml configure+build
                      return new Configuration().configure().buildSessionFactory();

        } 
    catch (Throwable ex)
    {
                      // Make sure you log the exception, as it might be swallowed
                      System.err.println("Initial SessionFactory creation failed." + ex);
                      throw new ExceptionInInitializerError(ex);
    }

  }


public static SessionFactory getSessionFactory(){
    return sessionFactory;
}



}

这是servlet FrontSERVLET

public class FrontServlet extends HttpServlet {

protected void doGet(HttpServletRequest req, HttpServletResponse resp)
        throws ServletException, IOException {


req.getRequestDispatcher("/WEB-INF/backOffice/index.jsp").forward(req, resp);
Taches tache=new Taches();

}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp)
        throws ServletException, IOException {
    Taches tache=new Taches();
    TachesDAO TDAO=new TachesDAO();

    String titre=req.getParameter("nom_tache");
    String description=req.getParameter("description_tache");

    tache.setNom_tache(titre);
    tache.setDescription_tache(description);

    TDAO.saveData(tache);


}

这是我的页面index.jsp

  <div class="ajouter">

      <a>Ajouter</a>
      <form method="post" enctype="multipart/form-data" boundary="boundary">
          Nom de la tache: <input type="text" name="module"><br>
          Description: <input type="text" name="description"><br>


          <input type="submit" value="Ajouter">
      </form>

</div>

2 个答案:

答案 0 :(得分:1)

您有一个命名问题:(请注意名称为module

Nom de la tache: <input type="text" name="module"><br>

但你读为

String titre=req.getParameter("nom_tache");

因此nom_tache字段变为空,所以你得到

....MySQLIntegrityConstraintViolationException: Column 'nom_tache' cannot be null .... 

希望这会有所帮助......

答案 1 :(得分:-1)

在班级internal class CategoryDataGroup { public string Name { get; set; } public List<CategoryData> Items { get; set; } } internal class CategoryData { public CategoryData(string grp, string title) { Grp = grp; Title = title; } public string Grp { get; private set; } public string Title { get; private set; } } internal class CategoryDataGenerator { private static List<CategoryData> _data; public static List<CategoryDataGroup> GetGroupedData() { if (_data != null) _data.Clear(); GenerateData(); return _data.GroupBy(d => d.Grp[0], (key, items) => new CategoryDataGroup() { Name = key.ToString(), Items = items.ToList() }).ToList(); } private static void GenerateData() { ObservableCollection<Category> ocCategories = new ObservableCollection<Category>(); SQLiteManager.Categories.Select(ocCategories); _data = new List<CategoryData>(); foreach (var temp in ocCategories) { _data.Add(new CategoryData(temp.Name.Substring(0,1), temp.Name)); } } } , 你忘记了注释,这是告诉hibernate在哪里插入数据的最重要的信息

Taches