第一次写博客,瞎折腾一下。 无聊玩了一下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