单个mysql查询:要使表的NULL值和数据库中的那一列

时间:2019-05-15 10:51:33

标签: mysql sql

是否可以通过单个查询将所有列和行设置为NULL或零(0)作为其值?

我已经尝试过但未能处理数据库中的2 3个表;使它们为NULL。

3 个答案:

答案 0 :(得分:1)

也许这就是您想要或不想要的。我不明白您为什么要将现有行中的列值设置为所有NULL0。只清空表,这样就没有行会更好吗?然后,您可以添加所需的新行。

要有效地清空表,请使用truncate

truncate table t;

如果要将表中的所有列设置为值,只需使用update并列出所有列:

update t
    set col1 = null,
        col2 = null,
        . . .;

但是,我不明白为什么这样做会有用。

答案 1 :(得分:0)

要在mysql中更新多个表,可以使用以下方法:

UPDATE table1 , table2 SET table1.column = 0 , table2.column =0

如果您不知道这些字段,则可以生成查询以获取所需的所有子查询

SELECT CONCAT("UPDATE `", TABLE_SCHEMA,"`.`", TABLE_NAME, "` SET `",COLUMN_NAME,"` = 0 ") AS MySQLCMD FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = "you_db_name_here"

现在所有查询都将数据库中所有表的所有列都设为0,因此现在可以使用PREPARE EXECUTE

SET @query :="";
SELECT @query := CONCAT("UPDATE `", TABLE_SCHEMA,"`.`", TABLE_NAME, "` SET `",COLUMN_NAME,"` = 0 ") AS MySQLCMD FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = "you_db_name_here";
PREPARE stmt FROM @query;
EXECUTE stmt;

如果您有主键,这将不起作用,我们需要跳过它们,最终结果将如下所示

SET @query :="";
SELECT @query := CONCAT("UPDATE `", C.TABLE_SCHEMA,"`.`", C.TABLE_NAME, "` SET `",C.COLUMN_NAME,"` = '' ") AS MySQLCMD from information_Schema.Columns C LEFT JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE U ON C.COLUMN_NAME = U.COLUMN_NAME WHERE C.TABLE_SCHEMA = "you_db_name_here" AND U.CONSTRAINT_NAME is NULL;
PREPARE stmt FROM @query;
EXECUTE stmt;

答案 2 :(得分:0)

$sql="SELECT CONCAT('UPDATE ', TABLE_SCHEMA,'.', TABLE_NAME, ' SET ',COLUMN_NAME,' = 0;') AS MySQLCMD FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_SCHEMA = 'DATABASE_NAME' ";

$result=$conn->query($sql);
if($result->num_rows> 0){
while($row=$result->fetch_assoc()){
    $exe=$conn->query($row['MySQLCMD']);
}

}

这是我需要的答案。非常感谢您提出的所有宝贵建议。特别感谢:angel.bonev