jfinal与postgresql整合实现多scheme

第一次写博客,瞎折腾一下。 无聊玩了一下jfinal,用的是postgresql。postgresql属于多scheme数据库,然而jfinal对这个支持并不好。 默认的public schema的表都可以正常使用。其他的GG了。然后上网查询到可以通过设置search path可以解决这个问题。

postgres=# alter role user_name set search_path = your_schema,public; 

就这样执行一下,确实没错,问题解决了。 那么新的问题来了,这里只是设置了搜索优先级,要是有两个scheme中出现了两张名字一样的表。那么默认会找到优先级高的scheme。 自己想方法解决,于是把 addMapping("tableName", User.class); 写成 addMapping("schemeName.tableName", User.class); 然而问题并没有这么简单 报错,提示找不到表schemeName.tableName 通过debug发现,生存查询sql时自动在表名两端加了双引号,所以这里的写法是不起任何作用的。 于是改成 addMapping("schemeName"."tableName", User.class); 再次测试,既然可以了。 随后重写了ActiveRecordPlugin类,加入了两个方法。 如图

这样就完美支持了postgresql的多scheme了。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值