mysql solves the problem of finding records where two or more fields are NULL

mysql solves the problem of finding records where two or more fields are NULL

Core code

/*--------------------------------
Find records t1 where two or more fields are NULL:
id, id1, id2, id3, id4, id5, id6
In the t1 table there is a field;
Where id is the primary key;
How to print the record ids where one or more of the fields are NULL?
In addition, what is the most convenient way to read records one by one in sequence during the storage process?
Note: The primary key id has no order and may also be a string;
-----------------------------------------*/
drop table if exists t1;
create table t1(id int,id1 int,id2 int,id3 int,id4 int,id5 int,id6 int);
insert t1 select
1,1,1,1,1,null,null union all select 
2,null,null,null,1,2,3 union all select 
3,1,2,3,4,5,6 union all select 
4,1,2,3,4,5,null union all select 
5,null,3,4,null,null,null ;
delimiter $$
create procedure usp_c_null()
begin 
declare n_c int;
declare idd int;
declare cur cursor for 
select id,case char_length(concat(ifnull(id1,'@'),ifnull(id2,'@'),ifnull(id3,'@'),ifnull(id4,'@'),ifnull(id5,'@'),ifnull(id6,'@')))
- char_length(replace(concat(ifnull(id1,'@'),ifnull(id2,'@'),ifnull(id3,'@'),ifnull(id4,'@'),ifnull(id5,'@'),ifnull(id6,'@')),'@','') )
 when 6 then 6 when 5 then 5 when 4 then 4 when 3 then 3 when 2 then 2 when 1 then 1 else 0 end as c from t1;
declare exit HANDLER for not found close cur ;
open cur;
repeat 
fetch cur into idd,n_c;
if(n_c>=2) then
select * from t1 where id=idd;
end if ;
until 0 end repeat;
close cur;
end ;
$$
delimiter ;
/*
+------+------+------+------+------+------+------+
| id | id1 | id2 | id3 | id4 | id5 | id6 |
+------+------+------+------+------+------+------+
| 1 | 1 | 1 | 1 | 1 | NULL | NULL |
+------+------+------+------+------+------+------+
1 row in set (0.10 sec)
+------+------+------+------+------+------+------+
| id | id1 | id2 | id3 | id4 | id5 | id6 |
+------+------+------+------+------+------+------+
| 2 | NULL | NULL | NULL | 1 | 2 | 3 |
+------+------+------+------+------+------+------+
1 row in set (0.14 sec)
+------+------+------+------+------+------+------+
| id | id1 | id2 | id3 | id4 | id5 | id6 |
+------+------+------+------+------+------+------+
| 5 | NULL | 3 | 4 | NULL | NULL | NULL |
+------+------+------+------+------+------+------+
1 row in set (0.17 sec)
*/

You may also be interested in:
  • Why should MySQL fields use NOT NULL?
  • Should nullable fields in MySQL be set to NULL or NOT NULL?
  • MySQL query empty fields or non-empty fields (is null and not null)
  • Analysis of the reasons why MySQL field definitions should not use null

<<:  Detailed explanation of for loop and double for loop in JavaScript

>>:  Detailed explanation of common Docker Compose commands

Recommend

HTML iframe usage summary collection

Detailed Analysis of Iframe Usage <iframe frame...

Using js to implement a number guessing game

Last week, the teacher gave me a small homework, ...

How to implement image mapping with CSS

1. Introduction Image maps allow you to designate...

Detailed explanation of nginx installation, deployment and usage on Linux

Table of contents 1. Download 2. Deployment 3. Ng...

Three.js realizes Facebook Metaverse 3D dynamic logo effect

Table of contents background What is the Metavers...

Reasons why MySQL kill cannot kill threads

Table of contents background Problem Description ...

Detailed process of installing Presto and connecting Hive in Docker

1. Introduction Presto is an open source distribu...

What are the core modules of node.js

Table of contents Global Object Global objects an...

translate(-50%,-50%) in CSS achieves horizontal and vertical centering effect

translate(-50%,-50%) attributes: Move it up and l...

How to install Jenkins using Docker

Table of contents 1. Pull the image 2. Create a l...

MySql fuzzy query json keyword retrieval solution example

Table of contents Preface Option 1: Option 2: Opt...

Docker FAQ

Docker only maps ports to IPv6 but not to IPv4 St...

Detailed explanation of Vue advanced construction properties

Table of contents 1. Directive custom directive 2...

JavaScript to implement limited time flash sale function

This article shares the specific code of JavaScri...

W3C Tutorial (6): W3C CSS Activities

A style sheet describes how a document should be ...