MySQLi-NULL 값 처리

우리는 SQL을 보았다 SELECT 함께 명령 WHERE MySQLi 테이블에서 데이터를 가져 오는 절이지만 필드 또는 열 값을 비교하는 조건을 제공하려고 할 때 NULL, 제대로 작동하지 않습니다.

이러한 상황을 처리하기 위해 MySQLi는 세 가지 연산자를 제공합니다.

  • IS NULL − 연산자는 열 값이 NULL이면 true를 반환합니다.

  • IS NOT NULL − 연산자는 열 값이 NULL이 아니면 참을 반환합니다.

  • <=> − 연산자는 두 개의 NULL 값에 대해서도 참인 값 (= 연산자와 달리)을 비교합니다.

NULL을 포함하는 조건은 특별합니다. = NULL 또는! = NULL을 사용하여 열에서 NULL 값을 찾을 수 없습니다. 그러한 비교는 그것이 사실인지 아닌지를 알 수 없기 때문에 항상 실패합니다. NULL = NULL도 실패합니다.

NULL이거나 NULL이 아닌 열을 찾으려면 IS NULL 또는 IS NOT NULL을 사용하십시오.

명령 프롬프트에서 NULL 값 사용

테이블을 가정 tutorials_bks TUTORIALS 데이터베이스에 있으며 두 개의 열이 있습니다. id name, NULL 이름은 값을 알 수 없음을 나타냅니다-

다음 예제를 시도하십시오-

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

mysql> INSERT INTO tutorials_bks (book) values('NULL');
Query OK, 1 row affected (0.08 sec)

+----+---------+
| id | book    |
+----+---------+
|  1 | java    |
|  2 | java    |
|  3 | html    |
|  4 | c++     |
|  5 | Android |
|  6 |         |
|  7 |         |
|  8 |         |
|  9 | NULL    |
| 10 | NULL    |
| 11 | NULL    |
+----+---------+
11 rows in set (0.00 sec)

mysql>

이름 열이 NULL이거나 NULL이 아닌 레코드를 찾으려면 쿼리를 다음과 같이 작성해야합니다.

mysql> SELECT * FROM tutorials_bks WHERE book = "null";
+----+------+
| id | book |
+----+------+
|  9 | NULL |
| 10 | NULL |
| 11 | NULL |
+----+------+
3 rows in set (0.00 sec)

mysql> SELECT * FROM tutorials_bks WHERE book ! = "null";
+----+---------+
| id | book    |
+----+---------+
|  1 | java    |
|  2 | java    |
|  3 | html    |
|  4 | c++     |
|  5 | Android |
|  6 |         |
|  7 |         |
|  8 |         |
+----+---------+
8 rows in set (0.00 sec)

mysql> SELECT * FROM tutorials_bks WHERE book = "";
+----+------+
| id | book |
+----+------+
|  6 |      |
|  7 |      |
|  8 |      |
+----+------+
3 rows in set (0.01 sec)

PHP 스크립트에서 NULL 값 처리

if ... else 조건을 사용 하여 NULL 값을 기반으로 쿼리를 준비 할 수 있습니다 .

다음 예제는 외부에서 tutorial_count를 가져온 다음 테이블에서 사용 가능한 값과 비교합니다.

<?php
   $dbhost = 'localhost:3036';
   $dbuser = 'root';
   $dbpass = 'rootpassword';
   $conn = mysql_connect($dbhost, $dbuser, $dbpass);
   
   if(! $conn ) {
      die('Could not connect: ' . mysql_error());
   }
   if( isset($tutorial_count )) {
      $sql = 'SELECT tutorial_author, tutorial_count FROM  tcount_tbl
         WHERE tutorial_count = $tutorial_count';
   } else {
      $sql = 'SELECT tutorial_author, tutorial_count
         FROM  tcount_tbl WHERE tutorial_count IS $tutorial_count';
   }
   mysql_select_db('TUTORIALS');
   $retval = mysql_query( $sql, $conn );
   
   if(! $retval ) {
      die('Could not get data: ' . mysql_error());
   }
   while($row = mysql_fetch_array($retval, MYSQL_ASSOC)) {
      echo "Author:{$row['tutorial_author']}  <br> ".
         "Count: {$row['tutorial_count']} <br> ".
         "--------------------------------<br>";
   } 
   echo "Fetched data successfully\n";
   mysql_close($conn);
?>