>데이터 베이스 >MySQL 튜토리얼 >PDO를 사용하여 MySQL의 BIT(1) 필드에 0을 삽입하면 1이 나오는 이유는 무엇입니까?

PDO를 사용하여 MySQL의 BIT(1) 필드에 0을 삽입하면 1이 나오는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-11-02 12:55:30407검색

Why Does Inserting 0 into a BIT(1) Field in MySQL using PDO Result in 1?

비트(1) 필드의 값 삽입 문제 이해

PHP의 PDO 확장을 사용하는 데이터베이스 프로그래밍은 데이터 조작을 처리할 때, 특히 다음과 같은 경우 문제가 발생할 수 있습니다. bit(1)과 같은 이진 데이터 유형. 이 문서에서는 비트(1) 필드에 0 값을 삽입하여 데이터베이스에 예기치 않은 값이 발생하는 경우 발생하는 일반적인 문제를 살펴봅니다.

문제 설명

PDO 준비된 문을 사용하여 비트(1) 필드에 값 0을 삽입하면 저장된 값 1이 생성됩니다. 이러한 불일치는 자리 표시자(?), 명명된 자리 표시자(:placeholder), binValue() 및 binParam() 메서드를 사용할 때 발생합니다. 자리 표시자 없이 SQL 문을 사용하여 데이터베이스를 직접 쿼리하면 올바른 값 0이 삽입됩니다.

해결책

권장되는 해결 방법은 비트(1)에서 필드 유형을 수정하는 것입니다. TINYINT(1)로. BIT 데이터 유형은 PDO를 포함한 클라이언트 라이브러리와 호환성 문제를 일으킬 수 있습니다. 이러한 문제를 방지하려면 부울 값을 저장하기 위해 BIT(1) 대신 TINYINT(1)를 사용하는 것이 중요합니다.

BIT(1)에 대한 대체 솔루션

변경하는 경우 필드 유형은 가능하지 않습니다. PDO::PARAM_INT 유형 힌트와 함께 바인딩값() 메소드를 사용하면 문제를 해결할 수 있습니다. 다음 코드 조각은 이를 보여줍니다.

<code class="php">$pdo = new PDO("connection string etc");
$statement = $pdo->prepare('INSERT INTO `test` (SomeText,TestBool) VALUES (:someText,:testBool)');
$statement->bindValue(':someText', "TEST");
$statement->bindValue(':testBool', 0, PDO::PARAM_INT);
$statement->execute();</code>

테이크아웃

TINYINT(1)을 사용하는 것은 MySQL 데이터베이스에 부울 값을 저장하는 데 선호되는 방법입니다. 그러나 BIT(1)을 사용해야 하는 경우 PDO::PARAM_INT 유형 힌트가 포함된 바인딩값() 메서드를 사용하면 0 값을 삽입하는 문제를 해결할 수 있습니다. BIT 데이터 유형은 특정 클라이언트 라이브러리와 호환되지 않을 수 있으므로 주의해서 사용해야 한다는 점에 유의하는 것이 중요합니다.

위 내용은 PDO를 사용하여 MySQL의 BIT(1) 필드에 0을 삽입하면 1이 나오는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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