목차
1. 테이블과 테이블을 비교하세요
데이터 베이스 MySQL 튜토리얼 SQL을 사용하여 작업 설정

SQL을 사용하여 작업 설정

Jun 04, 2018 am 09:29 AM
작업 지휘하다 모으다

이 기사에서는 특정 참조 값이 있는 집합 연산에 대한 SQL 사용을 주로 소개합니다. 이제 모든 사람과 공유합니다. 도움이 필요한 친구들이 참조할 수 있습니다

1. 테이블과 테이블을 비교하세요


두 테이블의 차이점을 직접 물어보세요

drop table if exists tbl_a;create table tbl_a(
key1 varchar(10),
col_1 int4,
col_2 int4,
col_3 int4
);insert into tbl_a values('A', 2, 3, 4);
insert into tbl_a values('B', 0, 7, 9);
insert into tbl_a values('c', 5, 1, 6);
drop table if exists tbl_b;create table tbl_b(
key1 varchar(10),
col_1 int4,
col_2 int4,
col_3 int4
);
insert into tbl_b values('A', 2, 3, 4);
insert into tbl_b values('B', 0, 7, 9);
insert into tbl_b values('c', 5, 1, 6);-- ## 如果union a b 行数一致则两张表相等 select count(1) row_cnt  from ( select * 
           from tbl_A           union 
          select *            from tbl_b
        ) tmp
;
로그인 후 복사

2. 차이 집합을 사용하여 관계형 나누기 연산을 구현합니다

테이블 만들기

(select * from tbl_a except
 select * from tbl_b) union all
 (select * from tbl_b  except
  select * from tbl_a);
로그인 후 복사
drop table if exists skills;create table skills(
skill varchar(10)
);insert into skills values('oracle');
insert into skills values('unix');insert into skills values('java');drop table if exists empskills;create table empskills(
emp varchar(10),
skill varchar(10)
);insert into empskills values('相田','oracle');
insert into empskills values('相田','unix');
insert into empskills values('相田','java');
insert into empskills values('相田','c#');
insert into empskills values('神奇','oracle');
insert into empskills values('神奇','unix');
insert into empskills values('神奇','java');
insert into empskills values('平井','oracle');
insert into empskills values('平井','unix');
insert into empskills values('平井','PHP');
insert into empskills values('平井','Perl');
insert into empskills values('平井','C++');
insert into empskills values('若田部','Perl');
insert into empskills values('度来','oracle');
로그인 후 복사

3. 동일한 하위 집합 찾기

--把除法变成减法select distinct emp  from empskills es1 where not exists
        (select skill from skills
         expect         select skill from empskills es2          where es1.emp = es2.emp);
로그인 후 복사

아이디어: 두 공급업체 모두 동일한 유형의 부품을 취급합니다(단순히 부품 열에 따라 연결). 두 공급업체의 부품 유형 수가 동일합니다(즉, 일대일 매핑이 있음)(개수 제한)

drop table if exists supparts;create table supparts(
sup varchar(10),
part varchar(10)
);insert into supparts values('A', '螺丝');
insert into supparts values('A', '螺母');
insert into supparts values('A', '管子');
insert into supparts values('B', '螺丝');
insert into supparts values('B', '管子');
insert into supparts values('C', '螺丝');
insert into supparts values('C', '螺母');
insert into supparts values('C', '管子');
insert into supparts values('D', '螺丝');
insert into supparts values('D', '管子');
insert into supparts values('E','保险丝');
insert into supparts values('E', '螺母');
insert into supparts values('E', '管子');
insert into supparts values('F','保险丝');
로그인 후 복사

4. 중복 행 삭제

select a.sup s1, b.sup s2  from supparts a, supparts b where a.sup < b.sup                       -- 生成供应商的全部组合 
   and a.part = b.part                     -- 条件1:经营同种类型的零件 
 group by a.sup, b.suphaving count(*) = (select count(1)         -- 条件2:经营的零件的数量种类相同 a = 中间数                     from supparts c                    where c.sup = a.sup)   and count(*) = (select count(1)         -- 条件2:经营的零件的数量种类相同 b = 中间数                     from supparts d                    where d.sup = b.sup)
;
로그인 후 복사

Exercise

drop table if exists products;create table products(
rowid int4,
name1 varchar(10),
price int4
);insert into products values(1,&#39;苹果&#39;,50);insert into products values(2,&#39;橘子&#39;,100);
insert into products values(3,&#39;橘子&#39;,100);insert into products values(4,&#39;橘子&#39;,100);
insert into products values(5,&#39;香蕉&#39;,80);-- 删除重行高效SQL语句(1):通过EXCEPT求补集delete from productswhere rowid  in (select rowid           -- 全部rowid                   from products 
                 except                 -- 减去                 select max(rowid)      -- 要留下的rowid                   from products                  group by name1, price
                  );-- 删除重行高效SQL语句(2):通过not indelete from products where rowid not in (select max(rowid)                      from products                     group by name1, price
                    );
로그인 후 복사

대부분의 내용 "SQL Advanced Textbook"에서 나온 것이므로 메모해 두세요. 연습문제의 일부 코드는 원본입니다.

위 내용은 SQL을 사용하여 작업 설정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Go 언어에서 컬렉션과 같은 기능을 구현하는 것이 왜 어려운가요? Go 언어에서 컬렉션과 같은 기능을 구현하는 것이 왜 어려운가요? Mar 24, 2024 am 11:57 AM

Go 언어에서는 컬렉션과 같은 기능을 구현하기가 어렵기 때문에 많은 개발자들이 고민하고 있습니다. Python이나 Java와 같은 다른 프로그래밍 언어와 비교할 때 Go 언어에는 집합, 맵 등과 같은 컬렉션 유형이 내장되어 있지 않아 개발자가 컬렉션 기능을 구현할 때 몇 가지 어려움을 겪습니다. 먼저 Go 언어에서 컬렉션과 유사한 기능을 직접 구현하는 것이 왜 어려운지 살펴보겠습니다. Go 언어에서 가장 일반적으로 사용되는 데이터 구조는 컬렉션과 유사한 기능을 완성할 수 있지만

Java 컬렉션 정렬 성능을 최적화하는 방법 Java 컬렉션 정렬 성능을 최적화하는 방법 Jun 30, 2023 am 10:43 AM

Java는 다양한 유형의 소프트웨어 개발에 널리 사용되는 강력한 프로그래밍 언어입니다. Java 개발에는 종종 컬렉션 정렬과 관련된 시나리오가 포함됩니다. 그러나 컬렉션 정렬에 대한 성능 최적화를 수행하지 않으면 프로그램의 실행 효율성이 저하될 수 있습니다. 이 기사에서는 Java 컬렉션 정렬 성능을 최적화하는 방법을 살펴보겠습니다. 1. 적절한 컬렉션 클래스 선택 Java에는 ArrayList, LinkedList, TreeSet 등과 같이 정렬에 사용할 수 있는 컬렉션 클래스가 많이 있습니다. 다양한 컬렉션 클래스가 있습니다.

Oracle 데이터베이스 조작 기술: 빼기 연산에 대한 자세한 설명 Oracle 데이터베이스 조작 기술: 빼기 연산에 대한 자세한 설명 Mar 02, 2024 pm 06:15 PM

강력한 관계형 데이터베이스 관리 시스템인 Oracle 데이터베이스는 사용자 요구 사항을 충족하는 풍부한 컴퓨팅 작업을 제공합니다. 일상적인 데이터베이스 작업에서 빼기 작업은 일반적이고 중요한 작업으로, 필요한 결과를 얻기 위해 데이터 빼기 작업을 구현하는 데 도움이 될 수 있습니다. 이 문서에서는 Oracle 데이터베이스의 빼기 작업과 관련된 기술을 자세히 설명하고 독자가 이 기능을 더 잘 이해하고 사용할 수 있도록 구체적인 코드 예제를 제공합니다. 1. Oracle 데이터의 뺄셈 연산의 기본 개념

HashSet 클래스의 addAll() 메서드를 사용하여 한 컬렉션의 모든 요소를 ​​다른 컬렉션에 추가합니다. HashSet 클래스의 addAll() 메서드를 사용하여 한 컬렉션의 모든 요소를 ​​다른 컬렉션에 추가합니다. Jul 24, 2023 am 08:58 AM

HashSet 클래스의 addAll() 메소드를 사용하여 컬렉션의 모든 요소를 ​​다른 컬렉션에 추가합니다. HashSet은 Java 컬렉션 프레임워크의 구현 클래스이며 Set 인터페이스를 구현합니다. HashSet은 해시 테이블을 기반으로 하는 순서가 지정되지 않은 집합으로 중복 요소를 허용하지 않습니다. 이는 컬렉션의 요소를 조작하기 위해 일반적으로 사용되는 여러 가지 메소드를 제공하며, 그 중 하나가 addAll() 메소드입니다. addAll() 메소드의 기능은 지정된 항목을 추가하는 것입니다.

Laravel 컬렉션의 Where 메소드에 대한 실용 가이드 Laravel 컬렉션의 Where 메소드에 대한 실용 가이드 Mar 10, 2024 pm 04:36 PM

Laravel 컬렉션의 Where 메소드에 대한 실용 가이드 Laravel 프레임워크를 개발하는 동안 컬렉션은 데이터를 조작하기 위한 풍부한 메소드를 제공하는 매우 유용한 데이터 구조입니다. 그 중 Where 방식은 특정 조건에 따라 컬렉션의 요소를 필터링할 수 있는 일반적으로 사용되는 필터링 방식이다. 이 글에서는 Laravel 컬렉션에서 Where 메소드의 사용법을 소개하고 특정 코드 예제를 통해 사용법을 보여줍니다. 1. Where 메소드의 기본 사용법

C#의 일반적인 동시 수집 및 스레드 안전 문제 C#의 일반적인 동시 수집 및 스레드 안전 문제 Oct 09, 2023 pm 10:49 PM

C#의 일반적인 동시 컬렉션 및 스레드 안전 문제 C# 프로그래밍에서 동시 작업 처리는 매우 일반적인 요구 사항입니다. 여러 스레드가 동시에 동일한 데이터에 액세스하고 수정할 때 스레드 안전 문제가 발생합니다. 이 문제를 해결하기 위해 C#에서는 몇 가지 동시 수집 및 스레드 안전 메커니즘을 제공합니다. 이 문서에서는 C#의 일반적인 동시 컬렉션과 스레드 안전 문제를 처리하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 동시 수집 1.1ConcurrentDictionaryConcurrentDictio

PHP 부동 소수점 연산 문제에 대한 분석 및 솔루션 PHP 부동 소수점 연산 문제에 대한 분석 및 솔루션 Feb 27, 2024 am 11:03 AM

PHP는 웹사이트 개발에 널리 사용되는 스크립팅 언어로, 강력한 기능과 유연성으로 인해 많은 개발자가 선택하는 도구입니다. 그러나 PHP는 부동 소수점 연산을 처리할 때 특히 정밀도와 정확성과 관련하여 몇 가지 문제를 안고 있습니다. 이 기사에서는 PHP 부동 소수점 연산 문제를 분석하고 몇 가지 솔루션을 제안할 것이며 독자가 이러한 문제를 더 잘 이해하고 해결하는 데 도움이 되는 특정 코드 예제도 제공할 것입니다. 문제 분석 PHP에서 부동 소수점 숫자는 소수를 나타내는 데 사용되는 데이터 유형입니다.

Java Iterator와 Iterable: 우아한 코드 작성을 위한 단계 Java Iterator와 Iterable: 우아한 코드 작성을 위한 단계 Feb 19, 2024 pm 02:54 PM

Iterator 인터페이스 Iterator 인터페이스는 컬렉션을 순회하는 데 사용되는 인터페이스입니다. hasNext(), next() 및 Remove()를 포함한 여러 메소드를 제공합니다. hasNext() 메서드는 컬렉션에 다음 요소가 있는지 여부를 나타내는 부울 값을 반환합니다. next() 메서드는 컬렉션의 다음 요소를 반환하고 컬렉션에서 제거합니다. Remove() 메서드는 컬렉션에서 현재 요소를 제거합니다. 다음 코드 예제에서는 Iterator 인터페이스를 사용하여 컬렉션을 반복하는 방법을 보여줍니다. Listnames=Arrays.asList("John","Mary","Bob");Iterator

See all articles