SQL을 작성할 때 프로그램 논리를 크게 단순화하기 위해 일부 SQL 문 작성 기술을 사용하는 경우가 많습니다. 프로그램과 데이터베이스 간의 상호 작용 횟수를 줄이는 것은 데이터베이스의 가용성을 높이는 데 도움이 되며 동료들에게 SQL 기술을 돋보이게 합니다.
Practical SQL
1. 새로운 레코드를 삽입하고 싶은데(INSERT) 레코드가 이미 존재하는 경우, 원본 레코드를 먼저 삭제한 후 새로운 레코드를 삽입하세요. .
시나리오 예시: 이 테이블은 각 고객의 최신 거래 주문 정보를 저장합니다. 단일 사용자 데이터가 반복적으로 입력되지 않도록 해야 하며, 데이터베이스와의 상호 작용을 최소화하면서 실행 효율성이 가장 높으며, 데이터베이스의 고가용성. 이때, "REPLACE INTO" 문을 사용하면 먼저 쿼리한 후 삭제 여부를 먼저 결정한 후 삽입할 필요가 없습니다. "REPLACE INTO" 문은 고유성(존재 여부)을 확인하기 위해 고유 인덱스 또는 기본 키를 기반으로 합니다.-- 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점 미만입니다. 원본 테스트 데이터는 다음과 같습니다.
쿼리문:
SELECT *,case when total_score >= 650 THEN '重点大学' when total_score >= 600 and total_score <650 THEN '一本' when total_score >= 500 and total_score <600 THEN '二本' when total_score >= 400 and total_score <500 THEN '三本' else '大专' end as status_student from student_score;
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!