无涯教程-H2数据库 - 更新数据(Update)

127 阅读2分钟

UPDATE查询用于更新或修改表中的现有记录,无涯教程可以将WHERE子句与UPDATE查询一起使用来更新所选行,否则所有行都会受到影响。

Update - 语法

以下是UPDATE查询的基本语法。

UPDATE tableName [ [ AS ] newTableAlias ] SET 
{ { columnName={ DEFAULT | expression } } [,...] } | 
{ ( columnName [,...] )=( select ) } 
[ WHERE expression ] [ ORDER BY order [,...] ] [ LIMIT expression ]

在这种UPDATE语法中,无涯教程可以使用ANDOR子句组合多个条件。

Update - 示例

考虑具有以下记录的CUSTOMER表。

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | MP        |  4500.00 | 
|  7 | Learnfk    |  24 | Indore    | 10000.00 | 
+----+----------+-----+-----------+----------+ 

如果要获取客户表以及给定的数据,请执行以下查询。

CREATE TABLE CUSTOMER (id number, name varchar(20), age number, address varchar(20), 
   salary number);  
INSERT into CUSTOMER values (1, Ramesh, 32, Ahmedabad, 2000); 
INSERT into CUSTOMER values (2, Khilan, 25, Delhi, 1500); 
INSERT into CUSTOMER values (3, kaushik, 23, Kota, 2000); 
INSERT into CUSTOMER values (4, Chaitali, 25, Mumbai, 6500); 
INSERT into CUSTOMER values (5, Hardik, 27, Bhopal, 8500); 
INSERT into CUSTOMER values (6, Komal, 22, MP, 4500); 
INSERT into CUSTOMER values (7, Learnfk, 24, Indore, 10000);

以下命令是一个示例,它将为ID为6的客户更新ADDRESS-

UPDATE CUSTOMERS SET ADDRESS=Pune WHERE ID=6;

现在,CUSTOMERS表将具有以下记录,无涯教程可以通过执行以下查询来检查客户表记录。

SELECT * FROM CUSTOMERS;

上面的查询产生以下输出。

+----+----------+-----+-----------+----------+ 
| ID | NAME     | AGE | ADDRESS   | SALARY   | 
+----+----------+-----+-----------+----------+ 
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 | 
|  2 | Khilan   |  25 | Delhi     |  1500.00 | 
|  3 | kaushik  |  23 | Kota      |  2000.00 | 
|  4 | Chaitali |  25 | Mumbai    |  6500.00 | 
|  5 | Hardik   |  27 | Bhopal    |  8500.00 | 
|  6 | Komal    |  22 | Pune      |  4500.00 | 
|  7 | Learnfk    |  24 | Indore    | 10000.00 | 
+----+----------+-----+-----------+----------+ 

要修改CUSTOMERS表中的所有ADDRESS和SALARY列值,无涯教程不需要使用WHERE子句。 UPDATE查询将如下所示-

UPDATE CUSTOMERS SET ADDRESS=Pune, SALARY=1000.00; 

现在,CUSTOMERS表将具有以下记录。无涯教程可以通过执行以下查询来检查客户表记录。

SELECT * FROM CUSTOMERS;

上面的查询产生以下输出-

+----+----------+-----+---------+---------+ 
| ID | NAME     | AGE | ADDRESS | SALARY  | 
+----+----------+-----+---------+---------+ 
|  1 | Ramesh   |  32 | Pune    | 1000.00 | 
|  2 | Khilan   |  25 | Pune    | 1000.00 | 
|  3 | kaushik  |  23 | Pune    | 1000.00 | 
|  4 | Chaitali |  25 | Pune    | 1000.00 | 
|  5 | Hardik   |  27 | Pune    | 1000.00 | 
|  6 | Komal    |  22 | Pune    | 1000.00 | 
|  7 | Learnfk    |  24 | Pune    | 1000.00 | 
+----+----------+-----+---------+---------+ 

参考链接

www.learnfk.com/h2/h2-datab…