问题一:shardingsphere.dialect.exception.syntax.database.UnknownDatabaseException
解决:
jdbcTemplate 类注入有问题,如:
1)如果使用@Resource注解引入该类时,变量名需要与初始化时@Bean修饰的方法名相一致。
2)如果使用@Autowired注解引入该类时,可使用@Autowired的属性,指定name为初始化的bean名称。
备注:这里的jdbcTemplate初始化时使用的数据源必须时shardingsphere管理的datasoure,否则如果涉及加密字段查询,加密字段查询出后不会被解密。
问题二:shardingsphere,parse异常
解决:
情况一:表中可能包含数据库关键字,如count,level
1)如果是jpa查询,即无显示sql的查询,可在表字段column注解中给列名加中括号
2)如果是显示sql查询,可使用双引号("")来包裹关键字,注意需要反斜杠来配合使用,如:t.\"level\"
情况二:初始化数据源连接信息时,使用了hibernate的一些sql相关的处理,与sharding的冲突了,导致生成的sql包含了异常信息,
如:
private Properties additionalProperties() {
Properties properties = new Properties();
properties.setProperty("hibernate.dialect", dialect);
properties.setProperty("hibernate.default_scheme", defaultScheme);
// 问题1:这里的配置会覆盖掉sharding的sql日志打印逻辑,只展示hibernate的sql日志
// properties.setProperty("hibernate.show_sql",showSql);
// properties.setProperty("hibernate.format_sql",formatSql);
// 问题2:hibernate.use_sql_comments 配置可能导致生成的sql多了双引号,导致sharding解析sql异常
// properties.setProperty("hibernate.use_sql_comments",useSqlComments);
return properties;
}
因此在sharding+jpa的项目中,hibernate的这三个配置需要关闭
问题三:多表关联查询,包含嵌套查询的sql,在sharding的环境下生成的sql出现了缺少某些sql语句或单词的问题。
解决:
在内部的嵌套查询中尽量不要提前设置字段别名,可以在最外层的select,sql中再设置别名
问题四:jpa查询,报了Unknown source
解决:
sql中 current_date()函数,改为curdate()函数