mysql - 带有子查询的 SQL 查询

标签 mysql sql subquery mysql-dependent-subquery

我的数据是这样的:

data1_qqq_no_abc_ccc
data1_qqq_abc_ccc
data2_qqq_no_abc_ccc
data2_qqq_abc_ccc
data3_qqq_no_abc_ccc
data4_qqq_no_abc_ccc
data4_qqq_abc_ccc

...

现在我想获取数据具有子字符串 _no_abc_ccc 但没有 _abc_ccc 的字段。在上面的例子中,它的data3

我正在尝试为它创建一个查询。 粗略的是

select SUBSTRING_INDEX(name, 'abc', 1)  
from table1 
where SUBSTRING_INDEX(name, 'abc', 1) not LIKE "%no" 
  and NOT IN (select SUBSTRING_INDEX(name, '_no_abc', 1) 
              from table 
              where name LIKE "%no_abc");

最佳答案

像这样(?)

create table t (
    col text
);

insert into t
values
('data1_qqq_no_abc_ccc'),
('data1_qqq_abc_ccc'),
('data2_qqq_no_abc_ccc'),
('data2_qqq_abc_ccc'),
('data3_qqq_no_abc_ccc'),
('data4_qqq_no_abc_ccc'),
('data4_qqq_abc_ccc');

select f from (
    select SUBSTRING_INDEX(col, '_', 1) as f, SUBSTRING_INDEX(col, '_', -3) as s from t
) tt
group by f
having 
count(case when s = 'no_abc_ccc' then 1 end) > 0
and
count(case when s like '%qqq_abc%' then 1 end)  = 0

demo

关于mysql - 带有子查询的 SQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52504612/

相关文章:

mysql - 合并两个包含 JOIN 的 SELECT

java - 从 MySql 数据库检索 JCombobox 值

mysql - vb mysql编码为希伯来语

sql - 在 SQL 中,在 OR 中使用括号是什么意思?

对部分列数据进行 SQL 联接 (SQL Server)

java - 刷新 hibernate 公式

java - JPA/JPQL JOIN 子选择/子查询

mysql - 输出排序不正确

SQL 检查约束

mysql - SUM 使用子查询