NULL có giống với 0 MySQL không?

Trong hướng dẫn này, tôi sẽ giải thích về cách làm việc với NULL trong MySQL bằng các ví dụ. Bài viết này sẽ bao gồm các chủ đề sau. Hãy xem nào

  1. Giới thiệu
  2. Ví dụ về giá trị NULL của MySQL
  3. MySQL SET NULL Giá trị trong Tuyên bố CẬP NHẬT
  4. Các hàm liên quan đến giá trị NULL trong MySQL
  5. Phần kết luận

Khái niệm về giá trị null là một vấn đề phổ biến đối với người mới bắt đầu. Null giống như một chuỗi rỗng. Trong MySQL, máy chủ không làm gì để không cho phép null làm giá trị của biểu thức được phân phối, cho dù đó là giá trị cột hay giá trị của biểu thức do người dùng cung cấp. Null là bất thường vì nó không đại diện cho một giá trị cụ thể theo cách mà các giá trị số, chuỗi hoặc thời gian thực hiện. Mặc dù được phép sử dụng Null làm giá trị của một biểu thức mà nếu không thì nó phải mang lại một số nguyên, nhưng điều quan trọng cần lưu ý là null không phải là một số

NULL được định nghĩa là, một thuật ngữ có giá trị khác 0 và chuỗi rỗng, i. e. giá trị không xác định hoặc dấu hiệu cho thấy dữ liệu bị thiếu

Ví dụ về giá trị NULL của MySQL

Chúng tôi cho rằng có một bảng có tên là “GrowthMindsets” trong cơ sở dữ liệu “csharpcorner” với một số dữ liệu giả trong đó. Hãy xem nào

Tạo một bảng

  1. DROP BẢNG NẾU TỒN TẠI GrowthMindSets;
  2. TẠO BẢNG GrowthMindSets[
  3. GMS_ID INT AUTO_INCREMENT KEY chính,
  4. First_Name VARCHAR[50] KHÔNG NULL,
  5. Họ_VARCHAR[50] KHÔNG NULL,
  6. MÔ TẢ VARCHAR[255] KHÔNG NULL,
  7. Địa chỉ email VARCHAR[100],
  8. Điện thoạiKhông BIGINT
  9. ];

Bây giờ, chèn một số dữ liệu giả vào nó

  1. CHÈN VÀO GrowthMindSets[First_Name, Last_Name, DESCRIPTION, EmailAddress, PhoneNo] VALUES['Vatsa', 'Admin', 'Expert in Business', 'test@gmail. com', '9876543211'],
  2. ['Onkar', 'Quản trị viên', 'Chuyên gia trong Phát triển', 'test1@gmail. com', '9876543221'],
  3. ['Rohit', 'Quản trị viên', 'Chuyên gia về Truyền thông', NULL, '9876543231'],
  4. ['Jasmine', 'Quản trị viên', 'Chuyên gia trong DBA', 'test@gmail. com', NULL],
  5. ['Anamika', 'Quản trị viên', 'Chuyên gia trong BDA', NULL, NULL];

Bây giờ, bạn có thể kiểm tra dữ liệu bảng của mình bằng cách nhập truy vấn sau

  1. CHỌN * TỪ GrowthMindSets;

Ở đây, chúng ta có thể thấy biểu tượng “=” và “. =” không hoạt động với các giá trị “NULL” như sau

  1. CHỌN * TỪ GrowthMindSets WHERE tutorial_count = NULL;
  2. CHỌN * TỪ GrowthMindSets Ở ĐÂU tutorial_count. = NULL;

Để tìm các bản ghi trong đó cột “EmailAddress” bằng hoặc không bằng NULL, các truy vấn phải được viết như sau

  1. CHỌN * TỪ GrowthMindSets
  2. Ở ĐỊA CHỈ Địa chỉ Email LÀ NULL;

  1. CHỌN * TỪ GrowthMindSets
  2. Ở ĐÂU Địa chỉ Email KHÔNG PHẢI là NULL;

Các giá trị SET NULL của MySQL trong câu lệnh CẬP NHẬT

Bằng cách sử dụng toán tử gán [“=”], bạn có thể đặt bất kỳ giá trị nào của một cột thành NULL bằng cách sử dụng Câu lệnh cập nhật

  1. CẬP NHẬT tư duy phát triển
  2. SET Địa chỉ Email = NULL
  3. Ở ĐÂU GMS_ID = 4 và GMS_ID = 5

Bằng cách sử dụng truy vấn sau, bạn có thể kiểm tra đầu ra

  1. CHỌN * TỪ BỘT TƯ DUY PHÁT TRIỂN
  2. Ở ĐÂU Địa chỉ email  LÀ NULL VÀ Số điện thoại IS NULL

GIÁ TRỊ NULL CÁC CHỨC NĂNG LIÊN QUAN TRONG MYSQL

1] Trong MYSQL có một số hàm dành riêng để sử dụng với các giá trị NULL, bao gồm ISNULL [] và IFNULL []. ISNULL[] là đúng nếu đối số của nó là NULL và sai nếu ngược lại

  1. CHỌN ISNULL[NULL], ISNULL[0], ISNULL[1];

2] IFNULL[] nhận hai đối số. Nếu đối số đầu tiên không phải là NULL, thì đối số đó được trả về;

  1. CHỌN IFNULL[NULL,'a'], IFNULL[0,'b'];

Trong ví dụ này, tôi sẽ chỉ cho bạn một truy vấn trả về chuỗi rỗng [‘’] nếu giá trị của nó là NULL

  1. CHỌN First_Name, Last_Name, Description, IFNULL[EmailAddress, ''], IFNULL[PhoneNo, ''] TỪ GROWTHMINDSETS;

3] Các hàm khác xử lý giá trị NULL theo nhiều cách khác nhau, vì vậy bạn phải biết cách hoạt động của một hàm đã cho. Trong nhiều trường hợp, việc truyền giá trị NULL cho hàm dẫn đến giá trị trả về NULL

Bất kỳ đối số NULL nào được chuyển đến CONCAT[] đều khiến nó trả về NULL

  1. CHỌN CONCAT['a','b'], CONCAT['a',NULL,'b'];

4] Nhưng không phải chức năng nào cũng hoạt động theo cách đó. CONCAT_WS[] [nối với dấu tách] chỉ cần bỏ qua hoàn toàn các đối số NULL

Ví dụ

  1. CHỌN CONCAT_WS['/','a','b'], CONCAT_WS['/','a',NULL,'b'];

Dưới đây là một số tài nguyên liên quan hữu ích

Trong bài viết này, tôi đã thảo luận về khái niệm xử lý giá trị NULL trong MySQL với nhiều ví dụ khác nhau

NULL và 0 có giống nhau trong SQL không?

Không nên nhầm lẫn null với giá trị 0 . Giá trị null biểu thị thiếu giá trị, giá trị này không giống với giá trị bằng 0.

NULL có được đặt 0 MySQL không?

Sử dụng hàm IFNULL hoặc COALESCE[] để chuyển MySQL NULL thành 0 . Chèn một số bản ghi vào bảng bằng lệnh chèn. Hiển thị tất cả các bản ghi từ bảng bằng cách sử dụng câu lệnh chọn.

Giá trị NULL có giống 0 không?

Không giống như số 0, giá trị null không phải là giá trị tuyệt đối hoặc thứ gì đó có thể định lượng được; . Vì vậy, chúng không nên được lưu trữ dưới dạng số [i. e. 0, -999, 999, v.v. ]. Bảng bên dưới cung cấp thông tin về cách tốt nhất và tệ nhất để mã hóa giá trị null trong tập dữ liệu. . As such they should not be stored as numbers [i.e. 0, -999, 999, etc.]. The table below provides information on the best and worst ways to encode null values in a dataset.

IS NULL được coi là 0 trong SQL?

Trong SQL Server, giá trị NULL cho biết giá trị không khả dụng hoặc chưa được gán. Giá trị NULL không bằng 0 [0] , cũng không bằng khoảng trắng [' ']. Vì giá trị NULL không thể bằng hoặc không bằng với bất kỳ giá trị nào nên bạn không thể thực hiện bất kỳ phép so sánh nào trên giá trị này bằng cách sử dụng các toán tử như '=' hoặc ''.

Chủ Đề