oracle 中一个字段存储的sql语句,现在要将sql中的表名取出,
本来准备用正则进行匹配,
但有个麻烦的问题,from后的表是用逗号隔开,并且其中一个表是用sql子查询的形式作为表存在的,这样就不好取了, 有好方法的话可以追加币
oracle 提取 sql中的表名
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
5条回答 默认 最新
- i__0o0__ 2020-07-24 17:30关注
- 1、直接用string的indexOf("from"),得到第一个form出现的位置
- 2、取sql字符串,保留form后面的字符串
- 3、用新变量暂存from后面的字符串,然后继续操作
- 4、将from后面的字符串一个字符一个字符的截取,然后比较是不是空格,如果是空格,说明前面已经是一个完整的单词,比较该单词是不是where,如果是,return
- 5、不是就比较是不是逗号,如果是逗号,说明前面的已经是一个完整表名,截取就行了
- 6、如果不是逗号,比较是不是左括号,如果是左括号,就用一个变量记录左括号的个数,然后记下这个字符位置,继续截取字符,接下来只比较是不是左括号和右括号,如果是左括号,就将记录的左括号数加1,如果是右括号,就将记录的左括号的个数减一, 当记录的个数为0时,将前面的字符截取下来,就是你的子查询语句了,将这个子查询语句存到一个集合里
- 7、然后继续前面的字符比较,直到比较到where单词时结束,你就可以得到主查询语句的表名和作为表的子查询语句
- 8、然后用子查询语句重复上面的过程就可以了
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 idea自动补全键位冲突
- ¥15 iis10中如何阻止别人网站重定向到我的网站
- ¥15 滑块验证码移动速度不一致问题
- ¥15 定制ai直播实时换脸软件
- ¥100 栈回溯相关,模块加载后KiExceptionDispatch无法正常回溯了
- ¥15 Utunbu中vscode下cern root工作台中写的程序root的头文件无法包含
- ¥15 麒麟V10桌面版SP1如何配置bonding
- ¥15 Marscode IDE 如何预览新建的 HTML 文件
- ¥15 K8S部署二进制集群过程中calico一直报错
- ¥15 java python或者任何一种编程语言复刻一个网页