请教一个关于boost正则表达式的问题

qiuxin315 2014-08-29 08:13:00
(?<=(?:from|into|update|delete)\s+(?:\w+(?:\s*,\s*)?)?)\w+



这个是我想用来提取sql语句中表名的正则表达式,用正则表达式工具测试可以用,但是使用boost.regex说这个语法是正确。看来一下boost关于regex的说明,是支持?<=和?:操作的。

比如提取:
select * from table_name;

哪位熟悉boost库的高手指点一下。
或者使用其他语法来实现提取sql语句中表名的功能。
...全文
112 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
qiuxin315 2014-09-04
  • 打赏
  • 举报
回复
还是没有找到问题在哪,估计是不支持这种语法吧 不过通过其他方式解决了 使用这样的方式替换
	
         string strRegex = "(from|into|table|update)(\\s+)(\\w+)";
	string strNew = "$1$2" + strNewTableName;
	string newSql = boost::regex_replace(strTest,strRegex,strNewTableName);
qiuxin315 2014-08-29
  • 打赏
  • 举报
回复
不是转义的问题
  • 打赏
  • 举报
回复
转义字符没写明白吧

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧