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 extends ActiveRecordPlugin {
    public MyActiveRecordPlugin(String configName, DataSource dataSource, int transactionLevel) {
        super(configName, dataSource, transactionLevel);
    }

    public MyActiveRecordPlugin(DataSource dataSource) {
        super(dataSource);
    }

    public MyActiveRecordPlugin(String configName, DataSource dataSource) {
        super(configName, dataSource);
    }

    public MyActiveRecordPlugin(DataSource dataSource, int transactionLevel) {
        super(dataSource, transactionLevel);
    }

    public MyActiveRecordPlugin(String configName, IDataSourceProvider dataSourceProvider, int transactionLevel) {
        super(configName, dataSourceProvider, transactionLevel);
    }

    public MyActiveRecordPlugin(IDataSourceProvider dataSourceProvider) {
        super(dataSourceProvider);
    }

    public MyActiveRecordPlugin(String configName, IDataSourceProvider dataSourceProvider) {
        super(configName, dataSourceProvider);
    }

    public MyActiveRecordPlugin(IDataSourceProvider dataSourceProvider, int transactionLevel) {
        super(dataSourceProvider, transactionLevel);
    }

    public MyActiveRecordPlugin(Config config) {
        super(config);
    }

    public ActiveRecordPlugin addMapping(String schemeName, String tableName, String primaryKey, Class<? extends Model<?>> modelClass) {
        if (schemeName==null || schemeName.isEmpty()) {
            return super.addMapping(tableName, primaryKey, modelClass);
        }
        return super.addMapping(schemeName+"\".\""+tableName, primaryKey, modelClass);
    }

    public ActiveRecordPlugin addMapping(String schemeName, String tableName, Class<? extends Model<?>> modelClass) {
        if (schemeName==null || schemeName.isEmpty()) {
            return super.addMapping(tableName, modelClass);
        }
        return super.addMapping(schemeName+"\".\""+tableName, modelClass);
    }
}

猜你喜欢

转载自my.oschina.net/u/3551926/blog/1548315