有时候需要只grep出代码中引用到的所有的表(关键字为后缀_t),不包含其他的内容。例如:
grep _t *
xxx.cpp: “or exists (select 1 from xxx_t e where a.event_type_id = e.event_type_id))”,
xxx.cpp: “and not exists (select 1 from xxx_t e where a.event_type_id = e.event_type_id)”,
我们只想要的是关键字输出,预期结果:
xxx_t
xxx_t
问题解决的出处:StackOverflow
主要用到的grep选项
-o, –only-matching
Prints only the matching part of the lines.
-h, –no-filename
Never print filename headers (i.e. filenames) with output lines.
因此可以实现该功能的写法为:
grep -roh "\w*_t[ |,|$]" *|sort|uniq