hibernate 如何查询带有外键的表
如题,我有两个表,结构如下
create table user
(
    int id primary key,
    name varchar(20),
    password varchar(20)
);
create table consume
(
   int id primary key,
   user varchar(20),
   .......
   foreign key (user)  referencs user(name)
        on delete cascade
        on update cascade
)
其中,consume表中的user为外键,参考表就是user表中的name
我想用hibernate访问数据库,
其中,用HQL  from user
访问数据库的时候,没有我呢提
可是,当我用HQL语言测试Consume的时候,发生了错误,
HQL如下from Consume
错误如下:
org.hibernate.exception.GenericJDBCException: could not execute query	at org.hibernate.exception.SQLStateConverter.handledNonSpecificException(SQLStateConverter.java:103)
	at org.hibernate.exception.SQLStateConverter.convert(SQLStateConverter.java:91)
	at org.hibernate.exception.
JDBCExceptionHelper.convert(JDBCExceptionHelper.java:43)
	at org.hibernate.loader.Loader.doList(Loader.java:2223)
	at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2104)
	at org.hibernate.loader.Loader.list(Loader.java:2099)
	at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:378)
	at org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:338)
	at org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:172)
	at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1121)
	at 
org.hibernate.impl.QueryImpl.list(QueryImpl.java:79)
Caused by: 
java.sql.SQLException: Invalid value for getInt() - 'ningbi'
	at 
com.mysql.jdbc.SQLError.create
SQLException(SQLError.java:910)
	at com.mysql.jdbc.ResultSet.getInt(ResultSet.java:2676)
	at com.mysql.jdbc.ResultSet.getInt(ResultSet.java:2749)
	at org.hibernate.type.IntegerType.get(IntegerType.java:28)
	at org.hibernate.type.NullableType.nullSafeGet(NullableType.java:163)
	at org.hibernate.type.NullableType.nullSafeGet(NullableType.java:154)
	at org.hibernate.type.ManyToOneType.hydrate(ManyToOneType.java:103)
	at org.hibernate.persister.entity.AbstractEntityPersister.hydrate(AbstractEntityPersister.java:2096)
	at org.hibernate.loader.Loader.loadFromResultSet(Loader.java:1380)
	at org.hibernate.loader.Loader.instanceNotYetLoaded(Loader.java:1308)
	at org.hibernate.loader.Loader.getRow(Loader.java:1206)
	at org.hibernate.loader.Loader.getRowFromResultSet(Loader.java:580)
	at org.hibernate.loader.Loader.doQuery(Loader.java:701)
	at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:236)
	at org.hibernate.loader.Loader.doList(Loader.java:2220)
------解决方案--------------------
+1+1+1+1+1+1