WedX - журнал о программировании и компьютерных науках

Требуется SQL-запрос для поиска родительских записей без дочерних записей

Я совершенно не разбираюсь в SQL, поэтому надеялся, что кто-то может помочь мне с запросом, который найдет все записи в родительской таблице, для которой нет записей в дочерней таблице.

Следующее работает для меня, чтобы найти родительские записи для определенных значений дочерних полей ...

`SELECT    ParentTable.ParentID
 FROM      ParentTable INNER JOIN
             ParentTable ON ParentTable.ParentID = ChildTable.ChildID
 WHERE     (ChildTable.ChildField_ = '2131')
 Group By
   ParentTable.ParentID
 Having
   count(distinct ChildTable.ChildField) > 0`

Могу ли я изменить предложение where, чтобы найти родителя с нулевым количеством дочерних записей.

Спасибо.

sql
27.07.2011

  • Разве вы не изменили > на = в пункте HAVING? 27.07.2011
  • user278859, если вы применяете простое внутреннее соединение, он не даст желаемый родительский идентификатор до тех пор, пока clouse (до того, как группа выполнит выполнение) ... так что вы должны либо использовать несуществующее, либо левое или правое соединение, как предлагает phil ... @zerkms : - тогда вы не получите никаких записей после того, как поставите там подпись `=` 27.07.2011
  • Я не понимаю того факта, что вышеупомянутый вопрос получил так много голосов 12.01.2019

Ответы:


1

Вы можете использовать предложение NOT EXISTS для этого

SELECT ParentTable.ParentID
FROM ParentTable
WHERE NOT EXISTS (
    SELECT 1 FROM ChildTable
    WHERE ChildTable.ParentID = ParentTable.ParentID
)

Также есть старый подход левое соединение и проверка на null

SELECT ParentTable.ParentID
FROM ParentTable
LEFT JOIN ChildTable
  ON ParentTable.ParentID = ChildTable.ParentID
WHERE ChildTable.ChildID IS NULL

Попробуйте оба варианта и посмотрите, какой из них вам больше подходит.

27.07.2011

2

Внешнее соединение родителя с потомком, а затем счетчик (*) = 0.

select
  p.parent_id,
  count(*)
from
  parent p left outer join child c on p.parent_id = c.parent_id
group by
  p.parent_id
having
  count(*) = 0
27.07.2011
  • в вопросе нужна запись для родителя, не имеющего дочернего элемента ... так что вы не изменили запрос на p.parent_id = c.parent_id* .. в оракуле такая же работа должна выполняться (+) и должна быть добавлена ​​в дочернюю таблицу (в этом случае) 27.07.2011
  • Да, внешнее соединение от родителя к потомку по-прежнему будет возвращать родителей, даже если детей нет - count (*) будет 0. 27.07.2011

  • 3

    В другом примере как

    Перечислить таблицу

        id: SERIAL
        name: TEXT
        enumerate_id: INT
    

    Все родители, у которых есть дети (все ветви дерева, даже корни, но без листьев!)

    SELECT id, name, enumerate_id
    FROM enumerate p
    WHERE EXISTS (
        SELECT 1 FROM enumerate c
        WHERE c.enumerate_id = p.id
    );
    

    Все дети, у которых нет детей (все листья дерева)

    SELECT id, name, enumerate_id
    FROM enumerate p
    WHERE NOT EXISTS (
        SELECT 1 FROM enumerate c
        WHERE c.enumerate_id = p.id
    );
    

    Обратите внимание, что изменяется только NOT СУЩЕСТВУЕТ

    Надеюсь, поможет

    11.01.2019

    4

    Вы можете попробовать NOT IN

    SELECT * FROM ParentTable WHERE ParentID NOT IN (SELECT DISTINCT ParentID FROM ChildTable)
    
    18.10.2018

    5

    Если вы выполните левое соединение для дочерней таблицы и просто скажете, где дочерний parentID имеет значение null.

    SELECT ParentTable.ParentID FROM ParentTable P
        Left Join ChildTable C on C.ParentID = P.ParentID
        WHERE C.Id IS NULL;
    
    11.12.2019

    6

    Я просто не понимаю, что делает предложение having в вашем запросе, поскольку я уже вижу, что вы говорите where ChildTable.ChildField_ = '2131', что уже означает, что у вас есть набор записей для дочернего поля 2131. Попробуйте выполнить следующий запрос, это будет означать, что если у родителя нет дочернего элемента в Childtable с полем 2131, тогда о / п то же самое.

         SELECT    ParentTable.ParentID
             FROM      ParentTable 
             Where ParentTable.ParentID NOT IN (Select ChildID 
            From ChildTable where
             ChildTable.ChildField_ = '2131')
    
    11.01.2019
    Новые материалы

    Как создать диаграмму градиентной кисти с помощью D3.js
    Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

    Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
    Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

    Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
    В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


    Для любых предложений по сайту: [email protected]