客户(客户号,名称,联系人,邮政编码,电话号码) 产品(产品号,名称,规格说明,单价) 订购单 (订单号,客户号,订购日期) 订购甲名细(订单号,序号,产品号,数量) 假设客户表中有客户号(关键字)C1~C10共10条客户记录,订购单表有订单号(关键字)

admin2014-11-29  41

问题 客户(客户号,名称,联系人,邮政编码,电话号码)
产品(产品号,名称,规格说明,单价)
订购单 (订单号,客户号,订购日期)
订购甲名细(订单号,序号,产品号,数量)
假设客户表中有客户号(关键字)C1~C10共10条客户记录,订购单表有订单号(关键字)OR1~0R8共8条订购单记录,并且订购单表参照客户表。如下命令可以正确执行的是(    )。

选项 A、INSERT INTO订购单VALUES(‘OR5’,‘C5’,{^2008/10/10})
B、INSERT INTO订购单VALUES(‘OR5’.  ’C11’,{^2008/10/10})
C、INSERT INTO订购单VALUES(’OR9’.‘C11’,{^2008/10/10})
D、INSERT INTO订购单VALUES(‘OR9’.‘C5’,{^2008/10/10})

答案D

解析 本题中,客户表和订购单表是相互关联的表,其中客户号是公共字段,客户表是父表,订购单表是子表,题目中说明了订购单表参照客户表,即实施了参照完整性规则。当要向订购单表中插入一条记录时要注意两点:
    ①新记录的订单号不能与表中已有记录的订单号重复,因为订单号是订购单表的主关键字。而题中说明订购单表中已有订购单号OR1~OR8,就不能再插  入订单号为OR5的记录。
    ②由于订购单表要参照客户表,所以在要插入记录的表中,如果联接字段值在父表中没有相匹配的值,则禁止插入。而题中说明父表客户表中并没有Cll这个客户号,因此在子表订购单表中不能插入客户号为Cll的记录。
    SQL中,插入操作的命令格式如下:
    INSERT INTO db_name[(fhame1[,fhame2,…])]VALUES(eExpression1[eExpression2,…])
    其中 dbf name指定要插入的表,当插入的不是完整记录时,可以用fname1,fname2,…指定字段,VALUES给出具体的记录值。
转载请注明原文地址:https://kaotiyun.com/show/jOop777K
0

最新回复(0)