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);
?>