- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 SQL 语法创建一个关系数据库,该数据库将具有使用 Java 的命令行界面。为了解析用户命令,我使用正则表达式(我知道这是一个糟糕的主意 - 它比其他任何东西都更需要学习)
我使用以分号作为分隔符的扫描仪类,因此我不会在正则表达式中查找分号。这样它就可以处理多行输入。输入在与正则表达式匹配之前会被修剪,因此字符串开头和结尾的空格不是表达式的一部分。
我这里有这个正则表达式,它按照我想要的方式工作,直到我为 where 子句添加可选标志 -
select\s+(.*?)(?:\s+where(.*))
这将匹配(组以粗体显示)-
从*中选择a,其中x = 3
但是如果我将正则表达式更改为这样 -
select\s+(.*?)(?:\s+where(.*))?
它只匹配引用的部分 -
"select "a from * where x = 3
我的目标是让它匹配所有内容,直到单词“select”(包括空格字符)之后的字符串末尾,除非字符串“where”前后有任何空格字符。如果存在,则将单词“select”和“where”之间的每个字符分组,并将单词“where”之后的所有内容分组。
例如:如果输入此文本:
select a from * where b = 3
它应该将“a from * ”和“b = 3 ”分组。
但如果这是输入:
select a where x = 3
表名“a”应该是一个组,where 子句“x = 3”应该是一个组。
值得注意的是,我正在使用 java.util.regex - 它没有 Perl 正则表达式中的 if/else 子句,但组内带有 or 语句的前瞻可以达到相同的效果。我可以使用另一个支持 if/then/else 语句的库,但我不知道我可以使用它来实现我正在寻找的结果。
最佳答案
用正则表达式解析SQL与parsing HTML with regex没有太大区别。换句话说,它不会起作用。这是无望的任务,立即停止。
相反,使用一些 SQL 解析器。例如,SQL::Statement::Structure对于 Perl 或 ANTLR对于 Java。
此外,由于您正在创建自己的数据库,因此值得看看其他 SQL 实现是如何做到这一点的。我建议阅读 PostgreSQL 的源代码或MySQL并了解他们如何实现高级 SQL 解析。
关于java - 使用正则表达式 : Does adding the optional flag in a regex expression change how greedy or posessive modifiers are matched? 解析 SQL 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18604868/
我从未见过这样初始化的 for 循环,不明白为什么要这样写? 我正在研究如何连接到 .NET 中的 IMAP 服务器,并开始查看名为 ImapX 的库中的代码。 .我在将数据写入 NetworkStr
我正在尝试解析这个标志“dataroot”(字符串类型)。 将此视为演示代码: from absl import flags from absl.flags import FLAGS flags.DE
我想知道调用之间是否有任何区别(或可能的副作用): AtomicBoolean.set(true) 和 AtomicBoolean.compareAndset(false, true) AtomicB
这个问题已经有答案了: Do you prefer "if (var)" or "if (var != 0)"? [closed] (26 个回答) 已关闭 6 年前。 两者之间有性能差异吗 if (
在 TensorFlow 中解析标志的目的是什么?什么是 tf.flags.FLAGS?&此代码语句的作用是什么? FLAGS = tf.flags.FLAGS FLAGS._parse_flags(
面试题:if (flag==0) 和 if (0==flag) 哪个会执行得更快?为什么? 最佳答案 我还没有看到任何正确的答案(并且已经有一些)警告:Nawaz 确实指出了用户定义的陷阱。而且我很遗
在我的一个站点上,我有一个主用户表,其中包含每个用户的唯一用户 ID、电子邮件地址、密码等。 我需要开始跟踪很多与每个用户相关的二进制标志,比如他们是否确认了他们的电子邮件,他们是否发布了消息,他们是
我有以下辅助函数用于使用 argparse 解析参数: def get_cli_arguments(): parser = argparse.ArgumentParser(prog='Xtra
var a = 'toto titi (should be removed) 5'.replace(/\(.*\)|\[.*\]|[^a-zA-Z0-9 ]|tata|tutu|tyty/gi, '!
我是 Golang 的新手,我一直无法使用标志找到解决此问题的方法。 我如何使用标志以便我的程序可以处理这样的调用,其中 -term 标志可能出现可变次数,包括 0 次: ./myprogram -f
我收到以下有关此正则表达式模式的控制台警告:。我看不到如何为该警告创建有效的正则表达式模式。请问,有没有人能解释一下这个错误以及如何解决它?。已尝试查看文档,但看不到如何使其对v标志有效
嗨,这两者有什么区别 在 SQL Server 中set @flag=1 和set @@flag = 1? 谢谢 最佳答案 什么都没有。作为惯例,某些内置函数的名称以双 at 符号 @@ 开头。为了避
是否可以在不覆盖现有标志的情况下使用 java 邮件在 IMAP 邮件消息上设置自定义标志?例如,我需要在已处理消息上设置一个标志“已处理”,而不将其状态更改为 SEEN/DELETED 或没有邮件客
我对以下行为感到困惑。变量标志从 Controller 传递到jsp代码: flag: flag eq 'Y': ${requestScope.flag eq 'Y'} flag == 'Y': $
我正在尝试根据标志值构建一个字符串 return `${super.getDetails()} Electric: ${this.isElectric} ${flag && '|hatchback'}
此外,将它们直接列在相应标签的对面是否为调试和发布设置了它们? 最佳答案 Xcode 帮助提供了相当清晰的定义: Name: Other C Flags Abstract: Space-separat
当我在 android studio 中创建或克隆一个 flutter 项目时,它显示“创建项目时出错设置 VM 标志失败:无法识别的标志:disable-dart-dev” 我使用的是 Androi
我有一些Python argparse命令行处理代码,最初看起来像这样: import argparse ap = argparse.ArgumentParser() ap.add_argument(
我尝试创建一个多线程单例模式类。 标题: class HL{ public: static HL* getInstance(); ......... priva
我在阅读别人的代码时遇到了很多标志, if (condition1) var1 = true else var1 = false 后来, if (var1 == true) /
我是一名优秀的程序员,十分优秀!