찾다
데이터 베이스MySQL 튜토리얼MySQL의 여러 실용적인 SQL 문을 공유하세요.

MySQL의 여러 실용적인 SQL 문을 공유하세요.

SQL을 작성할 때 프로그램 논리를 크게 단순화하기 위해 일부 SQL 문 작성 기술을 사용하는 경우가 많습니다. 프로그램과 데이터베이스 간의 상호 작용 횟수를 줄이는 것은 데이터베이스의 가용성을 높이는 데 도움이 되며 동료들에게 SQL 기술을 돋보이게 합니다.

Practical SQL

1. 새로운 레코드를 삽입하고 싶은데(INSERT) 레코드가 이미 존재하는 경우, 원본 레코드를 먼저 삭제한 후 새로운 레코드를 삽입하세요. .

시나리오 예시: 이 테이블은 각 고객의 최신 거래 주문 정보를 저장합니다. 단일 사용자 데이터가 반복적으로 입력되지 않도록 해야 하며, 데이터베이스와의 상호 작용을 최소화하면서 실행 효율성이 가장 높으며, 데이터베이스의 고가용성.

이때, "REPLACE INTO" 문을 사용하면 먼저 쿼리한 후 삭제 여부를 먼저 결정한 후 삽입할 필요가 없습니다.

"REPLACE INTO" 문은 고유성(존재 여부)을 확인하기 위해 고유 인덱스 또는 기본 키를 기반으로 합니다.
  • "REPLACE INTO" 문은 고유성(존재 여부)을 확인하기 위해 고유 인덱스 또는 기본 키를 기반으로 합니다.
  • "REPLACE INTO" 문은 고유성(존재 여부)을 확인하기 위해 고유 인덱스 또는 기본 키를 기반으로 합니다.
  • 참고: 다음 SQL에서 볼 수 있듯이 사용자 이름 필드에 고유 인덱스(Unique)를 설정해야 하며 transId 설정을 증가시킬 수 있습니다.
  • -- 20点充值
    REPLACE INTO last_transaction (transId,username,amount,trans_time,remark) 
       VALUES (null, 'chenhaha', 30, '2020-06-11 20:00:20', '会员充值');
     
    -- 21点买皮肤
    REPLACE INTO last_transaction (transId,username,amount,trans_time,remark) 
       VALUES (null, 'chenhaha', 100, '2020-06-11 21:00:00', '购买盲僧至高之拳皮肤');
username='chenhaha'의 레코드가 존재하지 않으면 REPLACE 문은 새 레코드를 삽입하고(첫 번째 재충전), 그렇지 않으면 현재 username='chenhaha'의 레코드가 삭제된 후 새 레코드가 생성됩니다. 삽입됩니다.

id에 특정 값을 제공하지 마십시오. 그렇지 않으면 비즈니스에 특별한 요구가 없는 한 SQL 실행에 영향을 미칩니다.

2. 삽입 또는 업데이트

새 레코드를 삽입하고 싶지만(INSERT) 레코드가 이미 존재하는 경우 레코드를 업데이트합니다. 이때 "INSERT INTO ... ON DUPLICATE KEY"를 사용할 수 있습니다. UPDATE.. ."문:

시나리오 예: 이 테이블은 사용자의 과거 충전 금액을 저장합니다. 사용자가 처음으로 충전하는 경우 새 데이터가 추가됩니다. 사용자가 이전에 충전한 경우 과거 충전 금액은 다음과 같습니다. 단일 사용자의 데이터가 반복적으로 입력되지 않도록 하는 것이 필요합니다.

이때 "INSERT INTO ... ON DUPLICATE KEY UPDATE ..." 문을 사용할 수 있습니다.

참고: 위와 마찬가지로 "INSERT INTO ... ON DUPLICATE KEY UPDATE ..." 문은 고유성(존재 여부)을 확인하기 위해 고유 인덱스 또는 기본 키를 기반으로 합니다. 다음 SQL에서 볼 수 있듯이 사용자 이름 필드에 고유 인덱스(Unique)를 설정해야 하며 transId 설정을 증가시킬 수 있습니다.

-- 用户陈哈哈充值了30元买会员
INSERT INTO total_transaction (t_transId,username,total_amount,last_transTime,last_remark) 
   VALUES (null, 'chenhaha', 30, '2020-06-11 20:00:20', '充会员') 
   ON DUPLICATE KEY UPDATE  total_amount=total_amount + 30, last_transTime='2020-06-11 20:00:20', last_remark ='充会员';
 
-- 用户陈哈哈充值了100元买瞎子至高之拳皮肤
INSERT INTO total_transaction (t_transId,username,total_amount,last_transTime,last_remark) 
   VALUES (null, 'chenhaha', 100, '2020-06-11 20:00:20', '购买盲僧至高之拳皮肤') 
   ON DUPLICATE KEY UPDATE total_amount=total_amount + 100, last_transTime='2020-06-11 21:00:00', last_remark ='购买盲僧至高之拳皮肤';

사용자 이름='chenhaha'인 레코드가 없으면 INSERT 문은 새 레코드를 삽입합니다. 그렇지 않으면 사용자 이름='chenhaha'인 현재 레코드가 업데이트되고 업데이트된 필드는 UPDATE에 의해 지정됩니다.

3. 삽입 또는 무시

새 레코드를 삽입하고 싶지만(INSERT) 레코드가 이미 존재하는 경우에는 아무것도 하지 않고 그냥 무시합니다. 이때 INSERT IGNORE INTO를 사용할 수 있습니다. ... 진술: 시나리오가 많기 때문에 예를 들어주지 않겠습니다.

참고: 위와 마찬가지로 "INSERT IGNORE INTO..." 문은 고유성(존재 여부)을 확인하기 위해 고유 인덱스 또는 기본 키를 기반으로 사용자 이름에 고유 인덱스(고유)를 설정해야 합니다. 필드 및 transId 설정이 증가될 수 있습니다.

-- 用户首次添加
INSERT IGNORE INTO users_info (id, username, sex, age ,balance, create_time) 
   VALUES (null, 'chenhaha', '男', 12, 0, '2020-06-11 20:00:20');
 
-- 二次添加,直接忽略
INSERT IGNORE INTO users_info (id, username, sex, age ,balance, create_time) 
   VALUES (null, 'chenhaha', '男', 12, 0, '2020-06-11 21:00:20');

사용자 이름='chenhaha'인 레코드가 없으면 INSERT 문은 새 레코드를 삽입하고, 그렇지 않으면 아무 작업도 수행되지 않습니다.

4. SQL의 If-else 판단 문

우리 모두 알고 있듯이 if-else 판단은 SQL 문에서 "CASE WHEN ... THEN ... ELSE ... END" 문을 비롯한 모든 곳에서 유용합니다. 다양한 유형의 추가, 삭제, 수정 및 검색 문에 사용됩니다.

시나리오를 제시해 주세요. 여성의 날 큰 보상, 2020년 신규 등록 사용자, 모든 성인 여성 계정은 10위안 빨간 봉투를 받고, 다른 사용자는 5위안 빨간 봉투를 받게 되며 자동으로 충전됩니다.

예문은 다음과 같습니다.

-- 送红包语句
UPDATE users_info u 
    SET u.balance = CASE WHEN u.sex ='女' and u.age > 18 THEN u.balance + 10 
                         ELSE u.balance + 5 end 
                         WHERE u.create_time >= '2020-01-01'

* 시나리오 2: 학생의 대학 입시 점수표가 있고 성적이 기재되어야 합니다. 650점 이상이 핵심 대학, 600~650점입니다. 1점, 500~600점은 2점, 400~500점은 3권, 대학은 400점 미만입니다.

원본 테스트 데이터는 다음과 같습니다.

쿼리문: MySQL의 여러 실용적인 SQL 문을 공유하세요.

SELECT *,case when total_score >= 650  THEN '重点大学' 
              when total_score >= 600 and total_score <650 THEN &#39;一本&#39;
              when total_score >= 500 and total_score <600 THEN &#39;二本&#39;
              when total_score >= 400 and total_score <500 THEN &#39;三本&#39;        
              else &#39;大专&#39; end as status_student 
              from student_score;

MySQL의 여러 실용적인 SQL 문을 공유하세요.5. 데이터 스냅샷 또는 백업 지정

테이블 스냅샷, 즉 현재 테이블의 데이터를 새 테이블에 복사하려는 경우 CREATE TABLE 및 SELECT:

-- 对class_id=1(一班)的记录进行快照,并存储为新表students_of_class1:
CREATE TABLE students_of_class1 SELECT * FROM student WHERE class_id=1;

와 결합할 수 있습니다. 새로 생성된 테이블 구조는 SELECT에서 사용하는 테이블 구조와 정확히 동일합니다.

6. 쿼리 결과 세트 쓰기

쿼리 결과 세트를 테이블에 작성해야 하는 경우 INSERT와 SELECT를 결합하여 SELECT 문의 결과 세트를 지정된 테이블에 직접 삽입할 수 있습니다.

예를 들어, 각 클래스의 평균 점수를 기록하는 통계 테이블을 생성합니다:

CREATE TABLE statistics (
    id BIGINT NOT NULL AUTO_INCREMENT,
    class_id BIGINT NOT NULL,
    average DOUBLE NOT NULL,
    PRIMARY KEY (id)
);

그런 다음 각 클래스의 평균 점수를 하나의 명령문으로 작성할 수 있습니다:

INSERT INTO statistics (class_id, average) SELECT class_id, AVG(score) FROM students GROUP BY class_id;

确保INSERT语句的列和SELECT语句的列能一一对应,就可以在statistics表中直接保存查询的结果:

SELECT * FROM statistics;
+----+----------+--------------+
| id | class_id | average      |
+----+----------+--------------+
|  1 |        1 |        475.5 |
|  2 |        2 | 473.33333333 |
|  3 |        3 | 488.66666666 |
+----+----------+--------------+
3 rows in set (0.00 sec)

7.强制使用指定索引

在查询的时候,数据库系统会自动分析查询语句,并选择一个最合适的索引。但是很多时候,数据库系统的查询优化器并不一定总是能使用最优索引。如果我们知道如何选择索引,可以使用FORCE INDEX强制查询使用指定的索引。例如:

SELECT * FROM students FORCE INDEX (idx_class_id) WHERE class_id = 1 ORDER BY id DESC;

指定索引的前提是索引idx_class_id必须存在。

心得体会:

MySQL路漫漫,其修远兮。永远不要眼高手低,一起加油,希望本文能对你有所帮助。

推荐教程: 《mysql教程

위 내용은 MySQL의 여러 실용적인 SQL 문을 공유하세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 segmentfault에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
MySQL의 장소 : 데이터베이스 및 프로그래밍MySQL의 장소 : 데이터베이스 및 프로그래밍Apr 13, 2025 am 12:18 AM

데이터베이스 및 프로그래밍에서 MySQL의 위치는 매우 중요합니다. 다양한 응용 프로그램 시나리오에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) MySQL은 웹, 모바일 및 엔터프라이즈 레벨 시스템을 지원하는 효율적인 데이터 저장, 조직 및 검색 기능을 제공합니다. 2) 클라이언트 서버 아키텍처를 사용하고 여러 스토리지 엔진 및 인덱스 최적화를 지원합니다. 3) 기본 사용에는 테이블 작성 및 데이터 삽입이 포함되며 고급 사용에는 다중 테이블 조인 및 복잡한 쿼리가 포함됩니다. 4) SQL 구문 오류 및 성능 문제와 같은 자주 묻는 질문은 설명 명령 및 느린 쿼리 로그를 통해 디버깅 할 수 있습니다. 5) 성능 최적화 방법에는 인덱스의 합리적인 사용, 최적화 된 쿼리 및 캐시 사용이 포함됩니다. 모범 사례에는 거래 사용 및 준비된 체계가 포함됩니다

MySQL : 소기업에서 대기업에 이르기까지MySQL : 소기업에서 대기업에 이르기까지Apr 13, 2025 am 12:17 AM

MySQL은 소규모 및 대기업에 적합합니다. 1) 소기업은 고객 정보 저장과 같은 기본 데이터 관리에 MySQL을 사용할 수 있습니다. 2) 대기업은 MySQL을 사용하여 대규모 데이터 및 복잡한 비즈니스 로직을 처리하여 쿼리 성능 및 트랜잭션 처리를 최적화 할 수 있습니다.

Phantom은 무엇을 읽고, Innodb는 어떻게 그들을 막을 수 있습니까 (다음 키 잠금)?Phantom은 무엇을 읽고, Innodb는 어떻게 그들을 막을 수 있습니까 (다음 키 잠금)?Apr 13, 2025 am 12:16 AM

InnoDB는 팬텀 읽기를 차세대 점화 메커니즘을 통해 효과적으로 방지합니다. 1) Next-Keylocking은 Row Lock과 Gap Lock을 결합하여 레코드와 간격을 잠그기 위해 새로운 레코드가 삽입되지 않도록합니다. 2) 실제 응용 분야에서 쿼리를 최적화하고 격리 수준을 조정함으로써 잠금 경쟁을 줄이고 동시성 성능을 향상시킬 수 있습니다.

MySQL : 프로그래밍 언어는 아니지만 ...MySQL : 프로그래밍 언어는 아니지만 ...Apr 13, 2025 am 12:03 AM

MySQL은 프로그래밍 언어가 아니지만 쿼리 언어 SQL은 프로그래밍 언어의 특성을 가지고 있습니다. 1. SQL은 조건부 판단, 루프 및 가변 작업을 지원합니다. 2. 저장된 절차, 트리거 및 기능을 통해 사용자는 데이터베이스에서 복잡한 논리 작업을 수행 할 수 있습니다.

MySQL : 세계에서 가장 인기있는 데이터베이스 소개MySQL : 세계에서 가장 인기있는 데이터베이스 소개Apr 12, 2025 am 12:18 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

MySQL의 중요성 : 데이터 저장 및 관리MySQL의 중요성 : 데이터 저장 및 관리Apr 12, 2025 am 12:18 AM

MySQL은 데이터 저장, 관리, 쿼리 및 보안에 적합한 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1. 다양한 운영 체제를 지원하며 웹 응용 프로그램 및 기타 필드에서 널리 사용됩니다. 2. 클라이언트-서버 아키텍처 및 다양한 스토리지 엔진을 통해 MySQL은 데이터를 효율적으로 처리합니다. 3. 기본 사용에는 데이터베이스 및 테이블 작성, 데이터 삽입, 쿼리 및 업데이트가 포함됩니다. 4. 고급 사용에는 복잡한 쿼리 및 저장 프로 시저가 포함됩니다. 5. 설명 진술을 통해 일반적인 오류를 디버깅 할 수 있습니다. 6. 성능 최적화에는 인덱스의 합리적인 사용 및 최적화 된 쿼리 문이 포함됩니다.

MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점Apr 12, 2025 am 12:17 AM

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

InnoDB 잠금 장치 (공유 잠금, 독점 잠금, 의도 잠금, 레코드 잠금, 갭 잠금, 차세대 자물쇠)를 설명하십시오.InnoDB 잠금 장치 (공유 잠금, 독점 잠금, 의도 잠금, 레코드 잠금, 갭 잠금, 차세대 자물쇠)를 설명하십시오.Apr 12, 2025 am 12:16 AM

InnoDB의 잠금 장치에는 공유 잠금 장치, 독점 잠금, 의도 잠금 장치, 레코드 잠금, 갭 잠금 및 다음 키 잠금 장치가 포함됩니다. 1. 공유 잠금을 사용하면 다른 트랜잭션을 읽지 않고 트랜잭션이 데이터를 읽을 수 있습니다. 2. 독점 잠금은 다른 트랜잭션이 데이터를 읽고 수정하는 것을 방지합니다. 3. 의도 잠금은 잠금 효율을 최적화합니다. 4. 레코드 잠금 잠금 인덱스 레코드. 5. 갭 잠금 잠금 장치 색인 기록 간격. 6. 다음 키 잠금은 데이터 일관성을 보장하기 위해 레코드 잠금과 갭 잠금의 조합입니다.

See all articles

핫 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尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

메모장++7.3.1

메모장++7.3.1

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

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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