shardingsphere+达梦+jpa项目改造适配中遇到的一些问题与解决

问题一: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()函数

相关推荐

  1. 数据库Springboot+MybatisPlus+数据库

    2024-03-22 20:46:03       56 阅读
  2. 项目当中使用JPA、Hibernate、MyBatis遇到

    2024-03-22 20:46:03       54 阅读
  3. nbsaas-bootjpa查询设计

    2024-03-22 20:46:03       42 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-22 20:46:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-22 20:46:03       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-22 20:46:03       82 阅读
  4. Python语言-面向对象

    2024-03-22 20:46:03       91 阅读

热门阅读

  1. 5.1.8、【AI技术新纪元:Spring AI解码】Anthropic Chat

    2024-03-22 20:46:03       42 阅读
  2. Matplotlib如何显示多张图片(管理多个子图)

    2024-03-22 20:46:03       39 阅读
  3. Eureka的数据同步和Nacos的Distro的区别

    2024-03-22 20:46:03       38 阅读
  4. c语言排序实验题

    2024-03-22 20:46:03       35 阅读
  5. 蓝桥杯刷题记录之数字王国之军训排队

    2024-03-22 20:46:03       39 阅读
  6. Uni-app开发介绍及入门

    2024-03-22 20:46:03       34 阅读
  7. CUDA学习笔记07:shared memory Code

    2024-03-22 20:46:03       46 阅读
  8. [C++提高编程](二):模板--类模板

    2024-03-22 20:46:03       47 阅读
  9. CCF软件能力认证202312-1——仓库规划

    2024-03-22 20:46:03       47 阅读
  10. 5.3、【AI技术新纪元:Spring AI解码】图像生成API

    2024-03-22 20:46:03       37 阅读