การแสดงสตริงว่างในชุดผลลัพธ์ขึ้นอยู่กับประเภทข้อมูลเมื่อเราแทรกสตริงว่างลงในคอลัมน์ MySQL ซึ่งประกาศเป็น NOT NULL ดังที่เราทราบดีว่าในการแทรกสตริงว่างนั้น เรากำลังให้ค่ากับ MySQL ที่มีการแสดงจำนวนเต็มเป็น INT 0
ตอนนี้ หากคอลัมน์นั้นมีประเภทข้อมูล INTEGER แล้ว MySQL จะแสดง 0 ในชุดผลลัพธ์เนื่องจากสตริงว่างนั้นถูกแมปเป็นศูนย์เป็นจำนวนเต็ม
ตัวอย่าง
mysql> create table test(id int NOT NULL, Name Varchar(10));
Query OK, 0 rows affected (0.19 sec)
mysql> Insert into test(id, name) values('1', 'Gaurav'),('0','Rahul'),('','Aarav');
Query OK, 3 rows affected, 1 warning (0.08 sec)
Records: 3 Duplicates: 0 Warnings: 1
mysql> Select * from test;
+----+--------+
| id | Name |
+----+--------+
| 1 | Gaurav |
| 0 | Rahul |
| 0 | Aarav |
+----+--------+
3 rows in set (0.00 sec) แต่ถ้าคอลัมน์นั้นมีข้อมูลประเภทอื่นว่า VARCHAR แล้ว MySQL จะแสดงสตริงว่างในชุดผลลัพธ์
mysql> create table test123(id Varchar(10) NOT NULL, Name Varchar(10));
Query OK, 0 rows affected (0.19 sec)
mysql> Insert into test123(id, name) values('1', 'Gaurav'),('0','Rahul'),('','Aarav');
Query OK, 3 rows affected, 1 warning (0.08 sec)
Records: 3 Duplicates: 0 Warnings: 1
mysql> Select * from test123;
+----+--------+
| id | Name |
+----+--------+
| 1 | Gaurav |
| 0 | Rahul |
| | Aarav |
+----+--------+
3 rows in set (0.00 sec) จากตัวอย่างข้างต้น เราจะเห็นได้ว่าประเภทข้อมูลมีบทบาทอย่างไรเมื่อเราแทรกสตริงว่างลงในคอลัมน์ MySQL ซึ่งถูกประกาศว่าไม่ใช่ NULL