达梦JAVA程序指定访问模式(模式名含有特殊字符的处理)

1> 问题:

最近在项目中迁移中遇到了一个问题,SpringBoot的项目使用的达梦数据库,我们为平台下的每个子系统都建立了相应的账号,这样子系统中的程序使用该账号登录时,默认都是读取自己模式(schema)下的表,sql中也不需要使用模式名.对象名的方式进行访问。而最近涉及到数据库迁移,平台我们使用了一个大的账号,所有子系统通过这个账号访问自己模式下的数据。然而登录账号默认是读取当前账号的默认模式,这样在不修改sql的情况下,我们必须要指定每个子系统访问的模式,这样的修改肯定是不切实际的。

2> 官方给出的方案:

达梦技术文档:https://eco.dameng.com/docs/zh-cn/faq/faq-java.html

在我查看达梦技术文档的时候,发现官方有这样的一条解达:

在这里插入图片描述

3> 实际使用中发现问题:

然而我们的用户名包含了一些特殊符号,类似于XXX-这样,加了统一的前缀,当构造出这样的url连接串时jdbc:dm://192.168.15.35:5236?schema=XXX-XXX,程序启动时总是报连接异常或者未识别的符号[-]
在这里插入图片描述

于是乎我换了一个测试库,类似于上面的TEST2这样的,程序启动成功了。那看来是因为特殊字符的原因了,首先我尝试着使用转义字符%2D,然后还是没识别出来;再然后既然是达梦没识别出来,那我用达梦的转字符""双引号包起来,结果还是启动报错;尝试了很多遍,也查阅了很多资料也没有找到方案,偶然中我想到是不是因为双引号被忽略掉了,那我再加一层试试,也就是这样jdbc:dm://192.168.15.35:5236?schema=""XXX-XXX"",结果成功了,也访问到了正确的表。暂时还不清楚这样写的原因,后面再深入研究吧。

总结

①达梦中如果想登录后访问其他模式下的表(非默认模式),可以在jdbc连接串中用schema=模式名的方式。

②如果模式名含有特殊字符的,需要将模式名用两层双引号包起来,即:schema=""模式名""这样的方式。

  • 6
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值