[发明专利]一种基于FMDB的SQL语句解析方法有效
申请号: | 201711042272.8 | 申请日: | 2017-10-31 |
公开(公告)号: | CN107832387B | 公开(公告)日: | 2021-07-13 |
发明(设计)人: | 郭艳杰 | 申请(专利权)人: | 北京酷我科技有限公司 |
主分类号: | G06F16/2453 | 分类号: | G06F16/2453;G06F16/242 |
代理公司: | 北京国标律师事务所 11753 | 代理人: | 姚克枫 |
地址: | 100080 北京市海淀区农大*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 基于 fmdb sql 语句 解析 方法 | ||
1.一种基于FMDB的SQL语句解析方法,其特征在于,包括如下步骤:
在FM接口层,创建一UserDBManager类,用于对用户数据库进行管理,
对用户数据库进行管理时,数据库中每个表分别创建一个管理类,且类名不同;
或者:对用户数据库进行管理时,UserDBManager类,作为一个大类,抽象管理类的共有内容,然后基于UserDBManager类,生成若干子类,每个子类一对一的管理数据库中某一个表;
所述UserDBManager类生成一个对象并调用方法:AllModel(),该方法内部调用FMDB封装函数:
表函数,用于指定table相关信息,所述table指用户数据库中的表,
操作函数,用于指定待执行的操作相关信息,
附加函数,用于指定附加条件信息,
经过FMDB封装函数传入参数后,对参数进行如下解析:
将表函数解析为table赋值语句;
将操作函数解析为列选择语句;
将附加函数解析为附加条件语句;
当以上封装函数对应的参数接收并解析完毕后,UserDBManager类通过commit指令将解析结果封装,然后调用SQL执行相应操作,其中:
UserDBManager类调用相关算法将解析结果组装成标准的SQL语句,组装完毕的标准的SQL语句,返回给UserDBManager类,UserDBManager类将接收到的组装完毕的标准的SQL语句,作为字符串通过commit指令封装。
2.如权利要求1所述的基于FMDB的SQL语句解析方法,其特征在于:所述附加条件信息与待执行的操作相关,包括但不限于:WHERE语句,ORDERBY语句,LIMIT数量限制语句。
3.如权利要求1所述的基于FMDB的SQL语句解析方法,其特征在于:所述table相关信息,包括但不限于:表名称。
4.如权利要求1所述的基于FMDB的SQL语句解析方法,其特征在于:所述操作相关信息包括:操作关键词及操作对象,
所述操作关键词包括:select关键词,create关键词,insert关键词,update关键词,add关键词,remove关键词,execute关键词,
所述操作对象包括:表对象table,行对象row,数组对象array。
5.如权利要求1所述的基于FMDB的SQL语句解析方法,其特征在于:所述字符串通过commit指令封装后作为params参数的值调用SQL执行相应操作,其中:
调用SQL执行相应操作时,首先将标准的SQL语句存储到FM执行层的DBQueue队列,
在FM执行层中,通过executeQuery()方法来执行操作以查询数据库,得到查询结果resultSet,
最后,将查询结果resultSet通过KWSqlResult参数返回给FM接口层;
所述查询结果resultSet进行统一格式化,以便于后续解析,查询结果resultSet中至少包括以下数据:
成功标志位success,用于标志SQL执行的结果,
多数据位rows,用于存储包括多个数据的查询结果,
单数据位id,用于存储包括一个数据的查询结果,
计数位num,用于存储包括统计数据的查询结果。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于北京酷我科技有限公司,未经北京酷我科技有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201711042272.8/1.html,转载请声明来源钻瓜专利网。