>데이터 베이스 >MySQL 튜토리얼 >SQL INSERT 쿼리에 데이터를 삽입할 때 아포스트로피를 이스케이프하는 방법은 무엇입니까?

SQL INSERT 쿼리에 데이터를 삽입할 때 아포스트로피를 이스케이프하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-24 03:39:31760검색

How to Escape Apostrophes When Inserting Data in an SQL INSERT Query?

IssueInsertingDataWithApostrophesError

SQL INSERT 쿼리를 사용하여 아포스트로피(작은따옴표)가 포함된 데이터를 삽입하려는 시도가 실패하고 다음으로 인해 SQL 구문 오류가 발생합니다. MySQL의 특수 문자 처리.

해결책

이 문제를 해결하려면 삽입된 데이터에서 백슬래시를 사용하여 아포스트로피를 이스케이프 처리하세요. 백슬래시는 SQL에서 이스케이프 문자 역할을 하며, 다음 문자가 문자 그대로 처리되어야 함을 나타냅니다. 아포스트로피를 이스케이프 처리하면 문자열을 종료하는 특수 문자가 아닌 데이터 값의 일부로 이를 해석하도록 MySQL에 지시할 수 있습니다.

예를 들어 다음을 사용하는 대신

INSERT INTO table_name (column_name) VALUES ('Kellog's');

다음을 사용합니다.

INSERT INTO table_name (column_name) VALUES ('Kellogg\'s');

이것은 MySQL에게 전체 문자열 'Kellogg's'를 'column_name' 열의 값으로 삽입하도록 지시합니다.

추가 고려 사항

  • 이스케이프 기능 사용: 일부 프로그래밍 언어는 특수 문자를 이스케이프 처리하도록 특별히 설계된 기능을 제공합니다. 예를 들어, PHP에서는 mysql_real_escape_string() 함수를 사용하여 데이터 값의 아포스트로피 및 기타 특수 문자를 SQL 쿼리에 삽입하기 전에 자동으로 이스케이프할 수 있습니다.
  • 수동 이스케이프 방지: 수동으로 이스케이프하는 동안 경우에 따라 아포스트로피 이스케이프가 작동할 수 있지만 일반적으로 SQL 삽입 공격을 방지하기 위해 이스케이프 기능이나 매개변수화된 쿼리 시스템을 사용하는 것이 좋은 방법으로 간주됩니다.

위 내용은 SQL INSERT 쿼리에 데이터를 삽입할 때 아포스트로피를 이스케이프하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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