SQL이 칼럼에서는 SQL을 완전히 이해하는 10단계를 소개합니다
권장(무료): SQL
많은 프로그래머는 SQL을 골칫거리로 여깁니다. SQL은 명령줄 언어, 객체지향 프로그래밍 언어, 심지어 우리에게 익숙한 기능적 언어와도 완전히 다르게 작동하는 몇 안 되는 선언적 언어 중 하나입니다(어떤 사람들은 SQL 언어도 기능적 언어라고 생각하지만). ).
우리는 매일 SQL을 작성하고 이를 오픈소스 소프트웨어인 jOOQ에 적용합니다. 그래서 아직도 SQL에 대해 고민하고 있는 친구들에게 SQL의 아름다움을 소개하고 싶어서 이 글은 다음 독자들을 위해 특별히 작성되었습니다.
1. 직장에서 SQL을 사용하지만 SQL을 완전히 이해하지 못하는 사람들.
2. SQL을 능숙하게 사용하지만 구문과 논리를 이해하지 못하는 사람.
3. 다른 사람에게 SQL을 가르치고 싶은 사람.
이 글은 SELECT 문장 패턴에 중점을 두고 있으며, 다른 DML(Data Manipulation Language)에 대해서는 다른 글에서 소개할 예정입니다.
SQL을 완전히 이해하기 위한 10가지 간단한 단계
1. SQL은 선언적 언어입니다
먼저 "선언"이라는 개념을 염두에 두어야 합니다. SQL 언어는 컴퓨터에게 결과를 얻는 방법을 알려주는 대신 원시 데이터에서 얻고자 하는 결과의 종류를 컴퓨터에 선언하는 예입니다. 정말 좋지 않나요?
(역자 주: 간단히 말해서 SQL 언어는 결과 집합의 속성을 선언합니다. 컴퓨터에 전통적인 사용법을 지시하는 것이 아니라 SQL에서 선언한 내용을 기반으로 컴퓨터가 데이터베이스에서 선언에 맞는 데이터를 선택합니다. 프로그래밍 사고.)
SELECT first_name, last_name FROM employees WHERE salary > 100000
위의 예는 이해하기 쉽습니다. 이러한 직원 기록이 어디서 왔는지는 중요하지 않습니다. 우리에게 필요한 것은 급여가 높은 사람들의 데이터입니다(번역자 주: 급여>100000).
우리는 이것을 어디서 배웠나요?
SQL 언어가 이렇게 단순하다면, 사람들이 “SQL을 듣고 얼굴이 창백해지는” 이유는 무엇입니까? 그 주된 이유는 우리가 무의식적으로 명령형 프로그래밍 사고방식에 따라 문제를 생각하기 때문입니다. 이는 다음과 같습니다: "컴퓨터, 이 단계를 먼저 수행한 다음 저 단계를 수행하고 그 전에 조건 A와 조건 B가 충족되는지 확인하십시오." 예를 들어 변수를 사용하여 매개변수를 전달하는 것, 루프 문을 사용하는 것, 반복, 함수 호출 등은 모두 이 명령형 프로그래밍의 사고 습관입니다.
2. SQL 구문은 문법 순서대로 실행되지 않습니다.
SQL 문에는 대부분의 사람들을 혼란스럽게 하는 특징이 있습니다. 즉, SQL 문의 실행 순서가 해당 문의 문법 순서와 일치하지 않습니다. SQL 문의 구문 순서는 다음과 같습니다.
- SELECT[DISTINCT]
- FROM
- WHERE
- GROUP BY
- HAVING
- UNION
- ORDER BY
이해의 편의를 위해 모든 SQL 구문 구조가 위에 나열되어 있지만 SQL 문의 문법 순서는 실행 순서와 완전히 다르다는 것을 보여주기에 충분합니다. 위 명령문을 예로 들면 실행 순서는
- FROM
- WHERE
- GROUP BY
- HAVING
- SELECT
- DISTINCT
- UNION
- ORDER BY
SQL 문의 실행 순서와 관련하여 주목할 만한 세 가지 사항이 있습니다.
1 실행의 첫 번째 단계입니다. SELECT가 아닌 SQL 문입니다. 데이터베이스가 SQL 문을 실행하는 첫 번째 단계는 하드 디스크의 데이터를 데이터 버퍼로 로드하여 작업할 수 있도록 하는 것입니다. (번역자 주: 원문은 "이러한 데이터에 대해 작업을 수행하기 위해 가장 먼저 일어나는 일은 디스크에서 메모리로 데이터를 로드하는 것입니다."이지만, 그렇지 않습니다. Oracle 등 일반적으로 사용되는 데이터베이스를 예로 들면 다음과 같습니다. , 데이터는 데이터 버퍼에서 추출됩니다. )
2. SELECT는 대부분의 명령문이 실행된 후에 실행됩니다. 엄밀히 말하면 FROM 및 GROUP BY 이후에 실행됩니다. 이를 이해하는 것이 매우 중요합니다. 따라서 SELECT에서 별칭이 지정된 WHERE의 필드를 조건으로 사용할 수 없습니다.
SELECT A.x + A.y AS z FROM A WHERE z = 10 -- z 在此处不可用,因为SELECT是最后执行的语句!
별칭 z를 재사용하려면 두 가지 옵션이 있습니다. z:
SELECT A.x + A.y AS z FROM A WHERE (A.x + A.y) = 10
로 표시되는 표현식을 다시 작성하거나 파생 테이블, 공통 데이터 표현식 또는 뷰를 사용하여 별칭 재사용을 방지하세요. 아래 예를 참조하세요.
3. 구문이나 실행 순서에 관계없이 UNION은 항상 ORDER BY보다 우선합니다. 많은 사람들이 모든 UNION 세그먼트를 ORDER BY를 사용하여 정렬할 수 있다고 생각하지만, SQL 언어 표준과 각 데이터베이스의 SQL 구현 차이에 따르면 이는 사실이 아닙니다. 일부 데이터베이스에서는 SQL 문에서 하위 쿼리 또는 파생 테이블을 정렬할 수 있지만 이것이 UNION 작업 후에 정렬이 정렬된 순서를 유지한다는 의미는 아닙니다.
참고: 모든 데이터베이스가 SQL 문에 대해 동일한 구문 분석 방법을 사용하는 것은 아닙니다. 예를 들어 MySQL, PostgreSQL 및 SQLite는 위의 두 번째 항목에서 언급한 대로 수행되지 않습니다.
우리는 무엇을 배웠나요?
既然并不是所有的数据库都按照上述方式执行 SQL 预计,那我们的收获是什么?我们的收获是永远要记得:SQL 语句的语法顺序和其执行顺序并不一致,这样我们就能避免一般性的错误。如果你能记住 SQL 语句语法顺序和执行顺序的差异,你就能很容易的理解一些很常见的 SQL 问题。
当然,如果一种语言被设计成语法顺序直接反应其语句的执行顺序,那么这种语言对程序员是十分友好的,这种编程语言层面的设计理念已经被微软应用到了 LINQ 语言中。
3、 SQL 语言的核心是对表的引用(table references)
由于 SQL 语句语法顺序和执行顺序的不同,很多同学会认为SELECT 中的字段信息是 SQL 语句的核心。其实真正的核心在于对表的引用。
根据 SQL 标准,FROM 语句被定义为:
<from> ::= FROM <table> [ { <comma> <table> }... ]<p>FROM 语句的“输出”是一张联合表,来自于所有引用的表在某一维度上的联合。我们们慢慢来分析:</p> <pre class="brush:php;toolbar:false">FROM a, b
上面这句 FROM 语句的输出是一张联合表,联合了表 a 和表 b 。如果 a 表有三个字段, b 表有 5 个字段,那么这个“输出表”就有 8 ( =5+3)个字段。
这个联合表里的数据是 ab,即 a 和 b 的笛卡尔积。换句话说,也就是 a 表中的每一条数据都要跟 b 表中的每一条数据配对。如果 a 表有3 条数据, b 表有 5 条数据,那么联合表就会有 15 ( =53)条数据。
FROM 输出的结果被 WHERE 语句筛选后要经过 GROUP BY 语句处理,从而形成新的输出结果。我们后面还会再讨论这方面问题。
如果我们从集合论(关系代数)的角度来看,一张数据库的表就是一组数据元的关系,而每个 SQL 语句会改变一种或数种关系,从而产生出新的数据元的关系(即产生新的表)。
我们学到了什么?
思考问题的时候从表的角度来思考问题提,这样很容易理解数据如何在 SQL 语句的“流水线”上进行了什么样的变动。
4、 灵活引用表能使 SQL 语句变得更强大
灵活引用表能使 SQL 语句变得更强大。一个简单的例子就是 JOIN 的使用。严格的说 JOIN 语句并非是 SELECT 中的一部分,而是一种特殊的表引用语句。SQL 语言标准中表的连接定义如下:
위 내용은 SQL을 완전히 이해하기 위한 10단계 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

SQL과 데이터베이스의 관계는 밀접하게 통합되었으며 SQL은 데이터베이스를 관리하고 운영하는 도구입니다. 1.SQL은 데이터 정의, 작동, 쿼리 및 제어에 사용되는 선언적 언어입니다. 2. 데이터베이스 엔진은 SQL 문을 구문 분석하고 쿼리 계획을 실행합니다. 3. 기본 사용에는 테이블 작성, 삽입 및 쿼리가 포함됩니다. 4. 고급 사용에는 복잡한 쿼리와 하위 쿼리가 포함됩니다. 5. 일반적인 오류에는 구문, 논리 및 성능 문제가 포함되며, 구문 검사 및 설명 명령을 통해 디버깅 할 수 있습니다. 6. 최적화 기술에는 인덱스 사용, 전체 테이블 스캔을 피하고 쿼리 최적화가 포함됩니다.

SQL은 관계형 데이터베이스를 관리하는 표준 언어이며 MySQL은 SQL을 사용하는 데이터베이스 관리 시스템입니다. SQL은 CRUD 작업을 포함한 데이터베이스와 상호 작용하는 방법을 정의하는 반면 MySQL은 SQL 표준을 구현하고 저장 프로 시저 및 트리거와 같은 추가 기능을 제공합니다.

데이터 관리에서 SQL의 역할은 쿼리, 삽입, 업데이트 및 삭제를 통해 데이터를 효율적으로 처리하고 분석하는 것입니다. 1.SQL은 사용자가 구조화 된 방식으로 데이터베이스와 대화 할 수있는 선언적 언어입니다. 2. 사용 예제에는 기본 선택 쿼리 및 고급 조인 작업이 포함됩니다. 3. WHERE 절을 잊거나 오용 조인 가입과 같은 일반적인 오류는 설명 명령을 통해 디버깅 할 수 있습니다. 4. 성능 최적화에는 인덱스 사용 및 코드 가독성 및 유지 관리와 같은 모범 사례가 포함됩니다.

SQL은 관계형 데이터베이스를 관리하고 운영하는 데 사용되는 언어입니다. 1. 테이블 만들기 : CreateTableUsers (Idintprimarykey, Namevarchar (100), 이메일 Varchar (100))와 같은 Createtable 문을 사용하십시오. 2. 데이터 삽입, 업데이트 및 삭제 : InsertInto 사용, 업데이트, insertIntousers (id, name, email) 값 (1, 'johndoe', 'john@example.com')과 같은 문장 삭제; 3. 쿼리 데이터 : Selec과 같은 SELECT 문을 사용하십시오

SQL과 MySQL의 관계는 다음과 같습니다. SQL은 데이터베이스를 관리하고 작동하는 데 사용되는 언어이며 MySQL은 SQL을 지원하는 데이터베이스 관리 시스템입니다. 1.SQL은 CRUD 작업 및 고급 데이터 쿼리를 허용합니다. 2.MySQL은 성능 및 보안을 향상시키기 위해 인덱싱, 트랜잭션 및 잠금 메커니즘을 제공합니다. 3. MySQL 성능을 최적화하려면 쿼리 최적화, 데이터베이스 설계 및 모니터링 및 유지 보수에주의를 기울여야합니다.

SQL은 데이터베이스 관리 및 데이터 운영에 사용되며 핵심 기능에는 CRUD 작업, 복잡한 쿼리 및 최적화 전략이 포함됩니다. 1) CRUD 작업 : InsertInto를 사용하여 데이터를 작성하고 데이터 읽기를 선택하고 데이터 업데이트 데이터를 업데이트하고 데이터 삭제 데이터를 삭제합니다. 2) 복잡한 쿼리 : Groupby를 통한 복잡한 데이터를 처리하고 조항이 있습니다. 3) 최적화 전략 : 인덱스 사용, 전체 테이블 스캔을 피하고, 조인 작업 및 페이징 쿼리를 최적화하여 성능을 향상시킵니다.

SQL은 구문이 간단하고 기능이 강하고 데이터베이스 시스템에서 널리 사용되기 때문에 초보자에게 적합합니다. 1.SQL은 관계형 데이터베이스를 관리하고 테이블을 통해 데이터를 구성하는 데 사용됩니다. 2. 기본 작업에는 데이터 작성, 삽입, 쿼리, 업데이트 및 삭제가 포함됩니다. 3. 조인, 하위 쿼리 및 창 함수와 같은 고급 사용량은 데이터 분석 기능을 향상시킵니다. 4. 일반적인 오류에는 검사 및 최적화를 통해 해결할 수있는 구문, 논리 및 성능 문제가 포함됩니다. 5. 성능 최적화 제안에는 인덱스 사용, 선택*피하기, 쿼리 분석, 데이터베이스 정규화 및 코드 가독성 향상이 포함됩니다.

실제 애플리케이션에서 SQL은 주로 데이터 쿼리 및 분석, 데이터 통합 및보고, 데이터 청소 및 전처리, 고급 사용 및 최적화에 사용되며 복잡한 쿼리를 처리하고 일반적인 오류를 피합니다. 1) 데이터 쿼리 및 분석을 사용하여 가장 많은 판매 제품을 찾을 수 있습니다. 2) 데이터 통합 및보고는 가입 운영을 통해 고객 구매 보고서를 생성합니다. 3) 데이터 청소 및 전처리는 비정상적인 연령 기록을 삭제할 수 있습니다. 4) 고급 사용 및 최적화에는 창 함수 사용 및 인덱스 생성이 포함됩니다. 5) CTE 및 조인은 SQL 주입과 같은 일반적인 오류를 피하기 위해 복잡한 쿼리를 처리하는 데 사용될 수 있습니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

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

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

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