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

oracle 提取 sql中的表名

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

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • 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、然后用子查询语句重复上面的过程就可以了
    点赞 评论
  • jingluan666 2020-07-27 12:59
    点赞 评论

相关推荐 更多相似问题