grails创建程序_在Grails应用程序中为同一数据库使用单独的Postgres模式

grails创建程序

最近,我想使用相同的Postgres数据库,但将我的持久性层拆分为使用独立模式的独立组件。 其动机是促进模块化设计,分离关注点并阻止开发人员彼此绊倒。 垂直域模型可能很难实现,但并非不可能。

在我的购物应用程序中,我有一个用户组件,一个购物组件和一个产品组件。 现在,如果您使用单独的数据库,这将非常容易,但是有时在同一数据库中使用单独的模式将关注点分离是一件好事,因为使用同一数据库可以使灾难恢复,日志传送,复制等工作变得更加容易。

虽然我可以找到用于单独数据库的文档,但是发现很难找到Grails文档来建议我的特定问题- 使用Postgres时如何在使用同一数据库时使用单独的模式 。 所以这就是我最终做的方式。
这是我的datasource.groovy。

String db_url = "jdbc:postgresql://localhost:5432/testdb"
String usernameVar = "db_user"
String passwordVar = "db_secret"
String dbCreateVar = "update"
String dialect = "net.kaleidos.hibernate.PostgresqlExtensionsDialect"

dataSource_user {
    pooled = true
    jmxExport = true
    dialect = dialect
    driverClassName = "org.postgresql.Driver"
    username = usernameVar
    password = passwordVar
    url = platform_url
    dbCreate= "validate"
}

hibernate_user {
    cache.use_second_level_cache = false
    cache.use_query_cache = false
    cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' // Hibernate 3
    singleSession = true // configure OSIV singleSession mode
    default_schema = "user"
}

dataSource_shopping {
    pooled = true
    jmxExport = true
    dialect = dialect
    driverClassName = "org.postgresql.Driver"
    username = usernameVar
    password = passwordVar
    url = platform_url
    dbCreate = "validate"
}

hibernate_shopping {
    cache.use_second_level_cache = false
    cache.use_query_cache = false
    cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' // Hibernate 3
    singleSession = true // configure OSIV singleSession mode
    default_schema = "shopping"
}

dataSource_product {
    pooled = true
    jmxExport = true
    dialect = dialect
    driverClassName = "org.postgresql.Driver"
    username = usernameVar
    password = passwordVar
    url = platform_url
    dbCreate= "validate"
}

hibernate_product {
    cache.use_second_level_cache = false
    cache.use_query_cache = false
    cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' // Hibernate 3
    singleSession = true // configure OSIV singleSession mode
    default_schema = "product"
}

注意:上面的配置中有一些明显的优化,但是以上只是使解释变得简单。

然后,我将每个GORM对象映射到适当的架构。

class Cart {
    // ...
    // ...
    static mapping = {
        datasource 'shopping'
        // ... 
    }
}

class Address {
    // ...
    // ...

    static mapping = {
        datasource 'user'
    }
}

class Stock {
    // ...
    // ...

    static mapping = {
        datasource 'product'
    }
}

然后,我启动了我的应用程序,并说“是的,这有效”,稍作休息,转到下一个问题。 可以看出,诀窍是使用单独的Hibernate闭包,在其中指定架构,并对单独的数据库使用相同的命名格式为闭包命名,但是使数据库闭包指向同一数据库。

翻译自: https://www.javacodegeeks.com/2015/06/using-separate-postgres-schemas-for-the-same-database-in-a-grails-app.html

grails创建程序

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值