[发明专利]一种数据库的适配装置、装置、计算机设备和存储介质在审
申请号: | 202110809343.2 | 申请日: | 2021-07-17 |
公开(公告)号: | CN113407547A | 公开(公告)日: | 2021-09-17 |
发明(设计)人: | 傅金波;李成棋 | 申请(专利权)人: | 广州汇思信息科技股份有限公司 |
主分类号: | G06F16/22 | 分类号: | G06F16/22;G06F16/242 |
代理公司: | 广州本诺知识产权代理事务所(普通合伙) 44574 | 代理人: | 许柏松 |
地址: | 510000 广东省广州市天河*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 数据库 配装 装置 计算机 设备 存储 介质 | ||
本发明实施例提供了一种数据库的适配装置、装置、计算机设备和存储介质,包括:源代码修改模块,用于修改shardingjdbc框架组件源代码;新增扩展模块,用于应用能加载特定数据库的数据元;集成shardingjdbc,sql经过shardingjdbc,shardingjdbc通过配置策略改写sql到分库分表去执行,分库分表技术方案对数据库的支持,单库(表)的数据量得以减少,提高性能,提高了系统的稳定性和负载能力,切分出的表结构相同,程序改动较少,拆分后业务清晰,达到专库专用,可以实现热数据和冷数据的分离,将不经常变化的数据和变动较大的数据分散再不同的库/表中,便于维护。
技术领域
本发明涉及计算机技术领域,特别是涉及一种数据库的适配装置、一种计算机设备和一种存储介质。
背景技术
现有数据库的多种多样,对用户而言,根据自身需求,选择使用合适的数据库是十分必要的;就使用而言,不同数据库间存在很大的差异性是非常大的,如语法之间的差异、使用方式之间的差异等。当用户需要使用多种数据库进行系统开发,在对数据进行读写操作时,需要保证不同数据库间的数据一致性,不然会导致访问缓慢、排队等问题,同时也使得不同数据库之间的数据同步缓慢。
发明内容
鉴于上述问题,提出了本发明实施例以便提供一种克服上述问题或者至少部分地解决上述问题的一种数据库的适配装置、一种计算机设备和一种存储介质。
为了解决上述问题,本发明实施例公开了一种数据库的适配装置,包括:
源代码修改模块,用于修改shardingjdbc框架组件源代码;
新增扩展模块,用于应用能加载特定数据库的数据元。
优选地,所述源代码修改模块包括:
第一修改子模块,用于、使其能加载到dm的数据元信息,支持特定数据库的子查询语句;
第二修改子模块,用于使其能通过分表条件找到逻辑表;
第三修改子模块,用于使其能根据sql条件找到路由后的表;
第四修改子模块,用于其支持非分表数据的正常归并。
优选地,所述新增扩展模块包括:
第一扩展子模块,用于通过DMDatabaseMetaDataDialectHandler采用spi方式扩展DatabaseMetaDataDialectHandler;
第二扩展子模块,用于通过DMDatabaseType以spi方式扩展BranchDatabaseType,新增一种数据库类型;
第三扩展子模块,用于通过DMDataSourceMetaData以spi方式扩展DataSourceMetaData支持扩展的数据库数据源数据加载。
本发明实施例公开了一种计算机设备,包括存储器和处理器,所述存储器存储有计算机程序,所述处理器执行所述计算机程序时实现上述的数据库的适配装置的对应步骤。
本发明实施例公开了一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现上述的数据库的适配装置的对应步骤。
本发明实施例包括以下优点:
本发明实施例中,web应用数据库操作,sql先通过java jdbc到达数据库执行,集成shardingjdbc,sql经过shardingjdbc,shardingjdbc通过配置策略改写sql到分库分表去执行,分库分表技术方案对国产化数据库的支持,单库(表)的数据量得以减少,提高性能,提高了系统的稳定性和负载能力,切分出的表结构相同,程序改动较少,拆分后业务清晰,达到专库专用,可以实现热数据和冷数据的分离,将不经常变化的数据和变动较大的数据分散再不同的库/表中,便于维护。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于广州汇思信息科技股份有限公司,未经广州汇思信息科技股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110809343.2/2.html,转载请声明来源钻瓜专利网。