是否可以通过单个查询将所有列和行设置为NULL或零(0)作为其值?
我已经尝试过但未能处理数据库中的2 3个表;使它们为NULL。
答案 0 :(得分:1)
也许这就是您想要或不想要的。我不明白您为什么要将现有行中的列值设置为所有NULL
或0
。只清空表,这样就没有行会更好吗?然后,您可以添加所需的新行。
要有效地清空表,请使用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