sql数据库基础面试题复习题考试题-全
SQL基础知识题库100道及答案(完整版)
SQL基础知识题库100道及答案(完整版)1. 在SQL 中,用于创建表的语句是()A. CREATE TABLEB. INSERT INTOC. UPDATED. DELETE答案:A2. 以下哪个关键字用于在SQL 中添加数据()A. ADDB. INSERTC. APPENDD. PUT答案:B3. 在SQL 中,用于从表中检索数据的语句是()A. SELECTB. GETC. FETCHD. REQUEST答案:A4. 以下哪个关键字用于在SQL 中更新数据()A. MODIFYB. CHANGEC. UPDATED. REPLACE答案:C5. 要从表中删除数据,应使用的SQL 语句是()A. DROPB. DELETEC. REMOVED. CLEAR答案:B6. SQL 中用于创建索引的关键字是()A. CREATE INDEXB. MAKE INDEXC. BUILD INDEXD. ESTABLISH INDEX答案:A7. 以下哪种数据类型用于存储整数()A. INTB. FLOATC. VARCHARD. DATE答案:A8. 用于存储字符串的常见数据类型是()A. CHARB. INTC. DECIMALD. DOUBLE答案:A9. 在SQL 中,用于对结果集进行排序的关键字是()A. SORTB. ORDER BYC. ARRANGED. ALIGN答案:B10. 以下哪个运算符用于等于比较()A. =B. ==C. <>D. >答案:A11. 用于不等于比较的运算符是()A.!=B. < >C. NOT EQUALSD. DIFFERENT答案:B12. 以下哪个运算符用于大于比较()A. >B. >=C. <D. <=答案:A13. 用于小于比较的运算符是()A. <B. <=C. >D. >=答案:A14. 以下哪个关键字用于在SQL 中进行分组操作()A. GROUP BYB. SORT BYC. CLASSIFY BYD. CATEGORIZE BY答案:A15. 聚合函数SUM 用于()A. 计算总和B. 计算平均值C. 计算数量D. 计算最小值答案:A16. 聚合函数AVG 用于()A. 计算总和B. 计算平均值C. 计算数量D. 计算最大值答案:B17. COUNT 函数用于()A. 计算总和B. 计算平均值C. 计算数量D. 计算最小值答案:C18. MAX 函数用于()A. 计算总和B. 计算平均值C. 计算最大值D. 计算最小值答案:C19. MIN 函数用于()A. 计算总和B. 计算平均值C. 计算最大值D. 计算最小值答案:D20. 在SQL 中,用于连接两个表的关键字是()A. JOINB. CONNECTC. LINKD. BIND答案:A21. 内连接使用的关键字是()A. INNER JOINB. LEFT JOINC. RIGHT JOIND. FULL JOIN答案:A22. 左连接使用的关键字是()A. INNER JOINB. LEFT JOINC. RIGHT JOIND. FULL JOIN答案:B23. 右连接使用的关键字是()A. INNER JOINB. LEFT JOINC. RIGHT JOIND. FULL JOIN答案:C24. 全连接使用的关键字是()A. INNER JOINB. LEFT JOINC. RIGHT JOIND. FULL JOIN答案:D25. 在SQL 中,用于限制结果集行数的关键字是()A. LIMITB. RESTRICTC. BOUNDD. CONSTRAINT答案:A26. 以下哪个子句用于在SQL 中进行条件筛选()A. WHEREB. HAVINGC. FROMD. GROUP BY答案:A27. HAVING 子句通常与()一起使用A. GROUP BYB. ORDER BYC. WHERED. FROM答案:A28. 在SQL 中,用于创建视图的语句是()A. CREATE VIEWB. MAKE VIEWC. BUILD VIEWD. ESTABLISH VIEW 答案:A29. 以下哪个关键字用于删除视图()A. DROP VIEWB. DELETE VIEWC. REMOVE VIEWD. CLEAR VIEW 答案:A30. 要在SQL 中添加注释,可以使用()A. //B. /* */C. #D. --答案:D31. 在SQL 中,以下哪种数据类型用于存储日期和时间()A. DATEB. TIMEC. DATETIMED. TIMESTAMP答案:C32. 用于提取日期部分的函数是()A. DATEPART()B. DAY()C. MONTH()D. YEAR()答案:A33. 以下哪个函数用于计算字符串的长度()A. LENGTH()B. SIZE()C. COUNT()D. LEN()答案:A34. 在SQL 中,用于将字符串转换为大写的函数是()A. UPPER()B. TO_UPPER()C. CAPITALIZE()D. BIGCASE()答案:A35. 用于将字符串转换为小写的函数是()A. LOWER()B. TO_LOWER()C. SMALLCASE()D. DECAPITALIZE()答案:A36. 以下哪个函数用于去除字符串两端的空格()A. TRIM()B. CLEAN()C. REMOVE_SPACES()D. STRIP()答案:A37. 在SQL 中,用于执行事务的语句是()A. BEGIN TRANSACTIONB. START TRANSACTIONC. OPEN TRANSACTIOND. INITIATE TRANSACTION答案:A38. 提交事务使用的语句是()A. COMMITB. SUBMITC. CONFIRMD. VALIDATE答案:A39. 回滚事务使用的语句是()A. ROLLBACKB. REVERTC. CANCELD. ABORT答案:A40. 以下哪个关键字用于在SQL 中创建存储过程()A. CREATE PROCEDUREB. MAKE PROCEDUREC. BUILD PROCEDURED. ESTABLISH PROCEDURE答案:A41. 调用存储过程使用的语句是()A. EXECUTEB. CALLC. INVOKED. RUN答案:B42. 在SQL 中,用于删除存储过程的语句是()A. DROP PROCEDUREB. DELETE PROCEDUREC. REMOVE PROCEDURED. CLEAR PROCEDURE答案:A43. 以下哪个关键字用于在SQL 中创建触发器()A. CREATE TRIGGERB. MAKE TRIGGERC. BUILD TRIGGERD. ESTABLISH TRIGGER44. 删除触发器使用的语句是()A. DROP TRIGGERB. DELETE TRIGGERC. REMOVE TRIGGERD. CLEAR TRIGGER答案:A45. 在SQL 中,用于授予权限的语句是()A. GRANTB. ALLOWC. PERMITD. AUTHORIZE答案:A46. 收回权限使用的语句是()A. REVOKEB. DENYC. REFUSED. FORBID答案:A47. 以下哪个关键字用于在SQL 中创建索引的唯一性约束()A. UNIQUEB. PRIMARY KEYC. FOREIGN KEYD. CHECK答案:A48. 用于定义主键约束的关键字是()A. PRIMARY KEYB. UNIQUE KEYC. FOREIGN KEYD. INDEX KEY答案:A49. 外键约束使用的关键字是()A. FOREIGN KEYB. OUTER KEYC. RELATED KEYD. REFERENCED KEY答案:A50. 以下哪个约束用于检查数据的有效性()A. CHECKB. VALIDATEC. INSPECTD. VERIFY答案:A51. 在SQL 中,以下哪个语句用于创建数据库()A. CREATE DATABASEB. MAKE DATABASEC. BUILD DATABASED. ESTABLISH DATABASE 答案:A52. 要删除数据库,应使用的语句是()A. DROP DATABASEB. DELETE DATABASEC. REMOVE DATABASED. CLEAR DATABASE 答案:A53. 以下哪个关键字用于在SQL 中切换数据库()A. USEB. SELECT DBC. CHANGE DBD. SWITCH DB答案:A54. 在SQL 中,以下哪种操作可以对多个表同时进行()A. 联合查询B. 子查询C. 交叉连接D. 内连接55. 子查询可以在以下哪个子句中使用()A. SELECTB. FROMC. WHERED. 以上都可以答案:D56. 以下哪个语句用于在SQL 中创建用户()A. CREATE USERB. MAKE USERC. BUILD USERD. ESTABLISH USER答案:A57. 删除用户使用的语句是()A. DROP USERB. DELETE USERC. REMOVE USERD. CLEAR USER答案:A58. 在SQL 中,用于修改表结构的语句是()A. ALTER TABLEB. MODIFY TABLEC. CHANGE TABLED. UPDATE TABLE答案:A59. 以下哪个操作可以添加列到表中()A. ADD COLUMNB. INSERT COLUMNC. APPEND COLUMND. PUT COLUMN答案:A60. 要删除表中的列,应使用()A. DROP COLUMNB. DELETE COLUMNC. REMOVE COLUMND. CLEAR COLUMN答案:A61. 在SQL 中,以下哪个关键字用于对结果集进行分页()A. PAGEB. PAGINGC. OFFSETD. LIMIT答案:D62. 以下哪个函数用于返回当前日期()A. CURDATE()B. NOW()C. CURRENT_DATE()D. TODAY()答案:C63. 用于返回当前时间的函数是()A. CURTIME()B. NOW()C. CURRENT_TIME()D. THIS_TIME()答案:C64. 在SQL 中,以下哪个关键字用于为表中的列设置默认值()A. DEFAULTB. INITIALC. BASED. START答案:A65. 以下哪个语句用于在SQL 中重命名表()A. RENAME TABLEB. MODIFY TABLE NAMEC. CHANGE TABLE NAMED. UPDATE TABLE答案:A66. 要获取表的结构信息,可以使用以下哪个语句()A. DESCRIBE TABLEB. SHOW TABLE STRUCTUREC. EXPLAIN TABLED. GET TABLE DETAILS答案:A67. 在SQL 中,以下哪个关键字用于在查询结果中去除重复行()A. DISTINCTB. UNIQUEC. SINGLED. ONLY答案:A68. 以下哪个函数用于对字符串进行拼接()A. CONCAT()B. JOIN()C. MERGE()D. COMBINE()答案:A69. 在SQL 中,用于创建临时表的关键字是()A. TEMPORARY TABLEB. TEMP TABLEC. TRANSIENT TABLED. SHORT_LIVED TABLE答案:A70. 以下哪个语句用于在SQL 中为列添加注释()A. COMMENT ON COLUMNB. NOTE ON COLUMNC. REMARK ON COLUMND. EXPLAIN COLUMN答案:A71. 在SQL 中,以下哪个关键字用于在子查询中引用外部查询的结果()A. CORRELATEDB. RELATEDC. CONNECTEDD. LINKED答案:A72. 以下哪个操作符用于在SQL 中进行范围查询()A. BETWEENB. INC. LIKED. EXISTS答案:A73. 用于模糊匹配的操作符是()A. LIKEB. SIMILARC. MATCHD. CLOSE_TO答案:A74. 在SQL 中,以下哪个关键字用于对查询结果进行排序时按照多个列进行()A. ORDER BY MULTIPLEB. SORT BY SEVERALC. ORDER BY MORE THAN ONED. ORDER BY MULTIPLE COLUMNS答案:D75. 以下哪个函数用于返回字符串的子串()A. SUBSTRING()B. PART()C. SEGMENT()D. SLICE()答案:A76. 在SQL 中,以下哪个关键字用于在存储过程中定义输入参数()A. INB. OUTC. INOUTD. PARAMETER答案:A77. 用于定义输出参数的关键字是()A. INB. OUTC. INOUTD. PARAMETER答案:B78. 以下哪个关键字用于在存储过程中定义既可以输入又可以输出的参数()A. INB. OUTC. INOUTD. PARAMETER答案:C79. 在SQL 中,以下哪个关键字用于在创建表时指定自增列()A. AUTO_INCREMENTB. SELF_INCREMENTC. AUTO_GROWD. SELF_GROW答案:A80. 以下哪个语句用于在SQL 中创建序列()A. CREATE SEQUENCEB. MAKE SEQUENCEC. BUILD SEQUENCED. ESTABLISH SEQUENCE 答案:A81. 要获取序列的下一个值,可以使用以下哪个函数()A. NEXTVAL()B. GET_NEXT()C. NEXT_VALUE()D. FOLLOWING_VALUE()答案:A82. 在SQL 中,以下哪个关键字用于锁定表()A. LOCKB. HOLDC. FREEZED. BLOCK答案:A83. 以下哪种锁类型用于防止其他事务读取或修改数据()A. 共享锁B. 排他锁C. 意向共享锁D. 意向排他锁答案:B84. 共享锁允许其他事务()A. 读取数据B. 修改数据C. 删除数据D. 以上都不行答案:A85. 在SQL 中,以下哪个关键字用于解锁表()A. UNLOCKB. RELEASEC. FREED. UNBIND答案:A86. 以下哪个函数用于计算两个日期之间的天数差()A. DATEDIFF()B. DATE_DIFFERENCE()C. DAY_DIFFERENCE()D. TIME_DIFFERENCE()答案:A87. 在SQL 中,以下哪个关键字用于在查询中使用别名()A. ASB. LIKEC. SAME ASD. EQUALS答案:A88. 以下哪个语句用于在SQL 中创建索引的唯一约束()A. UNIQUE INDEXB. PRIMARY INDEXC. FOREIGN INDEXD. CHECK INDEX答案:A89. 要在SQL 中创建全文索引,应使用()A. FULLTEXT INDEXB. COMPLETE TEXT INDEXC. ALL_TEXT INDEXD. WHOLE_TEXT INDEX 答案:A90. 在SQL 中,以下哪个关键字用于在存储过程中声明变量()A. DECLAREB. DEFINEC. STATED. ANNOUNCE答案:A91. 以下哪个语句用于在SQL 中为变量赋值()A. SETB. ASSIGNC. GIVED. PUT答案:A92. 在SQL 中,以下哪个关键字用于在存储过程中进行条件判断()A. IFB. WHENC. CASED. CHECK答案:A93. 以下哪种语句用于在SQL 中进行循环操作()A. FORB. WHILEC. LOOPD. 以上都是答案:D94. 在SQL 中,用于退出循环的语句是()A. BREAKB. EXITC. STOPD. END答案:A95. 以下哪个函数用于将数字转换为字符串()A. CAST()B. CONVERT()C. TO_STRING()D. NUM_TO_STR()答案:B96. 在SQL 中,用于获取当前会话的用户名称的函数是()A. CURRENT_USERB. SYSTEM_USERC. LOGGED_IN_USERD. SESSION_USER答案:A97. 以下哪个关键字用于在SQL 中创建存储函数()A. CREATE FUNCTIONB. MAKE FUNCTIONC. BUILD FUNCTIOND. ESTABLISH FUNCTION 答案:A98. 要删除存储函数,应使用的语句是()A. DROP FUNCTIONB. DELETE FUNCTIONC. REMOVE FUNCTIOND. CLEAR FUNCTION答案:A99. 在SQL 中,用于获取数据库版本信息的函数是()A. VERSION()B. DB_VERSION()C. DATABASE_VERSION()D. SYSTEM_VERSION()答案:A100. 以下哪个操作可以在SQL 中对表进行重命名()A. RENAME TABLEB. MODIFY TABLE NAMEC. CHANGE TABLE NAMED. UPDATE TABLE NAME答案:A。
sql基础面试题及答案
sql基础面试题及答案1. 什么是SQL?SQL(Structured Query Language)是一种用于管理和操作关系型数据库的标准化语言。
它允许用户从数据库中检索、插入、更新和删除数据,同时还可以定义和管理数据库结构。
2. SQL的分类有哪些?SQL可以分为以下几个方面:- 数据查询语言(Data Query Language,DQL):用于从数据库中检索数据的语言。
常见的DQL命令包括SELECT。
- 数据操纵语言(Data Manipulation Language,DML):用于对数据库中的数据进行操作的语言。
常见的DML命令包括INSERT、UPDATE和DELETE。
- 数据定义语言(Data Definition Language,DDL):用于创建和修改数据库结构的语言。
常见的DDL命令包括CREATE、ALTER和DROP。
- 数据控制语言(Data Control Language,DCL):用于授权和撤销用户对数据库的访问权限的语言。
常见的DCL命令包括GRANT和REVOKE。
3. SELECT语句的基本语法是什么?SELECT语句用于从数据库中检索数据,其基本语法如下:```sqlSELECT 列名1, 列名2, ... FROM 表名 WHERE 条件;```其中,列名指定所需的数据列,表名指定要检索数据的表,WHERE语句用于指定要返回的数据行的条件。
4. 如何在SELECT语句中使用通配符?通配符在SELECT语句中用于匹配不完整或不确定的数据,常见的通配符有两种:- 百分号(%):表示匹配任意数量的字符。
- 下划线(_):表示匹配单个字符。
例如,可以使用以下语句检索以字母“A”开头的所有姓氏:```sqlSELECT * FROM employees WHERE last_name LIKE 'A%';```5. 什么是SQL注入攻击,如何预防?SQL注入攻击是一种利用未正确过滤用户输入数据的漏洞,通过在用户提供的输入中插入恶意SQL代码来执行恶意操作的攻击。
SQL数据库面试题以及答案
Stude nt(S#,S name,Sage,Ssex) 学生表S#:学号Sn ame :学生姓名Sage :学生年龄Ssex :学生性别Course(C#,C name,T#) 课程表C#:课程编号Cn ame :课程名称T# :教师编号SC(S#,C#,score) 成绩表S#:学号C#:课程编号score :成绩Teacher(T#,T name) 教师表T# :教师编号:Tname:教师名字问题:1、查询“001课程比“002”程成绩高的所有学生的学号select a.S# from (select S#,score from SC where C#='001')a, (select s#,score from SC where c#='002')b Where a.score>b.score and a.s# = b.s#;2、查询平均成绩大于60分的同学的学号和平均成绩select S#, avg(score) from sc group by S# hav ing avg(score)>603、查询所有同学的学号、姓名、选课数、总成绩select stude nt.S#, stude nt.S name, cou nt(sc.C#), sum(score) from stude nt leStude nt(S#,S name,Sage,Ssex) 学生表ft outer join SC on student.S# = SC.S# group by Student.S#, Sname4、查询姓李'勺老师的个数:select cou nt(disti nct(T name))from teacherwhere tn ame like ' 李%';5、查询没有学过叶平”老师可的同学的学号、姓名:select stude nt.S#, stude nt.S namefrom Stude ntwhere S# not in (select dist in ct(SC.S#) from SC,Course,Teacherwhere sc.c#=course.c# AND teacher.T#=course.T# AND Teahcer.T name =' 叶平'); 6、查询学过叶平”老师所教的所有课的同学的学号、姓名:select S#,S name from Stude ntwhere S# in (select S# from SC ,Course ,Teacherwhere SC.C#=Course.C# and Teacher.T#=Course.T#and Teacher.T name=' 叶平'group by S#hav ing cou nt(SC.C#)=(select cou nt(C#) from Course,Teacherwhere Teacher.T#=Course.T# and Tn ame=' 叶平'));7、查询学过“01併且也学过编号“002课程的同学的学号、姓名:select Stude nt.S#,Stude nt.S namefrom Stude nt,SC where Stude nt.S#=SC.S#and SC.C#='001'a ndexists( Select * from SC as SC_2 where SC_2.S#=SC.S# and SC_2.C#='002');8查询课程编号“ 002的成绩比课程编号“001课程低的所有同学的学号、姓名:Select S#,S namefrom (select Stude nt.S#,Stude nt.S name,score , (select score from SC SC_2 where SC_2.S#=Stude nt.S# and SC_2.C#='OO2') score2from Stude nt,SCwhere Stude nt.S#=SC.S# and C#='001') S_2where score2 < score;9、查询所有课程成绩小于60的同学的学号、姓名:select S#, sn amefrom stude ntwhere s# n ot in(select stude nt.s# from stude nt, sc where s.s# = sc.s# and score>60);10、查询没有学全所有课的同学的学号、姓名:select stude nt.s#, stude nt.s namefrom stude nt, scwhere stude nt.s#=sc.s#group by stude nt.s#, stude nt.s namehav ing cou nt(c#)v(select cou nt(c#) from course);11、查询至少有一门课与学号为“1001同学所学相同的同学的学号和姓名:select s#, Sn amefrom Student, SCwhere stude nt.s# = sc.s#and c# in (select c# from SC where s#='1001');12、查询至少学过学号为“001同学所有一门课的其他同学学号和姓名;select disti net sc.s# , sn amefrom stude nt, sc where stude nt.s#=sc.s#and c# in (select C# from sc where s#='001');13、把“ SC表中叶平”老师教的课的成绩都更改为此课程的平均成绩:Update Sc Set Score=(Select Avg(s2_Score) From sc s2 Where s2.c#=sc.c#)Where c# IN(Select c# From sc cs INNER JOIN Teacher tc ON cs.t#=tc.t# WHERE tn ame =' 叶平)14、查询和“1002号的同学学习的课程完全相同的其他同学学号和姓名:select s# from sc where c# in(select c# from sc where s#='1002')group by s# hav ing cou nt(*)=(select count(*) from sc where s#='1002');15、删除学习叶平”老师课的SC表记录:delect scfrom course, Teacherwhere course.c#=sc.c#and course.t#=teacher.t#and tn ame=' 叶平:16、向SC表中插入一些记录,这些记录要求符合以下条件:没有上过编号“003课程的同学学号、002号课的平均成绩:In sert SC select S#,'002',(Select avg(score) from SC where C#='002') from Stude nt where S# n ot in (Select S# from SC whereC#='002');17、按平均成绩从高到低显示所有学生的数据库”企业管理”英语”三门的课程成绩,按如下形式显示:学生ID,数据库,企业管理,英语,有效课程数,有效平均分:select s# as 学生ID,(select score from sc where sc.s#=t.s# and c#='004') as 数据库,(select score from sc where sc.s#=t.s# and c#='001') as 企业管理,(select score from sc where sc.s#=t.s# and c#='006') as 英语,count(*) as 有效课程数,avg(t.score) as 平局成绩from sc as tgroup by s#order by avg(t.score)18、查询各科成绩最高和最低的分:以如下的形式显示:课程ID,最高分,最低分select L.c# as 课程ID, L.score as 最高分,R.score as 最低分from sc L, sc Rwhere L.c# = R.c#and L.score = (select max(IL.score)from sc IL, stude nt as IMwhere L.c#=IL.c# and IM.s#=IL.s#group by IL.c#)and R.score = (select min (IR.score)from sc as IRwhere R.c#=IR.c#group by IR.c#);19、按各科平均成绩从低到高和及格率的百分数从高到低顺序: SELECT t.C# AS 课程号,max(ame)AS 课程名,isnull(AVG(score),0) AS 平均成绩,100 * SUM(CASE WHEN isn ull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) AS 及格百分数FROM SC T,Coursewhere t.C#=course.C#GROUP BY t.C#ORDER BY 100 * SUM(CASE WHEN isn ull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) DESC20、查询如下课程平均成绩和及格率的百分数(用”1亍”显示):企业管理(001),马克思(002),0O&UML (003),数据库(004): 21、查询不同老师所教不同课程平均分从高到低显示:SELECT max(Z.T#) AS 教师ID,MAX(Z.Tname) AS 教师姓名,C.C# AS 课程ID,AVG(Score) AS 平均成绩FROM SC AS T,Course AS C ,Teacher AS Zwhere T.C#=C.C# and C.T#=Z.T#GROUP BY C.C#ORDER BY AVG(Score) DESC22、查询如下课程成绩第3名到第6名的学生成绩单:企业管理(001),马克思(002),UML(003),数据库(004):23、统计下列各科成绩,各分数段人数:课程ID,课程名称,[100-85],[85-70],[70-60],[ 小于60]:SELECT SC.C# as 课程ID, Cname as 课程名称,SUM(CASE WHEN score BETWEEN 85 AND 100 THEN 1 ELSE 0 END) AS [100 - 85],SUM(CASE WHEN score BETWEEN 70 AND 85 THEN 1 ELSE 0 END) AS [85 - 70],SUM(CASE WHEN score BETWEEN 60 AND 70 THEN 1 ELSE 0 END) AS [70 - 60],SUM(CASE WHEN score < 60 THEN 1 ELSE 0 END) AS [60 -]FROM SC,Coursewhere SC.C#=Course.C#GROUP BY SC.C#,C name;24、查询学生平均成绩及其名次:SELECT 1+(SELECT COUNT( distinct 平均成绩)FROM (SELECT S#,AVG(score) AS 平均成绩FROM SCGROUP BY S# ) AS T1 WHERE 平均成绩〉T2. 平均成绩)as 名次,S# as学生学号,平均成绩FROM (SELECT S#,AVG(score) 平均成绩FROM SCGROUP BY S# ) AS T2ORDER BY平均成绩desc;25、查询各科成绩前三名的记录(不考虑成绩并列情况)SELECT t1.S# as 学生ID,t1.C# as 课程ID,Score as 分数FROM SC t1WHERE score IN(SELECT TOP 3 scoreFROM SCWHERE t1.C#= C#ORDER BY score DESC)26、查询每门课程被选修的学生数:select c#, cou nt(s#)from scgroup by c#;27、查询出只选修一门课程的全部学生的学号和姓名: select sc.s#, stude nt.s name, cou nt(c#) as 选课数from sc,stude ntwhere sc.s# =stude nt.s#group by sc.s#,Stude nt.s namehav ing cou nt(c#)=1;28、查询男生、女生人数:select cou nt(Ssex) as 男生人数from stude ntgroup by Ssexhaving Ssex=' 男';select cou nt(Ssex) as 女生人数from stude ntgroup by Ssexhav ing Ssex=' 女:29、查询姓张”的学生名单:select sn amefrom stude ntwhere sn ame like 张%';30、查询同名同姓的学生名单,并统计同名人数:select sanm e,cou nt(*)from stude ntgroup by sn amehava ng cou nt(*)>1;31、1981年出生的学生名单(注:student表中sage列的类型是datetime):select sn ame, con vert(char(11),DATEPART(year,sage)) as agefrom stude ntwhere con vert(char(11),DATEPART(year,Sage))='1981';32、查询平均成绩大于85的所有学生的学号、姓名和平均成绩:select Sn ame,SC.S# ,avg(score)from Stude nt,SCwhere Stude nt.S#=SC.S#group by SC.S#,S namehav ing avg(score)>85;33、查询每门课程的平均成绩,结果按平均成绩升序排序,平均成绩相同时,按课程号降序排列:select C#, avg(score)from scgroup by c#order by avg(score), c# desc;from sc,stude nt34、查询课程名称为数据库”且分数低于60的学生名字和分数:select sn ame, is null(score,0)from stude nt, sc ,course数据库'and s where sc.s#=stude nt.s# and sc.c#=course.c# and course.c name=' core<60;35、查询所有学生的选课情况:select sc.s#,sc.c#,s name,c namefrom sc,stude nt coursewhere sc.s#=stude nt.s# and sc.c#=course.c#;36、查询任何一门课程成绩在70分以上的姓名、课程名称和分数:select disti net stude nt.s#,stude nt.s name,sc.c#,sc.scorefrom stude nt,scwhere sc.score>=70 and sc.s#=stude nt.s#;37、查询不及格的课程,并按课程号从大到小的排列:select c#from scwhere score<60order by c#;38、查询课程编号为“003且课程成绩在80分以上的学生的学号和姓名:select sc.s#,stude nt.s namewhere sc.s#=stude nt.s# and score>80 and c#='003';from sc,stude nt39、求选了课程的学生人数:select cou nt(*) from sc;40、 查询选修 叶平”老师所授课程的学生中,成绩最高的学生姓 名及其成绩:select stude nt.s name,scorefrom stude nt,sc,course c, teacherwhere stude nt.s#=sc.S# and sc.c#=c.c#and c.T#=teacher.T#and teacher.t name=' 叶平'and sc.score=(select max(score) from sc where c#=c.c#);41、 查询各个课程及相应的选修人数:select cou nt(*) from sc group by c#;42、 查询不同课程成绩相同的学生和学号、课程号、学生成绩: select disti net a.s#,b.scorefrom sc a ,sc bwhere a.score=b.scoreand a.c#<>b.c#;43、 查询每门课程成绩最好的前两名:select tl.s# as学生 ID,t1.c# 课程 ID, Score as 分数from sc t1where score in (select top 2 score from scwhere t1.c#=c#order by score desc) order by tl.c#;44、 统计每门课程的学生选修人数(超过10人的课程才统计)。
sql面试基础题
sql面试基础题摘要:1.SQL面试简介2.数据表操作3.数据查询4.数据更新5.数据删除6.数据排序与分组7.索引与约束8.函数与表达式9.存储过程与触发器10.高级SQL话题11.实战案例正文:一、SQL面试简介SQL(Structured Query Language,结构化查询语言)是一种用于管理关系型数据库的编程语言。
在面试中,SQL基础题是数据库相关职位的必备考察内容。
掌握SQL面试基础题有助于提高求职者的竞争力。
本文将为大家梳理SQL面试的基础题,帮助大家更好地备考。
二、数据表操作1.创建表:使用CREATE TABLE语句创建一个新的数据表。
2.删除表:使用DROP TABLE语句删除一个数据表。
3.修改表结构:使用ALTER TABLE语句修改数据表的结构,如添加、修改或删除列。
4.添加数据:使用INSERT INTO语句向数据表中插入数据。
三、数据查询1.选择所有列:使用SELECT *语句选择数据表中的所有列。
2.选择特定列:使用SELECT column_name语句选择特定列。
3.选择特定行:使用WHERE子句筛选符合条件的行。
4.聚合函数:使用如SUM、AVG、MAX、MIN等聚合函数对数据进行统计。
5.排序:使用ORDER BY子句对查询结果进行排序。
6.分组:使用GROUP BY子句对数据进行分组。
四、数据更新1.更新单行:使用UPDATE语句更新特定行的数据。
2.更新多行:使用UPDATE语句更新多行数据。
3.利用SET子句设置新值。
五、数据删除1.删除单行:使用DELETE FROM语句删除特定行的数据。
2.删除多行:使用DELETE FROM语句删除多行数据。
3.删除整个表:使用DROP TABLE语句删除整个数据表。
六、数据排序与分组1.排序:使用ORDER BY子句对查询结果进行排序。
2.分组:使用GROUP BY子句对数据进行分组。
七、索引与约束1.创建索引:使用CREATE INDEX语句创建索引。
sql 数据库 面试题
sql 数据库面试题SQL数据库面试题1. 数据库基础知识数据库是用来存储、管理和操作大量数据的工具。
在进行SQL数据库面试时,你可能会被问到一些基础的数据库知识问题。
1.1 数据库的定义和作用数据库是一个组织数据的集合,可以存储和管理大量结构化数据。
它的作用是提供数据的持久化存储和高效的数据访问。
1.2 关系型数据库和非关系型数据库的区别关系型数据库使用表格来组织和管理数据,通过定义表格之间的关系来建立数据模型。
非关系型数据库则以其他形式来存储和组织数据,例如键值对、文档、图形等。
1.3 主键和外键的概念和作用主键是表格中的一列或多列,用来唯一标识每一行数据。
外键是表格中的一列,用来建立表格之间的联系。
1.4 视图的作用和优势视图是虚拟的表格,它是从一个或多个基本表中导出的。
它可以简化数据的查询和操作,并且提供了更高的数据安全性。
2. SQL查询语句在数据库的使用过程中,最常见的操作之一就是查询数据。
以下是一些关于SQL查询语句的面试题。
2.1 SELECT语句及其用法SELECT是用于从数据库中查询数据的关键字。
它可以用来选择特定的列、过滤数据、排序结果等。
2.2 WHERE子句的作用和用法WHERE子句用于过滤满足特定条件的数据。
它可以在SELECT语句中使用,以便筛选满足特定要求的数据。
2.3 JOIN语句的作用和用法JOIN语句可以将两个或多个表格中的数据连接起来。
它通过共享表格之间的字段,来获取相关联的数据。
2.4 GROUP BY和HAVING的概念和区别GROUP BY用于将数据分组,并对每个组应用聚合函数。
HAVING 子句用于过滤分组结果。
3. SQL数据操作语句数据库不仅仅是用来查询数据的,还可以对数据进行新增、修改和删除操作。
以下是一些关于SQL数据操作语句的面试题。
3.1 INSERT语句及其用法INSERT语句用于向数据库中插入新的数据行。
它可以插入单行或多行数据,并指定插入的列和值。
SQL数据库面试题目及其答案
1.触发器的作用?答:触发器是一中特殊的存储过程,主要是通过事件来触发而被执行的。
它可以强化约束,来维护数据的完整性和一致性,可以跟踪数据库内的操作从而不允许未经许可的更新和变化。
可以联级运算。
如,某表上的触发器上包含对另一个表的数据操作,而该操作又会导致该表触发器被触发。
2.什么是存储过程?用什么来调用?答:存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。
如果某次操作需要执行多次SQL使用存储过程比单纯SQL语句执行要快。
可以用一个命令对象来调用存储过程。
3.索引的作用?和它的优点缺点是什么?答:索引就一种特殊的查询表,数据库的搜索引擎可以利用它加速对数据的检索。
它很类似与现实生活中书的目录,不需要查询整本书内容就可以找到想要的数据。
索引可以是唯一的,创建索引允许指定单个列或者是多个列。
缺点是它减慢了数据录入的速度,同时也增加了数据库的尺寸大小。
3。
什么是内存泄漏?答:一般我们所说的内存泄漏指的是堆内存的泄漏。
堆内存是程序从堆中为其分配的,大小任意的,使用完后要显示释放内存。
当应用程序用关键字new 等创建对象时,就从堆中为它分配一块内存,使用完后程序调用free 或者delete 释放该内存,否则就说该内存就不能被使用,我们就说该内存被泄漏了。
4.维护数据库的完整性和一致性,你喜欢用触发器还是自写业务逻辑?为什么?答:我是这样做的,尽可能使用约束,如check, 主键,外键,非空字段等来约束,这样做效率最高,也最方便。
其次是使用触发器,这种方法可以保证,无论什么业务系统访问数据库都可以保证数据的完整新和一致性。
最后考虑的是自写业务逻辑,但这样做麻烦,编程复杂,效率低下。
5.什么是事务?什么是锁?答:事务就是被绑定在一起作为一个逻辑工作单元的SQL语句分组,如果任何一个语句操作失败那么整个操作就被失败,以后操作就会回滚到操作前状态,或者是上有个节点。
sql面试题大全
sql面试题大全SQL(Structured Query Language)是一种用于管理关系型数据库的标准化语言。
在数据库相关的职位面试中,SQL面试题是常见的一种考察方式。
本文将为您提供一份SQL面试题大全,帮助您更好地准备面试。
1. SELECT语句SELECT语句用于从数据库中检索数据。
以下是一些常见的SELECT语句相关的面试题:- 请解释SELECT语句中的DISTINCT关键字的作用。
- 如何使用WHERE子句来过滤结果?- 什么是表达式(Expression)和谓词(Predicate)?- 请解释SQL中的NULL值和未知值(UNKNOWN)的区别。
2. 数据库表操作数据库表操作是SQL中的核心操作之一。
以下是一些常见的数据库表操作相关的面试题:- 如何创建一个新的数据库表?- 如何添加列、删除列或修改列的定义?- 如何添加主键(Primary Key)和外键(Foreign Key)约束?- 请解释SQL中的合并(JOIN)操作和不同类型的合并操作的区别。
3. 数据查询与过滤数据查询与过滤是SQL中的重要方面,以下是一些相关的面试题:- 如何使用GROUP BY子句对数据进行分组?- 如何使用HAVING子句过滤分组数据?- 请解释SQL中的聚合函数(Aggregate Functions)的作用和常见的聚合函数有哪些?- 如何使用ORDER BY子句对结果进行排序?4. 数据更新与删除数据更新与删除是SQL中的常见操作之一。
以下是一些相关的面试题:- 如何使用INSERT语句向数据库表中插入新的数据?- 如何使用UPDATE语句更新已有的数据?- 如何使用DELETE语句从数据库中删除数据?- 请解释SQL中的事务(Transaction)和事务的四个特性(ACID)。
5. 数据库索引与优化数据库索引和优化是提高数据库性能的重要手段。
以下是一些相关的面试题:- 请解释数据库索引的作用和常见的索引类型有哪些?- 如何使用索引来优化SQL查询?- 什么是数据库的查询执行计划(Execution Plan)?- 请解释SQL中的表锁(Table Lock)和行锁(Row Lock)。
sql 面试题及答案
sql 面试题及答案在面试过程中,SQL (Structured Query Language) 是常见的一个考察重点。
以下是一些常见的 SQL 面试题及其答案,帮助你在面试中更好地准备。
1. 什么是 SQL?SQL 是一种用于管理关系数据库系统的标准化语言。
它用于访问和操作数据库中的数据,并提供了创建、修改和删除数据库中的表、视图和存储过程等功能。
2. SQL 的主要分类有哪些?SQL 主要分为以下几类:- 数据定义语言 (DDL):用于创建和管理数据库中的对象,例如CREATE、ALTER、DROP 等。
- 数据操作语言 (DML):用于从数据库中获取、插入、修改和删除数据,例如 SELECT、INSERT、UPDATE 和 DELETE 等。
- 数据控制语言 (DCL):用于定义数据库对象的访问权限,例如GRANT 和 REVOKE 等。
3. 什么是表和视图?- 表:表是存储数据的基本结构,由列和行组成。
每个表代表一个数据实体,如用户、订单等。
- 视图:视图是从一个或多个表中导出的虚拟表。
它基于特定的查询定义,并可像表一样使用。
视图可以简化复杂的查询操作,并提供对数据的安全性和抽象性。
4. 什么是主键、外键和唯一键?- 主键 (Primary Key):主键是用来唯一标识表中每条记录的列或列组合。
它必须保证唯一性和非空性。
- 外键 (Foreign Key):外键是用来建立表之间的关联关系的列。
它建立在另一个表的主键上,并用于维护数据完整性。
- 唯一键 (Unique Key):唯一键是用来确保列或列组合的唯一性,但允许为空值。
5. 什么是索引?索引是一种数据结构,用于加快数据访问的速度。
它可以在一个或多个列上创建,以提高查找、排序和分组等操作的性能。
6. 什么是连接 (JOIN)?连接是指根据一定的条件将两个或多个表中的数据进行合并。
常见的连接类型有内连接 (INNER JOIN)、左连接 (LEFT JOIN)、右连接(RIGHT JOIN) 和全连接 (FULL JOIN)。
sql面试基础题
sql面试基础题摘要:1.SQL 概述2.SQL 的基本语法3.SQL 的常用函数4.SQL 的查询语句5.SQL 的插入、更新和删除语句6.SQL 的面试常见问题及答案正文:一、SQL 概述SQL(Structured Query Language,结构化查询语言)是一种用于管理关系型数据库的编程语言。
它可以用于查询、插入、更新和删除数据库中的数据,还可以用于创建和管理数据库表、视图和索引等。
SQL 具有丰富的功能和高度的灵活性,是现代数据库系统的核心技术之一。
二、SQL 的基本语法SQL 的基本语法包括以下几个部分:1.数据定义:用于创建、修改和删除数据库中的表、视图和索引等对象。
例如,CREATE TABLE、ALTER TABLE、DROP TABLE 等命令。
2.数据操作:用于查询、插入、更新和删除数据库中的数据。
例如,SELECT、INSERT、UPDATE、DELETE 等命令。
3.数据控制:用于控制数据库的访问权限和事务处理。
例如,GRANT、REVOKE、COMMIT、ROLLBACK 等命令。
三、SQL 的常用函数SQL 提供了许多常用函数,用于处理和转换数据。
以下是一些常用的函数:1.数值函数:例如,SUM、AVG、MAX、MIN 等,用于对数值数据进行统计和计算。
2.字符串函数:例如,LENGTH、SUBSTRING、INSTR 等,用于处理字符串数据。
3.日期和时间函数:例如,CURDATE、CURTIME、DATE 等,用于处理日期和时间数据。
4.聚合函数:例如,COUNT、GROUP BY 等,用于对数据进行分组和汇总。
四、SQL 的查询语句SQL 的查询语句(SELECT)用于从数据库中检索数据。
其基本语法如下:```SELECT column_name(s)FROM table_nameWHERE condition;```其中,column_name(s) 表示要查询的列名,table_name 表示要查询的表名,condition 表示查询条件。
sql数据库经典面试题
sql数据库经典面试题1. 数据库概念与常用操作数据库的定义:数据库是指按照数据结构来组织、存储和管理数据的仓库,它存储了大量有组织的数据,并且提供了对这些数据进行有效操作和管理的方法。
常用的数据库操作命令包括:- SELECT:从数据库中提取数据。
- UPDATE:修改数据库中的数据。
- INSERT INTO:向数据库插入新的数据。
- DELETE:从数据库中删除数据。
2. SQL语言基础SQL(Structured Query Language)是一种用于访问和处理关系型数据库的标准化语言。
以下是一些常见的SQL语句:- 创建表格的语法:```CREATE TABLE 表名 (列名1 数据类型,列名2 数据类型,...);```- 查询表格的语法:```SELECT 列名1, 列名2, ...FROM 表名WHERE 条件;```- 更新表格的语法:```UPDATE 表名SET 列名 = 值WHERE 条件;```- 插入数据的语法:```INSERT INTO 表名 (列名1, 列名2, ...)VALUES (值1, 值2, ...);```- 删除数据的语法:```DELETE FROM 表名WHERE 条件;```3. 数据库设计与规范化数据库设计是为了满足组织的数据存储与管理需求,提高数据的安全性和有效性。
规范化是数据库设计的基本原则,用于减少数据冗余、提高数据一致性和改善数据库性能。
常见的数据库规范化范式包括:- 第一范式(1NF):确保每个字段都是原子性的,即不可再分。
- 第二范式(2NF):在1NF的基础上,非主键字段必须完全依赖于候选键。
- 第三范式(3NF):在2NF的基础上,非主键字段不能传递依赖于候选键。
4. 数据库索引与优化索引是一种提高数据库查询速度的数据结构,它可以加快数据的检索过程。
常见的索引类型包括主键索引、唯一索引和聚集索引等。
通过合理的索引设计和优化,可以提高数据库的查询性能。
sql面试题目
sql面试题目一、介绍SQL(Structured Query Language)是一种用于管理和操作关系数据库系统的标准化语言。
在数据库相关的面试中,SQL题目是常见的考察内容之一。
以下是一些常见的SQL面试题目和对应的解答,希望对你有所帮助。
二、选择题1. SQL语言中"SELECT"关键字的作用是什么?A. 查询数据B. 插入数据C. 更新数据D. 删除数据答案:A. 查询数据2. 下列哪个关键字用于过滤数据库查询结果?A. WHEREB. SELECTC. INSERTD. UPDATE答案:A. WHERE3. 下面的SQL语句中,用于拉取指定行数数据的关键字是?A. LIMITB. ORDER BYC. GROUP BYD. HAVING答案:A. LIMIT4. 下列哪个SQL聚合函数用于统计行数?A. COUNTB. AVGC. MAXD. SUM答案:A. COUNT5. 下面的SQL语句中,用于删除表中所有数据的关键字是?A. DELETEB. TRUNCATEC. UPDATED. DROP答案:B. TRUNCATE三、简答题1. SQL中的数据类型有哪些?请列举一些常见的数据类型及其用途。
答:SQL中的数据类型包括整型、浮点型、字符型、日期型等。
其中,常见的数据类型有:- 整型:INT、BIT、TINYINT、BIGINT等,用于存储整数值。
- 浮点型:FLOAT、DOUBLE等,用于存储浮点数值。
- 字符型:CHAR、VARCHAR、TEXT等,用于存储文本信息。
- 日期型:DATE、TIME、DATETIME等,用于存储日期和时间信息。
2. SQL中的JOIN操作是用来做什么的?请简要解释。
答:JOIN操作用于在多个表中根据指定的条件将数据进行关联。
通过JOIN操作,可以将具有关联关系的数据进行合并,从而实现表之间的数据连接查询。
常见的JOIN操作包括INNER JOIN(内连接)、LEFT JOIN(左连接)、RIGHT JOIN(右连接)和FULL JOIN(全连接)等。
数据库sql面试题及答案
数据库sql面试题及答案数据库sql面试题及答案【篇一:sql数据库经典面试题(修改笔试题)(有答案)】部门,平均工资,要求按部门的字符串顺序排序,不能含有human resource部门,employee结构如下:employee_id, employee_name,depart_id,depart_name,wage 答:select depart_name, avg(wage)from employee where depart_name human resourcegroup by depart_name order by depart_name-------------------------------------------------------------------------- 29. 给定如下sql数据库:test(numint(4)) 请用一条sql语句返回num的最小值,但不许使用统计功能,如min,max等答:select top 1 num from test order by num-------------------------------------------------------------------------- 33.一个数据库中有两个表: 一张表为customer,含字段id,name;一张表为order,含字段id,customerid(连向customer中id的外键),revenue;写出求每个customer的revenue总和的sql语句。
建表create table customer(id int primary key,name char(10)) gocreate table [order](id int primary key,customerid int foreign key references customer(id) , revenue float) go--查询select customer.id, sum( isnull([order].revenue,0) ) from customer full join [order]on( [order].customerid=customer.id ) group by customer.id select customer.id,sum(order.revener) from order,customer where customer.id=customerid group by customer.idselect customer.id, sum(order.revener ) from customer full join orderon( order.customerid=customer.id ) group by customer.id 5数据库(10)a tabel called “performance”contain :name and score,please 用 sql语言表述如何选出score最high的一个(仅有一个)仅选出分数,select max(score) from performance 仅选出名字,即选出名字,又选出分数: select top 1score ,name from per order by scoreselect name1,score from per where score in/=(select max(score) from per) .....4 有关系 s(sno,sname) c(cno,cname) sc(sno,cno,grade) 1 问上课程 db的学生noselect count(*) from c,sc where came=db and co=sco select count(*) from sc where cno=(select cno from c where came=db)2 成绩最高的学生号select sno from sc where grade=(select max(grade) from sc ) 3 每科大于90分的人数select came,count(*) from c,sc where co=sco and sc.grade90 group by cameselect came,count(*) from c join sc on co=sco and sc.grade90 group by came 数据库笔试题 *建表: dept:deptno(primary key),dname,loc emp:empno(primary key),ename,job,mgr,sal,deptno */1 列出emp表中各部门的部门号,最高工资,最低工资select max(sal) as 最高工资,min(sal) as 最低工资,deptno from emp group by deptno;2 列出emp表中各部门job为clerk的员工的最低工资,最高工资 select max(sal) as 最高工资,min(sal) as 最低工资,deptno as 部门号 from emp where job = clerk group by deptno;3 对于emp中最低工资小于1000的部门,列出job为clerk 的员工的部门号,最低工资,最高工资select max(sal) as 最高工资,min(sal) as 最低工资,deptno as 部门号 from emp as bwhere job=clerk and 1000(select min(sal) from emp asa where a.deptno=b.deptno) group by b.deptno4 根据部门号由高而低,工资有低而高列出每个员工的姓名,部门号,工资select deptno as 部门号,ename as 姓名,sal as 工资from emp order by deptno desc,sal asc 5 写出对上题的另一解决方法(请补充)6 列出张三所在部门中每个员工的姓名与部门号select ename,deptno from emp where deptno = (select deptno from emp where ename = 张三)7 列出每个员工的姓名,工作,部门号,部门名select ename,job,emp.deptno,dept.dname from emp,dept where emp.deptno=dept.deptno8 列出emp中工作为clerk的员工的姓名,工作,部门号,部门名 select ename,job,dept.deptno,dname from emp,dept where 9 对于emp中有管理者的员工,列出姓名,管理者姓名(管理者外键为mgr)select a.ename as 姓名,b.ename as 管理者 from emp as a,emp as b where a.mgr is not null and a.mgr=b.empno10 对于dept表中,列出所有部门名,部门号,同时列出各部门工作为clerk的员工名与工作select dname as 部门名,dept.deptno as 部门号,ename as 员工名,job as 工作 from dept,empwhere dept.deptno *= emp.deptno and job = clerk11 对于工资高于本部门平均水平的员工,列出部门号,姓名,工资,按部门号排序select a.deptno as 部门号,a.ename as 姓名,a.sal as 工资 from emp as a where a.sal(select avg(sal) from emp asb where a.deptno=b.deptno) order by a.deptno12 对于emp,列出各个部门中平均工资高于本部门平均水平的员工数和部门号,按部门号排序select count(a.sal) as 员工数,a.deptno as 部门号 from emp as awhere a.sal(select avg(sal) from emp as b wherea.deptno=b.deptno) group by a.deptno order bya.deptno13 对于emp中工资高于本部门平均水平,人数多与1人的,列出部门号,人数,按部门号排序select count(a.empno) as 员工数,a.deptno as 部门号,avg(sal) as 平均工资 from emp as awhere (select count(c.empno) from emp as c wherec.deptno=a.deptno and c.sal(select avg(sal) from emp as b where c.deptno=b.deptno))1 group by a.deptno order by a.deptno14 对于emp中低于自己工资至少5人的员工,列出其部门号,姓名,工资,以及工资少于自己的人数select a.deptno,a.ename,a.sal,(select count(b.ename) from emp as b where b.sala.sal) as 人数 from emp as a where (select count(b.ename) from emp as b whereb.sala.sal)5 数据库笔试题及答案第一套一.选择题1. 下面叙述正确的是ccbad ______。
sql 面试题及答案
sql 面试题及答案在以下文章中,我将为您提供一些常见的SQL面试题以及它们的答案。
这些问题涵盖了SQL的基本概念、语句和技巧。
希望这些问题和答案能够帮助您在SQL面试中取得好成绩。
问题1:什么是SQL?答案:SQL是Structured Query Language(结构化查询语言)的缩写,是一种用于数据库管理系统的标准查询语言。
它用于存储、操纵和检索关系型数据库中的数据。
SQL语言具有简单、高效和功能强大的特点,广泛应用于各种数据库平台。
问题2:什么是数据库?答案:数据库是一个有组织的数据集合,用于存储和管理数据。
它可以是一个文件、一组文件或是一个完整的数据库管理系统。
数据库将数据以表格的形式进行组织,并使用关系模型来建立不同表之间的关系。
问题3:什么是关系型数据库?答案:关系型数据库是基于关系模型的数据库。
它使用表格(也称为关系)来存储和管理数据。
关系型数据库的数据以行和列的形式存储,其中每行代表一个记录,每列代表一种数据类型。
关系型数据库的一个重要特点是表格之间可以建立关系,并通过使用主键和外键来连接数据。
问题4:什么是主键?答案:主键是表中用来唯一标识每个记录的一列或一组列。
它的值必须在表中是唯一且非空的。
主键可以用于在表之间建立关系,也可以用于快速访问表中的数据。
问题5:什么是外键?答案:外键是一个表中的字段,它用于建立该表与其他表之间的关系。
外键是其他表的主键,在被引用表中的外键列中存储了其所引用表中的主键值。
通过外键,可以在多个表之间建立引用完整性约束,并实现表之间的数据关联和一致性。
问题6:什么是索引?答案:索引是一个特殊的数据结构,用于加快对表中数据的检索速度。
它通过创建一个排序的数据结构来提高访问表中数据的效率。
索引可以根据一个或多个列来创建,并可以根据这些列进行排序和过滤。
问题7:请解释SQL中的SELECT语句。
答案:SELECT语句用于从表中检索数据。
它可以从一个或多个表中选择所需的列,并根据条件过滤数据。
sql面试题目汇总(3篇)
第1篇第一部分:基础SQL查询1. 如何使用SELECT语句从数据库中查询数据?- 答案:SELECT语句用于从数据库表中查询数据。
基本语法如下:```sqlSELECT column1, column2, ... FROM table_name;```2. 如何使用WHERE子句对查询结果进行过滤?- 答案:WHERE子句用于过滤查询结果,只返回满足特定条件的行。
语法如下: ```sqlSELECT column1, column2, ... FROM table_name WHERE condition;```3. 如何使用ORDER BY子句对查询结果进行排序?- 答案:ORDER BY子句用于对查询结果进行排序。
语法如下:```sqlSELECT column1, column2, ... FROM table_name ORDER BY column1ASC|DESC;```4. 如何使用LIMIT子句限制查询结果的数量?- 答案:LIMIT子句用于限制查询结果的数量。
语法如下:```sqlSELECT column1, column2, ... FROM table_name LIMIT row_count;```5. 如何使用DISTINCT关键字去除查询结果中的重复值?- 答案:DISTINCT关键字用于去除查询结果中的重复值。
语法如下:```sqlSELECT DISTINCT column1, column2, ... FROM table_name;```第二部分:高级SQL查询6. 如何使用JOIN子句进行多表查询?- 答案:JOIN子句用于连接两个或多个表,并返回满足连接条件的行。
常见的JOIN类型包括:- INNER JOIN:返回两个表中匹配的行。
- LEFT JOIN(或LEFT OUTER JOIN):返回左表的所有行,即使右表中没有匹配的行。
- RIGHT JOIN(或RIGHT OUTER JOIN):返回右表的所有行,即使左表中没有匹配的行。
sql面试题及答案
sql面试题及答案sql面试题及答案一1. 简述索引存取的方法的作用和建立索引的原则作用:加快查询速度。
原则:(1) 如果某属性或属性组经常出现在查询条件中,考虑为该属性或属性组建立索引;(2) 如果某个属性常作为最大值和最小值等聚集函数的参数,考虑为该属性建立索引;(3) 如果某属性经常出现在连接操作的连接条件中,考虑为该属性或属性组建立索引;2. 简述数据库的设计过程数据库设计分为五个阶段:需求分析:主要是准确收集用户信息需求和处理需求,并对收集的结果进行整理和分析,形成需求说明。
概念结构设计:对用户需求进行综合、归纳、抽象,形成一个与与具体的DBMS无关概念模型(一般为ER模型)。
逻辑结构设计:将概念结构设计的概念模型转化为某个特定的DBMS所支持的数据模型,建立数据库逻辑模式,并对其进行优化,同时为各种用户和应用设计外模式。
物理结构设计:为设计好的逻辑模型选择物理结构,包括存储结构和存取方法等,建立数据库物理模式。
实施和维护:实施就是使用DLL语言建立数据库模式,将实际数据载入数据库,建立真正的数据库。
维护阶段是对运行中的数据库进行评价、调整和修改。
3. 什么是内存泄漏?答案:一般我们所说的内存泄漏指的是堆内存的泄漏。
堆内存是程序从堆中为其分配的,大小任意的,使用完后要显示释放内存。
当应用程序用关键字new 等创建对象时,就从堆中为它分配一块内存,使用完后程序调用free或者delete 释放该内存,否则就说该内存就不能被使用,我们就说该内存被泄漏了。
4. 什么是基本表?什么是视图?答案:基本表是本身独立存在的表,在 SQL 中一个关系就对应一个表。
视图是从一个或几个基本表导出的表。
视图本身不独立存储在数据库中,是一个虚表5. 试述视图的优点(1) 视图能够简化用户的操作(2) 视图使用户能以多种角度看待同一数据;(3) 视图为数据库提供了一定程度的逻辑独立性;(4) 视图能够对机密数据提供安全保护。
sql数据库面试题
sql数据库面试题1. 请解释什么是数据库以及数据库管理系统(DBMS)。
数据库是一种用于存储和管理结构化数据的软件系统。
它可以帮助我们有效地组织和处理大量的数据,并提供方便的数据访问和查询功能。
数据库管理系统(DBMS)是一种用于管理数据库的软件系统,它提供了一系列的操作和功能,例如数据定义、数据查询、数据更新等。
2. 请解释什么是SQL以及其用途。
SQL(Structured Query Language)是一种用于操作和管理关系型数据库的语言。
它可以用于创建数据库、建表、插入数据、更新数据、删除数据等操作,并且可以通过查询数据来获取所需的信息。
SQL是一种标准化的语言,几乎所有的关系型数据库都支持它。
3. 请解释什么是关系型数据库和非关系型数据库,并列举它们的优缺点。
关系型数据库是基于关系模型的数据库,数据以表格的形式组织,并且表格之间可以通过关系建立联系。
常见的关系型数据库有MySQL、Oracle等。
非关系型数据库则不遵循传统的表格和关系模型,常见的非关系型数据库有MongoDB、Redis等。
优点:- 关系型数据库具有良好的数据一致性和完整性,适用于复杂的数据结构。
- 非关系型数据库具有良好的可扩展性和性能,适用于大规模的分布式系统。
缺点:- 关系型数据库在处理大量数据和高并发访问时性能较差。
- 非关系型数据库在数据一致性和完整性上相对弱一些。
4. 请解释什么是索引,并讨论索引对数据库性能的影响。
索引是一种特殊的数据结构,用于快速定位和访问数据库中的数据。
它类似于书籍的目录,可以根据关键词快速查找到所需的数据行。
索引可以大大提高数据库的查询性能,减少数据扫描的时间。
索引对数据库性能的影响取决于使用的方式和索引的设计。
优化的索引可以加速数据查询,同时也会增加数据插入和更新的开销。
过多或不合理的索引会占用额外的存储空间,并且可能导致查询性能下降。
5. 请解释什么是事务,以及为什么使用事务。
sql面试题及答案
sql面试题及答案SQL(Structured Query Language)是一种用于管理和操作关系数据库的标准编程语言。
在面试中,SQL问题通常用来评估候选人对数据库查询、数据操作和数据库设计的理解。
以下是一些常见的SQL面试题及其答案:# 1. 什么是SQL?答案:SQL是一种用于存储、操作和检索数据的编程语言,主要用于关系数据库管理系统(RDBMS)。
# 2. 列举一些基本的SQL命令。
答案:基本的SQL命令包括:- SELECT:用于从数据库中检索数据。
- INSERT INTO:用于向数据库表中插入新数据。
- UPDATE:用于修改表中的数据。
- DELETE:用于从表中删除数据。
- CREATE TABLE:用于创建新表。
- ALTER TABLE:用于修改现有表的结构。
- DROP TABLE:用于删除表。
# 3. 什么是主键(Primary Key)?答案:主键是数据库表中的一个或多个字段,用于唯一标识表中的每条记录。
主键的值必须是唯一的,并且不能为NULL。
# 4. 什么是外键(Foreign Key)?答案:外键是一个表中的字段,它引用了另一个表的主键。
外键用于建立两个表之间的关联,确保数据的引用完整性。
# 5. 什么是索引(Index)?答案:索引是数据库表中的一个结构,用于提高查询速度。
通过索引,数据库可以快速定位到表中的数据,而不需要扫描整个表。
# 6. 什么是事务(Transaction)?答案:事务是一系列的数据库操作,它们作为一个整体被执行,具有原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)的特性。
# 7. 什么是SQL注入?答案:SQL注入是一种安全漏洞,攻击者可以通过在应用程序的输入字段中插入恶意SQL代码,来操纵后端数据库。
# 8. 如何防止SQL注入?答案:防止SQL注入的方法包括:- 使用参数化查询。
sql数据库面试题及答案
sql数据库面试题及答案【篇一:sql数据库经典面试题(笔试题)】=txt>1.一道sql语句面试题,关于group by表内容:2005-05-09 胜2005-05-09 胜2005-05-09 负2005-05-09 负2005-05-10 胜2005-05-10 负2005-05-10 负如果要生成下列结果, 该如何写sql语句?胜负2005-05-09 2 22005-05-10 1 2------------------------------------------create table #tmp(rq varchar(10),shengfu nchar(1))insert into #tmp values(2005-05-09,胜)insert into #tmp values(2005-05-09,胜)insert into #tmp values(2005-05-09,负)insert into #tmp values(2005-05-09,负)insert into #tmp values(2005-05-10,胜)insert into #tmp values(2005-05-10,负)insert into #tmp values(2005-05-10,负)1)select rq, sum(case when shengfu=胜 then 1 else 0 end)胜,sum(case when shengfu=负 then 1 else 0 end)负 from #tmp group by rq2) select n.rq,n.勝,m.負 from (select rq,勝=count(*) from #tmp where shengfu=胜group by rq)n inner join(select rq,負=count(*) from #tmp where shengfu=负group by rq)m on n.rq=m.rq3)select a.col001,a.a1 胜,b.b1 负 from(select col001,count(col001) a1 from temp1 where col002=胜group by col001) a,(select col001,count(col001) b1 from temp1 where col002=负group by col001) bwhere a.col001=b.col0012.请教一个面试中遇到的sql语句的查询问题表中有a b c三列,用sql语句实现:当a列大于b列时选择a列否则选择b列,当b列大于c列时选择b列否则选择c列。
sql数据库基础面试题复习题考试题-全
sql数据库基础面试题复习题考试题-全D6、某单位由不同的部门组成,不同的部门每天都会生产一些报告、报表等数据,以为都采用纸张的形式来进行数据的保存和分类,随着业务的发展,这些数据越来越多,管理这些报告越来越费力,此时应考虑()(选择一项)A、由多个人来完成这些工作B、在不同的部门中,由专门的人员去管理这些数据C、采用数据库系统来管理这些数据D、把这些数据统一成一样的格式7、在SQL Server 2005中,对于数据库的定义正确的是()(选择一项)A、数据库是用来描述事物的符号记录B、数据库是位于用户与操作系统之间的一层数据管理软件C、数据库是按照数据结构来组织、存储和管理数据的创库D、数据库是指在计算机系统中引入数据库系统后的构成8、在SQL Server 2005中,对于数据库的基本概念描述错误的是()(选择一项)A、数据、数据库、数据库管理系统和数据库系统都是与数据库技术相关的概念B、数据库是计算机科学的重要分支,是信息系统的核心和基础C、数据库系统由数据库、数据库管理系统、应用系统、数据库管理员和用户组成D、数据库系统只由数据库和用户组成9、数据库管理技术发展至今,主要经历了3个阶段,它们的顺序是()(选择一项)A、人工管理阶段、数据库管理阶段、文件管理阶段B、人工管理阶段、文件管理阶段、数据库管理阶段C、数据库管理阶段、文件管理阶段、人工管理阶段D、文件管理阶段、人工管理阶段、数据库管理阶段10、下列对于数据库管理技术发展至今经历的阶段特点描述错误的是()(选择一项)A、人工管理阶段数据由人员自行携带,数据与程序并不能独立且不能长期保存数据B、文件管理阶段是指可以通过按文件访问的方式管理数据C、数据库管理阶段使得数据结构化,数据共享性好但独立性差D、数据库管理阶段出现的数据库管理系统实现了数据库的独立、使用和维护11、数据库系统根据数据存储的数据模型可分为()(选择一项)A、层次型数据库B、层次型数据库、网状型数据库C、层次型数据库、网状型数据库、关系型数据库D、层次型数据库、网状型数据库、关系型数据库、面向对象型数据库12、在SQL Server 2005中,最常用的数据存储模型是()(选择一项)A、层次型数据库B、网状型数据库C、关系型数据库D、面向对象型数据库13在SQL Server 2005中,对于数据库管理系统的特点描述不正确的是()(选择一项)A、安全性,数据不会丢失B、共享性,多个用户可以同时使用C、独立性,数据与应用程序之间相互分离D、完整性,数据保持一致13、在SQL Server 2005中,对于SQL全称描述正确的是()(选择一项)A、数据库语言B、结构化查询语言C、结构化语言D、数据库查询语言14、下列对SQL Server2008描述错误的是()(选择一项)A、SQL Server采用的是浏览器/服务器体系结构B、SQL Server2008是用于大规模联机事物处理、数据仓库和电子商务应用的数据库和数据分析平台C、它为使用者提供了强大的、界面友好的工具D、SQL Server2008降低了从移动设备到企业数据库系统的多平台上创建、部署、管理,使企业数据和分析应用程序的复杂性15、使用SQL Server2008,以下方式中()不能正确启动服务器(选择一项)A、在运行对话框中输入net stop mssqlserverB、在运行对话框中输入net start mssqlserverC、单击“开始“→选择”程序“→选择”Microsoft SQL Server 2008“→选择“配置工具”→选择“SQL Server配置管理器”D、单击“开始“→选择”设置“→选择”控制面板“→选择“管理工具”→选择“服务”→选中SQL Server(MSSQLSERVER)服务16、SQL Server中自己建立的studentMIS数据库属于(选择一项)A用户数据库B、系统数据库C、数据库管理系统D、数据库模板17、下列关于系统数据库说法错误的是(选择一项)A、master数据库保存有放在SQL Server实体上的所有数据库B、tempdb数据库中存放的是临时对象C、msdb数据库包含了诸如系统登录、配置设置、已连接的Server等信息D、model数据库是一个用来在实体上创建新用户数据库的模板数据库第二章1、在SQL Server 2005中,数据完整性是指()。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
不定项选择题(针对以下题目,请选择最符合题目要求的答案,每道题有一项或二项正确答案。
针对每一道题目,所有答案都选对,则该题得分,所选答案错误或不能选出所有答案,则该题不得分。
题量为50道,每题2分,总分为100分。
)第一章1、是SQLServer数据库的主数据文件的扩展名。
(选择一项)A、.sqlB、.mdbC、.ldfD、.mdf2、在SQL Server 2005中,有系统数据库和用户数据库,下列不属于系统数据库的是()。
(选择一项)A、masterB、pubsC、modelD、msdb3、当安装完SQL Server2005数据库时,系统默认当前的超级管理员是( ) (选择一项)A、saB、masterC、administratorD、super4、在使用SQL Server2005数据库时,有时需要将本机的数据库移动到其他机器上,恢复成对应的数据库使用。
移动数据库分两步进行,应包括()和附加数据库(选择一项)A、分离数据库 B、删除数据库 C、新建数据库 D、合并数据库5、在SQL Server2005中,附加数据库操作是指()(选择一项)A、把SQL Server 数据库文件保存为其他数据文件B、根据数据库物理文件中的信息,把数据库在SQL Server 2005中恢复C、把所有该数据库表的数据清空D、把数据库删除掉6、某单位由不同的部门组成,不同的部门每天都会生产一些报告、报表等数据,以为都采用纸张的形式来进行数据的保存和分类,随着业务的发展,这些数据越来越多,管理这些报告越来越费力,此时应考虑()(选择一项)A、由多个人来完成这些工作B、在不同的部门中,由专门的人员去管理这些数据C、采用数据库系统来管理这些数据D、把这些数据统一成一样的格式7、在SQL Server 2005中,对于数据库的定义正确的是()(选择一项)A、数据库是用来描述事物的符号记录B、数据库是位于用户与操作系统之间的一层数据管理软件C、数据库是按照数据结构来组织、存储和管理数据的创库D、数据库是指在计算机系统中引入数据库系统后的构成8、在SQL Server 2005中,对于数据库的基本概念描述错误的是()(选择一项)A、数据、数据库、数据库管理系统和数据库系统都是与数据库技术相关的概念B、数据库是计算机科学的重要分支,是信息系统的核心和基础C、数据库系统由数据库、数据库管理系统、应用系统、数据库管理员和用户组成D、数据库系统只由数据库和用户组成9、数据库管理技术发展至今,主要经历了3个阶段,它们的顺序是()(选择一项)A、人工管理阶段、数据库管理阶段、文件管理阶段B、人工管理阶段、文件管理阶段、数据库管理阶段C、数据库管理阶段、文件管理阶段、人工管理阶段D、文件管理阶段、人工管理阶段、数据库管理阶段10、下列对于数据库管理技术发展至今经历的阶段特点描述错误的是()(选择一项)A、人工管理阶段数据由人员自行携带,数据与程序并不能独立且不能长期保存数据B、文件管理阶段是指可以通过按文件访问的方式管理数据C、数据库管理阶段使得数据结构化,数据共享性好但独立性差D、数据库管理阶段出现的数据库管理系统实现了数据库的独立、使用和维护11、数据库系统根据数据存储的数据模型可分为()(选择一项)A、层次型数据库B、层次型数据库、网状型数据库C、层次型数据库、网状型数据库、关系型数据库D、层次型数据库、网状型数据库、关系型数据库、面向对象型数据库12、在SQL Server 2005中,最常用的数据存储模型是()(选择一项)A、层次型数据库B、网状型数据库C、关系型数据库D、面向对象型数据库13在SQL Server 2005中,对于数据库管理系统的特点描述不正确的是()(选择一项)A、安全性,数据不会丢失B、共享性,多个用户可以同时使用C、独立性,数据与应用程序之间相互分离D、完整性,数据保持一致13、在SQL Server 2005中,对于SQL全称描述正确的是()(选择一项)A、数据库语言B、结构化查询语言C、结构化语言D、数据库查询语言14、下列对SQL Server2008描述错误的是()(选择一项)A、SQL Server采用的是浏览器/服务器体系结构B、SQL Server2008是用于大规模联机事物处理、数据仓库和电子商务应用的数据库和数据分析平台C、它为使用者提供了强大的、界面友好的工具D、SQL Server2008降低了从移动设备到企业数据库系统的多平台上创建、部署、管理,使企业数据和分析应用程序的复杂性15、使用SQL Server2008,以下方式中()不能正确启动服务器(选择一项)A、在运行对话框中输入net stop mssqlserverB、在运行对话框中输入net start mssqlserverC、单击“开始“?选择”程序“?选择”Microsoft SQL Server 2008“?选择“配置工具”?选择“SQL Server配置管理器”D、单击“开始“?选择”设置“?选择”控制面板“?选择“管理工具”?选择“服务”?选中SQL Server(MSSQLSERVER)服务16、SQL Server中自己建立的studentMIS数据库属于(选择一项)A用户数据库B、系统数据库C、数据库管理系统D、数据库模板17、下列关于系统数据库说法错误的是(选择一项)A、master数据库保存有放在SQL Server实体上的所有数据库B、tempdb数据库中存放的是临时对象C、msdb数据库包含了诸如系统登录、配置设置、已连接的Server等信息D、model数据库是一个用来在实体上创建新用户数据库的模板数据库第二章3、在SQL Server 2005中,数据完整性是指()。
(选择一项)A、数据库中所有数据格式一致B、数据库中数据的准确性C、所有的数据都存入了数据库中D、数据库中不存在数据冗余4、在SQL Server2005中,()约束表示字段的NOTNULL属性。
(选择一项)A、主键B、检查C、默认值D、非空5、在SQL Server2000中,下面关于数据完整性的描述正确的是()(选择二项)A、如果数据库中没有重复的数据,即没有数据冗余的时候,数据就是完整的B、维护数据完整性就是保证数据库中数据的准确性C、数据库中数据越详细则越符合数据完整性D、维护数据完整性可以保证数据的一致性,避免出现没有意义的数据4、在SQL Server2005中,主键用来实施( ? )(选择一项)A、引用完整性约束B、实体完整性约束C、域完整性约束D、自定义完整性约束5、在SQL Server2005数据库中,有一个book(图书)表 ,包含字段:bookId(图书编号),title(书名),pDate(出版日期),author(作者)等字段,其中( )字段作为该表的主键是最适当的.(选择一项)A、bookIDB、titleC、pDateD、author6、在SQL Server2005数据库中,主键是表中的能用来唯一标识表中的每一行的一列或多列的组合。
以下关于主键的说法正确的是()(选择一项)A、表创建后,一旦设定了主键,主键就不能现更改B、表中可以没有主键C、主键列的值可以重复D、主键列允许插入空值7、在SQL Server 2005中,外键用于将一个表中的列与另一表中的列关联起来,为了确保引用的完整性,要求()(选择一项)A、外键列的列值必须已经存在于主键表的对应列的列值中B、外键列的列值必须与主键表的对应列的列值——对应C、外键列不能有重复的值D、外键表的数据行行数必须大于主键表的数据行行数8、在SQL Server 2005数据库中,唯一地标识表中记录的一列或者几列被称为()(选择一项)A、约束B、查询C、主键D、关系9、在数据库系统中,数据存在副本的现象是数据冗余,减少数据冗余最常用的方法是()(选择一项)A、建立实体之间的关系B、分类存储C、去掉实体中存在数据冗余的列D、建立索引10、数据库系统发展到今天,占统治地位的乃然是关系数据库。
关系数据库中所谓的数据冗余指的是()(选择一项)A、数据不准确B、存在重复数据C、数据之间不存在关系D、数据量太大11、在SQL server 2005数据库中,标识列本身没有实际意义,而是为了区分表中不同的记录。
下列关于标识列的说法中错误的是()。
(选择一项)A、一个表中只能有一格标识列B、不能对标识列加上默认约束C、标识列可以使任意数据类型D、不能更新或输入标识列的值12、在SQL Server 2005数据库中,主键是表中能用来惟一标识表中每一行的一列或多列的组合。
通过设定表的主键可以实现()完整性约束。
(选择一项)A、引用B、实体C、域D、自定义13、要在SQL Server 2005数据库中创建一个网站用户信息表,其中用户的Email地址用一个字段来存储,规定Email地址中要含有“@”和“.”字符。
这一规定可以采用()来实现。
(选择一项)A、主键约束B、外键约束C、检查约束D、默认约束14、在SQL Server2005数据库中建立表间关系是实施引用完整性约束,关于表间关系,以下说法错误的是()(选择一项)A、建立关系的两张表中,关联字段的名称可以不同B、建立关系的两张表中,如果子表中包含记录,则主表中一定包含记录C、建立关系的两张表中,如果主表中包含记录,则子表中一定包含记录D、建立关系的两张表中,主表和子表中的记录可是一对多的15、在SQL Server2005数据库中,可以使用()关键字来判断表中是否存在包含空数据字段的记录行(选择一项)A、NONEB、NOTC、NULLD、NO16、下列关于数据表的描述错误的有()(选择二项)A、数据库中的表由行和列组成B、列包含了若干行的信息,一列称之为一条记录C、行由同类的信息组成,每一行称为一个字段D、一个表有一条或多条记录组成17、存储电话号码格式应当采用的数据类型是()(选择一项)A、字符B、整数C、浮点数D、bit18、在SQL Server2005中,标识列必须采用()数据类型(选择一项)A、字符B、intC、浮点数D、bit19、在SQL Server2005中,以下对字段数据类型指定错误的是()(选择一项)A、charB、varcharC、int(4)D、decimal(4,1)20、在SQL Server2005中,想建立一张名为student的表,下列创建正确的是()(选择一项)A、create table student( …)B、create student( …)C、create table student{…}D、create database student( …)21、在SQL Server2005中,需要将表student,其中id字段需要设置为主键,则以下可以实现的有()(选择二项)A、create table student(id int primary key not null)B、create table student(id primary key int not null)C、create table student(id int not null)Alter table student add constraint 约束名称 primary key (id)D、create table student(id int not null)add constraint 约束名称 primary key (id)22、在SQL Server2005中,对userinfo表中列修改错误的是()(选择一项)A、alter table userinfo add age int not null;B、alter table userinfo drop column age;C、alter table userinfo update column age decimal(6,2)D、alter table userinfo alter column age decimal(6,2)23、在SQL Server2005中,要删除表studentInfo错误的是()(选择一项)A、if exists(select * from where [name]=’studentInfo’)Drop table studentInfogoB、if object_id(‘studentInfo’) is not nullDrop table studentInfogoC、drop table studentInfoD、delete table studentInfo第三章6、在SQL Server 2005中,假设表users包含主键列id,那么执行“Update users SET id=20WHERE id=30”,执行的结果可能是()。