SQL을 사용하여 작업 설정
이 기사에서는 특정 참조 값이 있는 집합 연산에 대한 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 ;
테이블 만들기
(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');
--把除法变成减法select distinct emp from empskills es1 where not exists
(select skill from skills
expect select skill from empskills es2 where es1.emp = es2.emp);
로그인 후 복사
아이디어:
두 공급업체 모두 동일한 유형의 부품을 취급합니다(단순히 부품 열에 따라 연결).
두 공급업체의 부품 유형 수가 동일합니다(즉, 일대일 매핑이 있음)(개수 제한)--把除法变成减法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','保险丝');
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)
;
로그인 후 복사
Exerciseselect 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) ;
drop table if exists products;create table products(
rowid int4,
name1 varchar(10),
price int4
);insert into products values(1,'苹果',50);insert into products values(2,'橘子',100);
insert into products values(3,'橘子',100);insert into products values(4,'橘子',100);
insert into products values(5,'香蕉',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"에서 나온 것이므로 메모해 두세요. 연습문제의 일부 코드는 원본입니다.
drop table if exists products;create table products( rowid int4, name1 varchar(10), price int4 );insert into products values(1,'苹果',50);insert into products values(2,'橘子',100); insert into products values(3,'橘子',100);insert into products values(4,'橘子',100); insert into products values(5,'香蕉',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을 사용하여 작업 설정의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











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

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

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

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

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

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

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

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