0

只是试图保持 GORM 实体之间的关系,并且在保存期间在映射上附加溢出错误。

1)我在用户和数据存储之间创建了一个manyTomany关系:

User entity: 
...
static belongsTo = DataStore
    static hasMany = [groups: Groups,dataStore:DataStore]

    Profile profile
    Contacts contact
    DataStore dataStore
...

DataStore entity:
...
static belongsTo = [service:Service]
    static hasMany = [users:User]

    Service service
    List<User>   users
...

2)从控制器调用服务以保存数据:

 UserRole.create user, roleCustomer, true
        UserRole.create user, roleAdmin, true
        dataStoreService.createDS('ds',profile.service,user)

3)服务逻辑:

 @Transactional
    def createDS(ds,service,user) {
        def key = service.domainkey
        if (user && key) {
            DataStore ds = new DataStore(ds:ds)
            ds.validate() ? ds.save(flus:true) : ds.errors.allErrors.println()
            ds.addToUsers(user).save(flush:true)
            service.addToDataStore(ds).save(flush:true)
            user.setDataStore(ds)
...}

4)我需要解决的奇怪错误:

Stacktrace 如下:org.codehaus.groovy.grails.web.servlet.mvc.exceptions.ControllerExecutionException:执行控制器 [$$.StoreController] 的操作 [sendOrder] 导致异常:在 grails.plugin.cache.web 执行操作时出现运行时错误。 filter.PageFragmentCachingFilter.doFilter(PageFragmentCachingFilter.java:195) 在 grails.plugin.cache.web.filter.AbstractFilter.doFilter(AbstractFilter.java:63) 在 net.bull.javamelody.JspWrapper.invoke(JspWrapper.java:149)在 net.bull.javamelody.JdbcWrapper$DelegatingInvocationHandler.invoke(JdbcWrapper.java:259) 在 net.bull.javamelody.MonitoringFilter.doFilter(MonitoringFilter.java:202) 在 net.bull.javamelody.MonitoringFilter.doFilter(MonitoringFilter.java :175) 在 java.util.concurrent 的 java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)。ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918) at java.lang.Thread.run(Thread.java:680) 原因:org.codehaus.groovy.grails.web.servlet.mvc.exceptions.ControllerExecutionException: 运行时错误执行动作... 9 更多原因:java.lang.reflect.InvocationTargetException ... 9 更多原因:org.apache.commons.validator.EmailValidator.stripComments(EmailValidator.java:246) 的 java.lang.StackOverflowError org.apache.commons.validator.EmailValidator.isValid(EmailValidator.java:95)StackOverflowError at org.apache.commons.validator.EmailValidator.stripComments(EmailValidator.java:246) at org.apache.commons.validator.EmailValidator.isValid(EmailValidator.java:95)StackOverflowError at org.apache.commons.validator.EmailValidator.stripComments(EmailValidator.java:246) at org.apache.commons.validator.EmailValidator.isValid(EmailValidator.java:95)

请问有什么帮助吗?

4

3 回答 3

1

编辑

再次查看堆栈跟踪后,问题与 Melody 无关(也许?也许不是?)但让我们知道出了什么问题)。

检查用户的电子邮件参考(不确定它位于哪个子域类,可能是联系类?打印它或使用调试器检查域值,然后仔细检查您的约束)。如果电子邮件问题与您的域类无关,请再次仔细检查旋律...

org.apache.commons.validator.EmailValidator.isValid(EmailValidator.java:95)....

-- 仍然仔细检查 Melody 正在做什么。

如果问题与 Melody 有关,请告知我们,仅用于个人信息。我从使用该插件的人那里看到了很多随机问题,它看起来很有用但有问题。

于 2013-04-30T16:11:50.527 回答
0

dataStore您定义了两次变量:一次在您的hasMany和一次作为直接参考。

尝试:

User entity: 
...

static belongsTo = [datastore: DataStore]

static hasMany = [groups: Groups,dataStores:DataStore]

Profile profile
Contacts contact

...
于 2013-04-30T15:57:41.617 回答
0

只需按照休眠文档重做我的模型:

class User implements Serializable {

    static hasMany = [dataStores:DataStore,contacts:Contacts,groups: Groups]

    Profile profile
    Contacts contacts
    List<DataStore> dataStores

有约束:dataStores nullable:true

和 DS 实体:

class DataStore implements Serializable{

    static hasMany = [users:User,contacts:Contacts]
    static belongsTo = [service:Service]

    Service service
    User users

明确地删除几个溢出并保持模型可靠。

于 2013-05-01T18:30:24.007 回答