修改已经存储在数据库中的数据的行为叫做更新。你可以更新 独立的行,也可以更新表中所有的行,还可以更新其中的一部分行。 我们可以独立地更新每个字段,而其他的字段则不受影响。
要执行一次更新,你需要三种信息:
表的名字和要更新的字段名,
字段的新数值,
要更新的是哪行。
我们在 Chapter 5 里说过,SQL 通常并不为数据行 提供唯一标识。因此我们无法直接声明需要更新哪一行。但是, 我们可以通过声明一个要更新的行必须满足的条件。只有在表里面 存在主键的时候(不管你叫它什么),我们才能可靠地指定一个 独立的行,方法是选取一个匹配主键的行。图形化的数据库访问 工具依赖这个东西来让我们可以独立地更新某些行。
比如,这条命令更新价格为5的所有产品的的价格为10:
UPDATE products SET price = 10 WHERE price = 5;
这样做可能导致零行,一行或者更多数据行被更新。如果我们试图 做一个不匹配任何数据行的更新,那也不算错误。
让我们仔细看看这个命令:首先是关键字 UPDATE, 然后跟着表名字。和平常一样,表名字也可以是用模式修饰的, 否则就会从路径中把它找出来。然后是关键字 SET, 后面跟着字段名,一个等号以及新的字段数值。新的字段数值可以是 任意标量表达式,而不仅仅是常量。比如,如果你想把所有产品的 价格提高10%,你可以用:
UPDATE products SET price = price * 1.10;
如你所见,用于新值的表达式也可以引用旧数值。我们还忽略了 WHERE 子句。如果我们忽略了这个子句,那么 就意味着表中的所有行都要更新。如果出现了WHERE 子句, 那么只有匹配它后面的条件的行被更新。请注意在 SET 子句 中的等号是一个赋值,而在 WHERE 子句中的等号 是比较,不过这样并不会导致任何歧义。当然条件不一定非得等于测试。 许多其他操作符也都可以使用(参阅 Chapter 9)。 但是表达式必须得出一个布尔结果。
你还可以在一个 UPDATE 命令中更新更多的字段, 方法是在 SET 子句中列出更多赋值。比如:
UPDATE mytable SET a = 5, b = 3, c = 1 WHERE a > 0;