Hibernate et de la monnaie de précision

J'ai une hibernate mapping comme suit:

<hibernate-mapping>
<class name="kochman.elie.data.types.InvoiceTVO" table="INVOICE">
<id name="id" column="ID">
<generator class="increment"/>
</id>
<property name="date" column="INVOICE_DATE"/>
<property name="customerId" column="CUSTOMER_ID"/>
<property name="schoolId" column="SCHOOL_ID"/>
<property name="bookFee" column="BOOK_FEE"/>
<property name="adminFee" column="ADMIN_FEE"/>
<property name="totalFee" column="TOTAL_FEE"/>
</class>
</hibernate-mapping>    

où InvoiceTVO a les variables définies comme:

private int id;
private Date date;
private int customerId;
private int schoolId;
private float bookFee;
private float adminFee;
private float totalFee;

Quand je fais un insert sur cette table, j'obtiens l'erreur suivante:

Hibernate: insert into INVOICE (INVOICE_DATE, CUSTOMER_ID, SCHOOL_ID, BOOK_FEE, ADMIN_FEE, TOTAL_FEE, ID) values (?, ?, ?, ?, ?, ?, ?)
50156 [AWT-EventQueue-0] WARN org.hibernate.util.JDBCExceptionReporter - SQL Error: 0, SQLState: 22001
50156 [AWT-EventQueue-0] ERROR org.hibernate.util.JDBCExceptionReporter - Data truncation: Data truncated for column 'ADMIN_FEE' at row 1
50156 [AWT-EventQueue-0] ERROR org.hibernate.event.def.AbstractFlushingEventListener - Could not synchronize database state with session

J'ai essayé de changer le type de adminFee à double, et qui ne fonctionne pas non plus. Le problème est, Hibernate n'a réellement procéder à l'insérer correctement, et l'avenir des instructions select travail pour revenir au jeu de valeurs, mais cette erreur m'empêche de faire des traitements sur cette facture.

Les champs bookFee, adminFee, et totalFee sont tous censés être des devises. Ils sont définis dans la base de données MySQL comme decimal(5,2).

Toute aide dans la façon de résoudre ce serait grandement apprécié.

Tout d'abord configurer hibernate pour afficher les requêtes SQL. Ce serait très utile.
Avez-vous les définir comme séparateur décimal 5,2 ou était-ce de Hibernate?
Je l'ai fait, mais j'ai hérité de la plupart des données, de sorte qu'il n'y avait pas beaucoup d'options.
c'est la "requête SQL" j'ai Hibernate configuré pour afficher les requêtes. Aussi loin que j'ai pu trouver, il n'y a pas un moyen d'afficher les valeurs, il est en fait l'utilisation.

OriginalL'auteur Elie | 2008-12-30

Leave a Reply

Votre adresse de messagerie ne sera pas publiée. Les champs obligatoires sont indiqués avec *