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

1> 问题:

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

2> 官方给出的方案:

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

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

达梦JAVA程序指定访问模式(模式名含有特殊字符的处理)_第1张图片

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

然而我们的用户名包含了一些特殊符号,类似于XXX-这样,加了统一的前缀,当构造出这样的url连接串时jdbc:dm://192.168.15.35:5236?schema=XXX-XXX,程序启动时总是报连接异常或者未识别的符号[-]
达梦JAVA程序指定访问模式(模式名含有特殊字符的处理)_第2张图片

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

总结

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

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

你可能感兴趣的:(SpringBoot,java,达梦)