QUESTION 31 CREATE table 注意事项

本文分析了四个CREATE TABLE语句示例,指出每个语句的问题所在,并确定了正确的表格创建方式。强调了一个表只能有一个主键,UNIQUE与NOT NULL间不应有逗号,以及DEFAULT NOT NULL需要指定默认值等关键点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

32. Which CREATE TABLE statement is valid? 
A. CREATE TABLE ord_details         
(ord_no NUMBER(2) PRIMARY KEY,  
item_no NUMBER(3) PRIMARY KEY,  
ord_date DATE NOT NULL); 
B. CREATE TABLE ord_details         
(ord_no NUMBER(2) UNIQUE, NOT NULL,  
item_no NUMBER(3),  
ord_date DATE DEFAULT SYSDATE NOT NULL); 
C. CREATE TABLE ord_details         
(ord_no NUMBER(2) ,  
item_no NUMBER(3),  
ord_date DATE DEFAULT NOT NULL,  
CONSTRAINT ord_uq UNIQUE (ord_no),  
CONSTRAINT ord_pk PRIMARY KEY (ord_no)); 
D. CREATE TABLE ord_details  
(ord_no NUMBER(2),  
item_no NUMBER(3),  
ord_date DATE DEFAULT SYSDATE NOT NULL,  
CONSTRAINT ord_pk PRIMARY KEY (ord_no, item_no)); 


答案:D

解析:

--A选项错误,一个表不能有两个主键
SQL> CREATE TABLE ord_details
  2  (ord_no NUMBER(2) PRIMARY KEY,
  3  item_no NUMBER(3) PRIMARY KEY,
  4  ord_date DATE NOT NULL);
item_no NUMBER(3) PRIMARY KEY,
                  *
ERROR at line 3:
ORA-02260: table can have only one primary key

--B选项错误,UNIQUE和NOT NULL之间应该没有逗号。
SQL> CREATE TABLE ord_details
  2  (ord_no NUMBER(2) UNIQUE, NOT NULL,
  3  item_no NUMBER(3),
  4  ord_date DATE DEFAULT SYSDATE NOT NULL);
(ord_no NUMBER(2) UNIQUE, NOT NULL,
                          *
ERROR at line 2:
ORA-00904: : invalid identifier

--C选项错误,有两处,一个是在ord_date DATE DEFAULT NOT NULL未指定默认值,一个是创建主键约束的时候会创建一个唯一约束和一个主键约束,因此再次建立唯一约束会导致错误
SQL> CREATE TABLE ord_details
  2  (ord_no NUMBER(2) ,
  3  item_no NUMBER(3),
  4  ord_date DATE DEFAULT NOT NULL,
  5  CONSTRAINT ord_uq UNIQUE (ord_no),
  6  CONSTRAINT ord_pk PRIMARY KEY (ord_no));
ord_date DATE DEFAULT NOT NULL,
                      *
ERROR at line 4:
ORA-00936: missing expression
SQL>  CREATE TABLE ord_details
  2   (ord_no NUMBER(2) ,
  3   item_no NUMBER(3),
  4   ord_date DATE DEFAULT to_date(20140101,'yyyymmdd') NOT NULL,
  5   CONSTRAINT ord_uq UNIQUE (ord_no),
  6   CONSTRAINT ord_pk2 PRIMARY KEY (ord_no));
 CONSTRAINT ord_uq UNIQUE (ord_no),
                   *
ERROR at line 5:
ORA-02261: such unique or primary key already exists in the table

--D选项正确,顺利执行
SQL>  CREATE TABLE ord_details
  2  (ord_no NUMBER(2),
  3  item_no NUMBER(3),
  4  ord_date DATE DEFAULT SYSDATE NOT NULL,
  5  CONSTRAINT ord_pk1 PRIMARY KEY (ord_no, item_no));

Table created.



在 ClickHouse 中执行类似于其他关系型数据库中的 `UPDATE ... FROM` 操作时,由于 ClickHouse 的设计初衷并非完全支持传统的关系型操作模式,因此其语法和功能有所差异。以下是实现该需求的方法。 ClickHouse 不直接支持标准 SQL 的 `UPDATE ... FROM` 语法,但可以通过以下方式间接达成目标: ### 方法一:使用 `ALTER TABLE ... UPDATE` 如果表 A 和表 B 已经存在,并且满足 ClickHouse 对于 `ALTER TABLE ... UPDATE` 的限制条件,则可以尝试如下语句[^1]: ```sql ALTER TABLE a UPDATE hot_id = ( SELECT b.hot_question_id FROM b WHERE a.hot_question_new = b.hot_question ) WHERE hot_question_new IN (SELECT DISTINCT hot_question FROM b); ``` #### 注意事项: - 子查询 `(SELECT b.hot_question_id FROM b WHERE a.hot_question_new = b.hot_question)` 必须返回唯一的值,否则会报错。 - 上述语句仅适用于 MergeTree 类型的表,并且需要确保引擎版本支持 `ALTER TABLE ... UPDATE` 功能。 - 如果数据量较大或者子查询复杂度较高,可能会导致性能下降。 --- ### 方法二:重建表 A 当无法直接修改现有数据时,另一种常见做法是创建一张新表并重新插入更新后的数据。具体步骤如下: 1. 创建临时表存储更新结果; 2. 将原始表 A 数据与表 B 关联后生成新的记录集; 3. 替换原表 A。 示例代码如下: ```sql CREATE TABLE temp_a AS a ENGINE = Memory; INSERT INTO temp_a SELECT a.id, COALESCE(b.hot_question_id, a.hot_id) AS hot_id, -- 若无匹配则保留原有值 a.hot_question_new, a.is_shield FROM a LEFT JOIN b ON a.hot_question_new = b.hot_question; -- 替换原表 RENAME TABLE a TO old_a, temp_a TO a; -- 清理旧表(可选) DROP TABLE IF EXISTS old_a; ``` 这种方法虽然稍显繁琐,但在大规模数据场景下通常更加稳定可靠。 --- ### 性能调优建议 无论采用哪种方案,都应注意以下几点以提高效率: - 确保参与连接的关键列已建立索引(如适用)。 - 控制中间结果集规模,避免内存溢出等问题发生。 - 测试过程中逐步增加输入数据范围,观察实际运行表现调整策略。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值