2012-04-17 168 views
4

我正在使用H2数据库来测试我的Grails应用程序。我有一些简单的域类,如:表创建失败

package mypackage 

class UserSession { 
    User user 
    String sessionTokenHash 

    // last seen info 
    String lastSeenIP 
    Date lastSeenTime 
    String lastSeenUserAgent 
    String lastSeenURL 
} 

但是,该表似乎无法正确创建。

hbm2ddl.SchemaExport Unsuccessful: create table user_session (id bigint not null auto_increment, version bigint not null, last_seenip varchar(255) not null, last_seen_time datetime not null, last_seenurl varchar(255) not null, last_seen_user_agent varchar(255) not null, session_token_hash varchar(255) not null, user_id bigint not null, primary key (id)) ENGINE=InnoDB 
hbm2ddl.SchemaExport Syntax error in SQL statement "CREATE TABLE USER_SESSION (ID BIGINT NOT NULL AUTO_INCREMENT, VERSION BIGINT NOT NULL, LAST_SEENIP VARCHAR(255) NOT NULL, LAST_SEEN_TIME DATETIME NOT NULL, LAST_SEENURL VARCHAR(255) NOT NULL, LAST_SEEN_USER_AGENT VARCHAR(255) NOT NULL, SESSION_TOKEN_HASH VARCHAR(255) NOT NULL, USER_ID BIGINT NOT NULL, PRIMARY KEY (ID)) ENGINE=[*]INNODB "; expected "identifier"; SQL statement: 
create table user_session (id bigint not null auto_increment, version bigint not null, last_seenip varchar(255) not null, last_seen_time datetime not null, last_seenurl varchar(255) not null, last_seen_user_agent varchar(255) not null, session_token_hash varchar(255) not null, user_id bigint not null, primary key (id)) ENGINE=InnoDB [42001-147]

它被设置为使用create-drop模式下的临时内存H2数据库。

+0

不知道这是否是问题,但我试图远离“我的域名中的”用户“和”会话“这样的”常用“单词,因为它们可能具有某种受保护的grails行为,甚至可能有一些保留用途在H2中。 – Mikey 2012-04-17 16:50:44

回答

6

我使用了错误的方言;我DataSource.groovy中有以下方言集的数据源块:

dialect = "org.hibernate.dialect.MySQL5InnoDBDialect" 

我添加以下行的发展数据来源:

dialect = "org.hibernate.dialect.H2Dialect" 

这已经解决了这一问题。