数据库A,列名:aa为操作任务,列名bb为操作步骤, bb的第一条数据为: 理工站,拉开2019K11刀闸,检查2018装设GH78刀闸在拉开; 第二条数据为: 广泰是的购物车站点,断开KV母线1M开关,检查KV母线1M开关在分闸; 用PGsql查看同一个“操作任务”的“操作步骤”中, "断开"和"开关"之间的内容 与其后面的"检查"和"开关在分闸"之间的内容一致
时间: 2024-03-13 16:45:31 浏览: 49
可以使用以下SQL语句来查询同一个“操作任务”的“操作步骤”中, "断开"和"开关"之间的内容 与其后面的"检查"和"开关在分闸"之间的内容一致的数据:
```
SELECT aa, bb
FROM 数据库A
WHERE aa IN (
SELECT aa
FROM 数据库A
WHERE bb LIKE '%断开%开关%'
GROUP BY aa
HAVING COUNT(DISTINCT SUBSTRING(bb, CHARINDEX('断开', bb)+2, CHARINDEX('开关', bb)-CHARINDEX('断开', bb)-2)) = 1
)
AND bb LIKE '%断开%开关%'+ SUBSTRING(bb, CHARINDEX('断开', bb)+2, CHARINDEX('开关', bb)-CHARINDEX('断开', bb)-2) + '%检查%开关在分闸%'
```
其中,`SUBSTRING(bb, CHARINDEX('断开', bb)+2, CHARINDEX('开关', bb)-CHARINDEX('断开', bb)-2)`用于提取出“断开”和“开关”之间的内容,`LIKE`和`%`用于模糊匹配对应的字眼。
相关问题
数据库A,列名:aa为操作任务,列名bb为操作步骤, bb的样例数据为: 理工站,拉开2019K11刀闸,检查2018装设GH78刀闸在拉开; 广泰是的购物车站点,断开KV母线1M开关,检查KV母线1M开关在分闸; 用PGsql查看同一个“操作任务”的“操作步骤”中, 当数据出现"断开XX开关"或"拉开XX刀闸"字眼时, 检查对应后面的"检查XX开关在分闸"或"XX刀闸在拉开"的字眼中的 XX和"断开XX开关"或"拉开XX刀闸"字眼中的XX名称是否一致。
可以使用以下SQL语句来查询同一个“操作任务”的“操作步骤”中出现的对应字眼中 XX 名称是否一致:
```
SELECT aa, bb
FROM 数据库A
WHERE aa IN (
SELECT aa
FROM 数据库A
WHERE bb LIKE '%断开%开关%' OR bb LIKE '%拉开%刀闸%'
GROUP BY aa
HAVING COUNT(DISTINCT SUBSTRING(bb, 3, CHARINDEX('开关', bb)-3)) = 1
)
AND (bb LIKE '%断开%开关%' OR bb LIKE '%拉开%刀闸%')
AND bb LIKE '%检查%'+ SUBSTRING(bb, 3, CHARINDEX('开关', bb)-3) + '%在%'+ SUBSTRING(bb, CHARINDEX('在', bb)+1, LEN(bb)-CHARINDEX('在', bb)-1) + '%'
```
其中,`SUBSTRING(bb, 3, CHARINDEX('开关', bb)-3)`用于提取出“断开/拉开”后面的XX名称,`SUBSTRING(bb, CHARINDEX('在', bb)+1, LEN(bb)-CHARINDEX('在', bb)-1)`用于提取出“检查”后面XX名称所在的位置,`LIKE`和`%`用于模糊匹配对应的字眼。
数据库A,列名:操作任务为操作任务,列名操作步骤为操作步骤, 操作步骤的第一条数据为: 理工站,拉开2019K11刀闸,检查2018装设GH78刀闸在拉开; 第二条数据为: 广泰是的购物车站点,断开KV母线1M开关,检查KV母线1M开关在分闸; 用PGsql查看"操作步骤"列中, "断开"和"开关"之间的内容 与后面的"检查"和"开关在分闸"之间的内容一模一样;
你可以使用如下的PGsql查询语句来查看操作步骤中, "断开"和"开关"之间的内容 与后面的"检查"和"开关在分闸"之间的内容是否完全一致:
```
SELECT *
FROM A
WHERE
操作步骤 ~ '断开.*开关.*检查.*开关在分闸';
```
这个查询语句会从你的A表中选择出所有操作步骤描述中包含"断开"和"开关"的步骤,以及包含"检查"和"开关在分闸"的步骤,并且这两个内容之间没有其他字符,然后将这些步骤输出到结果中,你可以查看这些步骤的内容是否完全一致。注意要把"A"替换成你的表名,"操作任务"和"操作步骤"替换成你的列名。
阅读全文