sql在程序中最有可能发生错误的语句是:
A.INSERTINTOemp(empno,ename)VALUES(8888,'Jone')B.UPDATEempSETsal=sal+100C.DELETEFROMe...
A. INSERT INTO emp(empno,ename) VALUES(8888,'Jone')
B. UPDATE emp SET sal=sal+100
C. DELETE FROM emp
D. SELECT * FROM emp
为什么? 展开
B. UPDATE emp SET sal=sal+100
C. DELETE FROM emp
D. SELECT * FROM emp
为什么? 展开
5个回答
展开全部
A. INSERT INTO emp(empno,ename) VALUES(8888,'Jone')
A只是插入值的时候要区分下empno是不是int型的,ename是不是char型的,如果不匹配则会出错,和多少多少列没关系,但严防一些列是不是不能插入空值
B. UPDATE emp SET sal=sal+100
B可以这样写,但注意的是,这条语句一执行,则会更新emp表的所以数据行中sal列的值
C. DELETE FROM emp
C没啥关系,但不推荐使用,对于删除一个表,如果这个表有主外键相关的话,删除会报错。而且在数据库中就随便这么一执行下就删除一个表,如果处理不好,会对整个数据库都有影响,所以不推荐使用。但语句没错。
D. SELECT * FROM emp
D可以执行,没问题,只要数据库存在emp这个表,就算不存在,也只是会提醒不存在此表。
然后请看题目,A\B\C\D四个选项分别代表的是:insert,update,delete,select四个操作语句,而只有select是不会对数据造成影响的,也不会修改任何数据,。
如果说单单只是insert,update,delete,select的话,那么前面三个的危险系数是高的。而select是没关系的。
A只是插入值的时候要区分下empno是不是int型的,ename是不是char型的,如果不匹配则会出错,和多少多少列没关系,但严防一些列是不是不能插入空值
B. UPDATE emp SET sal=sal+100
B可以这样写,但注意的是,这条语句一执行,则会更新emp表的所以数据行中sal列的值
C. DELETE FROM emp
C没啥关系,但不推荐使用,对于删除一个表,如果这个表有主外键相关的话,删除会报错。而且在数据库中就随便这么一执行下就删除一个表,如果处理不好,会对整个数据库都有影响,所以不推荐使用。但语句没错。
D. SELECT * FROM emp
D可以执行,没问题,只要数据库存在emp这个表,就算不存在,也只是会提醒不存在此表。
然后请看题目,A\B\C\D四个选项分别代表的是:insert,update,delete,select四个操作语句,而只有select是不会对数据造成影响的,也不会修改任何数据,。
如果说单单只是insert,update,delete,select的话,那么前面三个的危险系数是高的。而select是没关系的。
展开全部
A还一种情况就是ename可能是数字类型的,那字符就不能插入了
B的话字符数字都可以加
C的话没任何影响,语句没这样写的,但也不是错的
D的话就更不是错的了
B的话字符数字都可以加
C的话没任何影响,语句没这样写的,但也不是错的
D的话就更不是错的了
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
A.因为emp表可能某些字段不允许为空,因此插入的时候只修改两个字段很可能出错
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
A
因为比如你表内列字段多的时候
value赋值的位置容易混淆
比如你一个表30个列名,你就知道了
因为比如你表内列字段多的时候
value赋值的位置容易混淆
比如你一个表30个列名,你就知道了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2010-12-19
展开全部
最有可能的是A. INSERT INTO emp(empno,ename) VALUES(8888,'Jone')
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询