[发明专利]用于验证数据库系统正确性的方法和装置无效

专利信息
申请号: 201010624761.6 申请日: 2010-12-30
公开(公告)号: CN102541966A 公开(公告)日: 2012-07-04
发明(设计)人: 周祥;杨新颖;陈东升;刘沭华;贾焱;魏可伟;周婧 申请(专利权)人: 国际商业机器公司
主分类号: G06F17/30 分类号: G06F17/30
代理公司: 北京市中咨律师事务所 11247 代理人: 于静;杨晓光
地址: 美国*** 国省代码: 美国;US
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 用于 验证 数据库 系统 正确性 方法 装置
【权利要求书】:

1.一种用于验证数据库系统的正确性的方法,包括:

接收结构化查询SQL指令;

扩展所接收到的SQL指令的访问路径;

利用所述扩展的访问路径执行所述SQL指令;以及

根据执行所述SQL指令的结果验证数据库系统的正确性。

2.如权利要求1所述的方法,其中扩展所接收到的SQL指令的访问路径包括:

获取组成所述SQL指令的访问路径的元素;以及

组合所述元素的可能取值以生成扩展的访问路径。

3.如权利要求2所述的方法,进一步包括:

根据访问路径中的元素的权重值以及历史错误信息,计算所扩展的访问路径的权重值。

4.如权利要求3所述的方法,所述历史错误信息包括:在SQL指令执行出错的情况下,每个元素的各个可能的取值所占的比例。

5.如权利要求3或4所述的方法,其中利用所述扩展的访问路径执行所述SQL指令包括:

根据所计算得到的所扩展的访问路径的权重值,选择需要利用的所扩展的访问路径;以及

利用所选择的访问路径执行所述SQL指令。

6.如权利要求5所述的方法,其中根据所计算得到的所扩展的访问路径的权重值,选择需要利用的所扩展的访问路径是利用蒙特卡洛算法实现的。

7.如权利要求1-6任一所述的方法,其中根据执行所述SQL指令的结果验证数据库系统的正确性包括:

判断执行所述SQL指令的结果是否与之前的执行所述SQL指令的结果相同;以及

如果结果不同,则确定所述数据库系统存在错误。

8.一种用于验证数据库系统的正确性的系统,包括:

接收装置,用于接收结构化查询SQL指令;

访问路径扩展装置,用于扩展所接收到的SQL指令的访问路径;

执行装置,用于利用所述扩展的访问路径执行所述SQL指令;以及

验证装置,用于根据执行所述SQL指令的结果验证数据库系统的正确性。

9.如权利要求8所述的系统,其中访问路径扩展装置包括:

元素获取装置,用于获取组成所述SQL指令的访问路径的元素;以及

访问路径扩展装置,用于组合所述元素的可能取值以生成扩展的访问路径。

10.如权利要求9所述的系统,进一步包括:

访问路径选择装置,用于根据访问路径中的元素的权重值以及历史错误信息,计算所扩展的访问路径的权重值。

11.如权利要求10所述的系统,所述历史错误信息包括:在SQL指令执行出错的情况下,每个元素的各个可能的取值所占的比例。

12.如权利要求10或11所述的系统,其中执行装置被进一步配置为:

根据所计算得到的所扩展的访问路径的权重值,选择需要利用的所扩展的访问路径;以及

利用所选择的访问路径执行所述SQL指令。

13.如权利要求12所述的系统,其中执行装置被进一步配置为:利用蒙特卡洛算法选择需要利用的所扩展的访问路径。

14.如权利要求8-13任一所述的系统,其中验证装置被进一步配置为:

判断执行所述SQL指令的结果是否与之前的执行所述SQL指令的结果相同;以及

如果结果不同,则确定所述数据库系统存在错误。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于国际商业机器公司,未经国际商业机器公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201010624761.6/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top