데이터 베이스 MySQL 튜토리얼 MySQL의 준비, 실행 및 할당 해제 사용법에 대한 자세한 설명

MySQL의 준비, 실행 및 할당 해제 사용법에 대한 자세한 설명

Dec 22, 2017 pm 01:48 PM
execute prepare

prepare,execute,dealcate는 모두 mysql의 전처리문을 중심으로 MySQL에서 prepare,execute,dealcate의 사용법 튜토리얼을 소개하고 있어 누구나 유용하게 사용할 수 있다. mysql을 배우거나 사용하십시오. 특정 참조 및 학습 가치가 있습니다. 필요한 친구는 편집자를 따라 배울 수 있습니다.

추천 관련 mysql 비디오 튜토리얼: "mysql tutorial"

Foreword

MySQL은 공식적으로 PREPARE STATEMENT라고 부르는데 익숙합니다. 사용법 매우 간단하므로 아래에서는 길게 설명하지 않겠습니다. 자세한 소개를 살펴보겠습니다.

샘플 코드

PREPARE stmt_name FROM preparable_stmt

EXECUTE stmt_name
 [USING @var_name [, @var_name] ...] -

{DEALLOCATE | DROP} PREPARE stmt_name
로그인 후 복사

예:

mysql> PREPARE pr1 FROM 'SELECT ?+?';
Query OK, 0 rows affected (0.01 sec)
Statement prepared

mysql> SET @a=1, @b=10 ;
Query OK, 0 rows affected (0.00 sec)

mysql> EXECUTE pr1 USING @a, @b;
+------+
| ?+? |
+------+
| 11 |
+------+
1 row in set (0.00 sec)

mysql> EXECUTE pr1 USING 1, 2; -- 只能使用用户变量传递。
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the 
right syntax to use near '1, 2' at line 1

mysql> DEALLOCATE PREPARE pr1;
Query OK, 0 rows affected (0.00 sec)
로그인 후 복사

PAREPARE STATEMENT를 사용하면 WHERE 조건으로 SELECT 및 DELETE 실행, UPDATE 또는 INSERT 실행과 같은 각 SQL 실행의 구문 분석을 줄일 수 있습니다. , 매번 변수 값만 수정하면 됩니다.

SQL 주입도 방지할 수 있으며, 매개변수 값에는 이스케이프 문자와 구분 기호가 포함될 수 있습니다.

애플리케이션 또는 SQL 스크립트에 적용 가능합니다.

추가 사용법:

비슷하게 PREPARE... FROM은 사용자 변수를 직접 연결할 수 있습니다:

mysql> CREATE TABLE a (a int);
Query OK, 0 rows affected (0.26 sec)

mysql> INSERT INTO a SELECT 1;
Query OK, 1 row affected (0.04 sec)
Records: 1 Duplicates: 0 Warnings: 0

mysql> INSERT INTO a SELECT 2;
Query OK, 1 row affected (0.04 sec)
Records: 1 Duplicates: 0 Warnings: 0

mysql> INSERT INTO a SELECT 3;
Query OK, 1 row affected (0.04 sec)
Records: 1 Duplicates: 0 Warnings: 0

mysql> SET @select_test = CONCAT('SELECT * FROM ', @table_name);
Query OK, 0 rows affected (0.00 sec)

mysql> SET @table_name = 'a';
Query OK, 0 rows affected (0.00 sec)

mysql> PREPARE pr2 FROM @select_test;
Query OK, 0 rows affected (0.00 sec)
Statement prepared

mysql> EXECUTE pr2 ;
+------+
| a |
+------+
| 1 |
| 2 |
| 3 |
+------+
3 rows in set (0.00 sec)

mysql> DROP PREPARE pr2; -- 此处DROP可以替代DEALLOCATE
Query OK, 0 rows affected (0.00 sec)
로그인 후 복사

EXECUTE를 실행할 때마다 좋은 습관을 기르고 DEALLOCATE PREPARE... 문을 실행하세요. 실행에 사용된 모든 데이터베이스 리소스(예: 커서)입니다.

그뿐만 아니라 세션에 준비된 명령문이 너무 많으면 max_prepared_stmt_count의 상한에 도달할 수 있습니다.

준비된 발언은 창작자 세션에서만 사용할 수 있으며, 다른 세션에서는 사용할 수 없습니다.

그리고 어떤 식으로든(정상이든 비정상이든) 세션을 종료하면 이전에 정의된 준비된 명령문은 더 이상 존재하지 않습니다.

저장 프로시저에서 사용되는 경우 프로시저에서 DEALLOCATE되지 않으면 준비된 문은 저장 프로시저가 끝난 후에도 계속 유효합니다.

관련 권장 사항:

MySQL 시작하기 및 준비된 문 사용

php_pdo 준비된 문에 대한 자세한 설명

php Mysqli 준비된 문 두 가지 예제 코드

위 내용은 MySQL의 준비, 실행 및 할당 해제 사용법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Docker에서 MySQL 메모리 사용을 줄입니다 Docker에서 MySQL 메모리 사용을 줄입니다 Mar 04, 2025 pm 03:52 PM

Docker에서 MySQL 메모리 사용을 줄입니다

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Mar 19, 2025 pm 03:51 PM

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. Mar 04, 2025 pm 04:01 PM

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Mar 04, 2025 pm 03:54 PM

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

sqlite 란 무엇입니까? 포괄적 인 개요 sqlite 란 무엇입니까? 포괄적 인 개요 Mar 04, 2025 pm 03:55 PM

sqlite 란 무엇입니까? 포괄적 인 개요

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 Mar 04, 2025 pm 03:49 PM

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? 인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? Mar 21, 2025 pm 06:28 PM

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)?

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? Mar 18, 2025 pm 12:01 PM

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까?

See all articles