weixin_42632763 2020-07-21 17:18 采纳率: 100%
浏览 393
已采纳

oracle 提取 sql中的表名

oracle 中一个字段存储的sql语句,现在要将sql中的表名取出,
本来准备用正则进行匹配,
但有个麻烦的问题,from后的表是用逗号隔开,并且其中一个表是用sql子查询的形式作为表存在的,这样就不好取了, 有好方法的话可以追加币

  • 写回答

5条回答 默认 最新

  • i__0o0__ 2020-07-24 17:30
    关注
    1. 1、直接用string的indexOf("from"),得到第一个form出现的位置
    2. 2、取sql字符串,保留form后面的字符串
    3. 3、用新变量暂存from后面的字符串,然后继续操作
    4. 4、将from后面的字符串一个字符一个字符的截取,然后比较是不是空格,如果是空格,说明前面已经是一个完整的单词,比较该单词是不是where,如果是,return
    5. 5、不是就比较是不是逗号,如果是逗号,说明前面的已经是一个完整表名,截取就行了
    6. 6、如果不是逗号,比较是不是左括号,如果是左括号,就用一个变量记录左括号的个数,然后记下这个字符位置,继续截取字符,接下来只比较是不是左括号和右括号,如果是左括号,就将记录的左括号数加1,如果是右括号,就将记录的左括号的个数减一, 当记录的个数为0时,将前面的字符截取下来,就是你的子查询语句了,将这个子查询语句存到一个集合里
    7. 7、然后继续前面的字符比较,直到比较到where单词时结束,你就可以得到主查询语句的表名和作为表的子查询语句
    8. 8、然后用子查询语句重复上面的过程就可以了
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

悬赏问题

  • ¥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或者任何一种编程语言复刻一个网页