Question

Nous avons décidé de déplacer l'un de mon projet de iBatis à mybatis et a rencontré un problème avec insert.

mappeur xml:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"    
                 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="bap.persistance.interfaces.ArticleMapper">
 <insert id="insertTestA">
  insert into test_a ( cookie ) values( 'tomek pilot');
 </insert>
</mapper>

fichier java Mapper:

public interface ArticleMapper {
 void insertTestA();
}

mise en œuvre du cartographe:

String resource = "bap/persistance/MyBatis_xml/MyBatisConfig.xml";

....

... 
public void createArticle( Article article ) throws IOException {
  Reader reader = Resources.getResourceAsReader(resource);
  SqlSessionFactory sqlSessionFactory = 
          new SqlSessionFactoryBuilder().build(reader);
  SqlSession session = sqlSessionFactory.openSession();

  try{
   ArticleMapper mapper = session.getMapper(ArticleMapper.class);
   mapper.insertTestA();
  } catch( Exception e ){
   e.printStackTrace();
  } finally{
   session.close();
  }
  return article.getId();
 }
...

... line omitted for brevity.

la table en cours d'utilisation:

    CREATE TABLE test_a
(
  cookie text
)
WITH (OIDS=FALSE);

Je suis en train de courir avec cette mybatis 3.0.1, 3.0.3 printemps, postgresql 8.3 (en utilisant postgresql-8.4-701.jdbc3.jar)

Je crois que tous les réglages de passe-partout est correctement configuré (je peux exécuter une sélection par rapport à une autre fin de tableau.

J'ai testé la Inser manuellement et il fonctionne très bien (insert into test_a ( cookie ) values( 'some stuff');)

Pour une raison quelconque l'insert n'exécute pas et ne se présente pas de trace de pile jusqu'à: - (

Les conseils seront les plus appréciés: -)

Était-ce utile?

La solution

Vous n'a pas commis votre transaction. Essayez d'ajouter un "session.commit ()".

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top