[发明专利]一种基于SQL的分布式数据统一访问系统及方法有效
申请号: | 201910695813.X | 申请日: | 2019-07-30 |
公开(公告)号: | CN110688397B | 公开(公告)日: | 2022-05-17 |
发明(设计)人: | 邢志岩;刘元勋;王飞;王鑫 | 申请(专利权)人: | 民生科技有限责任公司 |
主分类号: | G06F16/2455 | 分类号: | G06F16/2455;G06F16/2458;G06F16/27;G06F16/28 |
代理公司: | 北京金智普华知识产权代理有限公司 11401 | 代理人: | 巴晓艳 |
地址: | 101300 北*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 sql 分布式 数据 统一 访问 系统 方法 | ||
1.一种基于SQL的分布式数据统一访问系统,其特征在于,用于银行支付系统的数据连接,所述SQL的分布式数据统一访问系统包括:
数据访问接口层,为应用程序提供统一的数据访问接口来访问不同类型的数据存储设备;
SQL解析器,用于SQL语法解析,从SQL语句中抽取出表名、字段以及字段的值,形成语法树;
SQL转换器,根据SQL语法解析生成的语法树,构造redis访问命令;
执行组件,用于执行SQL,返回执行结果记录集的记录;所述执行组件包括单笔执行组件和批量执行组件,所述单笔执行组件用于执行一次SQL只返回执行结果记录集的一条记录;所述批量执行组件用于执行一次SQL批量返回执行结果记录集的N条记录,N为大于1的整数;
ODBC组件,应用程序通过所述ODBC组件,能同时与多种数据库进行交互;
PayHiredis客户端,Payhiredis是在开源项目hiredis的基础上封装的一个redis数据库访问的C客户端,增加了对redis的主从模式的支持,能根据配置访问主服务器master或者从服务器slave,同时增加了自动重连机制;
连接管理器,用于执行数据库连接管理,管理所有数据存储的长连接以及执行连接切换。
2.如权利要求1所述的基于SQL的分布式数据统一访问系统,其特征在于,所述ODBC组件采用开源项目unixODBC。
3.一种基于SQL的分布式数据统一访问的方法,其特征在于,所述方法包括:
SQL语法解析:根据关键词把SQL语句划分为若干子句,并根据需要利用关键字对所述子句进行词法分析,从SQL语句中抽取出表名、字段以及字段的值,形成语法树;根据抽取的表名访问数据库的系统表得到表的唯一索引、主键信息;对于复杂的解析不出来的SQL语句,不再访问redis直接访问数据库;
数据源选择:根据所述SQL语法解析中获得的表名,在配置文件中查看表的访问位置,确定所述访问位置在数据库或redis;优先访问redis;所述数据源选择,在配置文件中每个表配置一条记录,其中tbName为表名,dbName为数据库名,redisFlag为redis服务器标识,redisFlag为“-1”表示该表不存在redis中;只要redisFlag不为-1,就优先访问redis而不访问数据库;若redisFlag为-1,则访问dbName指定的数据库;
redis访问:SQL转换器根据SQL语法分析生成的所述语法树,检查where条件是否满足主键或唯一索引要求,并构造redis访问命令;
数据库访问:通过使用ODBC组件,应用程序能与多种类型的数据库进行交互;
数据库连接管理:为每一个数据库连接保留一份独立的连接上下文环境,在所述连接上下文环境中包含了连接数据库的基本信息,所述连接数据库的基本信息包括数据库配置名称、数据库驱动名称、DNS、用户名、连接句柄;通过切换所述连接上下文环境完成数据库的切换。
4.如权利要求3所述的基于SQL的分布式数据统一访问的方法,其特征在于,所述redis访问中,redis访问命令的构造规则包含插入、删除、更新和查询规则。
5.如权利要求3所述的基于SQL的分布式数据统一访问的方法,其特征在于,设置PayHiredis客户端,提供方便访问redis的接口;Payhiredis是在开源项目hiredis的基础上封装的一个redis数据库访问的C客户端,增加了对redis的主从模式的支持,能根据配置访问master或者slave,同时增加了自动重连机制。
6.如权利要求3所述的基于SQL的分布式数据统一访问的方法,其特征在于,数据库访问时,同时提供单笔/批量操作数据库的接口,提高批量访问的效率。
7.如权利要求3-6任一项所述的基于SQL的分布式数据统一访问的方法,其特征在于,所述数据库连接管理,对于垂直拆分的数据库,根据SQL语句中的表名切换数据库连接达到访问不同的数据库的目的;对于水平拆分的数据库,根据数据库水平拆分的规则切换数据库连接达到访问不同的数据库的目的。
8.如权利要求3-6任一项所述的基于SQL的分布式数据统一访问的方法,其特征在于,所述数据库连接管理,增加自动重连机制,遍历所有连接上下文环境,判断数据库连接是否正常,若异常则关闭数据库再重新连接。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于民生科技有限责任公司,未经民生科技有限责任公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201910695813.X/1.html,转载请声明来源钻瓜专利网。
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置