当前位置: 首页 > news >正文

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()函数

http://www.lryc.cn/news/323363.html

相关文章:

  • YOLOV9训练自己的数据集
  • UG NX二次开发(C++)-CAM-获取加工操作的四种方法
  • python共享单车信息系统的设计与实现flask-django-php-nodejs
  • Python之Web开发中级教程----Django站点管理
  • Spring Boot项目中使用MyBatis连接达梦数据库6
  • Matlab快捷键与函数
  • 接雨水-热题 100?-Lua 中文代码解题第4题
  • JVM内存溢出排查
  • Leetcode 200. 岛屿数量
  • 多线程基础 -概念、创建、等待、分离、终止
  • 【Vue3】走进Pinia,学习Pinia,使用Pinia
  • 【TB作品】430单片机,单片机串口多功能通信,Proteus仿真
  • 【C++ leetcode】双指针问题
  • Kubernetes集群部署
  • 深拷贝与浅拷贝
  • golang学习网址
  • 2024学习鸿蒙开发,未来发展如何?
  • 3.21Code
  • 学习总结2
  • 【LeetCode】--- 动态规划 集训(一)
  • 【数据结构与算法】(18):树形选择排序:按照锦标赛的思想进行排序
  • 统计单词数
  • c++pair的用法
  • 石油炼化5G智能制造工厂数字孪生可视化平台,推进行业数字化转型
  • IP代理技术革新:探索数据采集的新路径
  • 流畅的 Python 第二版(GPT 重译)(一)
  • Vue+jquery+jquery.maphilight实现图片热区高亮以及点击效果
  • 靠谱!朋友圈一键转发和自动转发好友朋友圈
  • 线性顺序表算法库
  • java分割等和子集(力扣Leetcode416)