已知表a 如下: CREATE TABLE a (ID NUMBER,value1 VARCHAR(20),value2 VARCHAR(20)); INSERT INTO a VALUES (1,'A1','B1'); INSERT INTO a VALUES (1,'A2','B2'); INSERT INTO a VALUES (2,'A1','B2'); INSERT INTO a VALUES (2,'A2',NULL); 求如何用sql转换成表b: CREATE TABLE b (ID NUMBER,value1 VARCHAR(20)); INSERT INTO a VALUES (1,'A1A2'); INSERT INTO a VALUES (1,'B1B2'); INSERT INTO a VALUES (2,'A1A2'); INSERT INTO a VALUES (2,'B2');
时间: 2023-11-23 12:05:40 浏览: 90
可以使用 GROUP BY 和 CONCAT 函数来将表 a 转换成表 b,具体的 SQL 语句如下:
```
CREATE TABLE b (ID NUMBER,value1 VARCHAR(20));
INSERT INTO b
SELECT ID, CONCAT(MAX(value1), MIN(value1)) AS value1
FROM a
GROUP BY ID;
INSERT INTO b
SELECT ID, CONCAT(MAX(value2), MIN(value2)) AS value1
FROM a
GROUP BY ID
HAVING COUNT(*) = 2 AND COUNT(value2) = 2;
```
首先创建表 b,然后使用 SELECT 语句查询表 a 中的 ID 和 value1 列并使用 GROUP BY 子句按 ID 分组。使用 CONCAT 函数将每个组中的 value1 列连接成一个字符串,其中 MAX 函数返回组中 value1 列的最大值,MIN 函数返回组中 value1 列的最小值。将结果插入到表 b 中。
接下来再次使用 SELECT 语句查询表 a 中的 ID 和 value2 列,并使用 GROUP BY 子句按 ID 分组。使用 CONCAT 函数将每个组中的 value2 列连接成一个字符串,其中 MAX 函数返回组中 value2 列的最大值,MIN 函数返回组中 value2 列的最小值。在 HAVING 子句中添加条件,只有当每个组中的行数为 2 且 value2 列的非空行数为 2 时,才将结果插入到表 b 中。
最终,表 b 中的数据就与要求的结果一致。
阅读全文