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

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 Stata链式中介效应代码修改
  • ¥15 latex投稿显示click download
  • ¥15 请问读取环境变量文件失败是什么原因?
  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错