2010.NET面试题整理之数据库篇_第1页
2010.NET面试题整理之数据库篇_第2页
2010.NET面试题整理之数据库篇_第3页
2010.NET面试题整理之数据库篇_第4页
2010.NET面试题整理之数据库篇_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、2010 .net面试题整理之数据库篇开篇语:这段时间由于换地方换工作而停止了该系列文章的整理,虽然现在已经开始了新的工作,为了供找工作的朋友参考以及自己复习,还是继续把该系列整理完成。对于数据库方面主要整理了最基础的知识概念(这些都是在面试和笔试中经常出现的问题)和一些常出现的数据库面试题,同样该贴也将进行继续收集和整理更新,同样欢迎大家指正完善。1 、索引好处: (1)提高查询表内数据的速度。(2)表与表之间的连接速度加快。坏处: (1)创建索引和维护索引都会消耗时间。(2 )会占用一定物理空间,占用物理空间过多会影响整个sql server性能。建立索引的原则:(1 ) 主键的数据列一定

2、要建立索引,因为主键可以加速定位到表中的某一行。(2 ) 外键的数据列一定要建立索引,外键列通常用于表与表之间的连接,在其上创建索引可以加快表间的连接速度。(3 ) 对于经常查询的数据列最好建立索引。索引分类: (1 )聚集索引。(2 )非聚集索引。(3)唯一索引。2 、视图优点:(1 ) 数据保密,对不同的用户定义不同的视图,使用户只能看到与自己相关的数据。(2 ) 简化查询操作。(3 ) 保证数据的逻辑独立性。缺点: 某些视图是不能更新数据的,union 、group by 、avg 、sum 、 max 、distinct等及连接表的视图。3 、存储过程存储过程是一个预编译的sql 语句

3、,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次sql ,使用存储过程比单纯sql 语句执行要快。主要优点有如下三点:(1 )通过本地存储、代码预编译和缓存技术,提高数据操作的性能。(2 )增加了可维护性。(3 )增强了安全性。4 、触发器触发器( trigger)是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作(insert,delete , update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。触发器的主要好处在于它们可以包含使用transact-sql 代码的

4、复杂处理逻辑。虽然触发器功能强大,能轻松可靠地实现许多复杂的功能,但必须慎用触发器,因为滥用会造成数据库及应用程序的维护困难。5 、游标游标( cursor )是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次以行或者多行前进或向后浏览数据的能力。我们可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理。游标包含两个部分:游标结果集 (定义该游标得select语句返回的行的集合),游标位置 (指向这个结果集某一行的当前指针)。游标的优点:1. 允许程序对由查询语句select返回的行集合中的每一行执行相同或不同的操作,而不是对整个

5、行集合执行同一操作。2. 提供基于游标位置的表中的行进行删除和更新的能力。3. 游标实际上是作为面向数据库集合的数据库管理系统(dbms ) 和面向行的程序设计之间的桥梁。6 、什么是事务?什么是锁?事务:被绑定在一起作为一个逻辑工作单元的sql 语句分组,如果任何一个语句操作失败那么整个操作就会失败,以后操作就会回滚到操作前状态,或者是上一个节点。为了确保要么执行,要么不执行,就可以使用事务。要将有组语句作为事务考虑,就需要通过acid测试,即原子性,一致性,隔离性和持久性。锁:在所以的dbms中,锁是实现事务的关键,锁可以保证事务的完整性和并发性。与现实生活中锁一样, 它可以使某些数据的拥

6、有者,在某段时间内不能使用某些数据或数据结构。当然锁还分级别的。7 、存储过程和函数的区别1. 一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。2. 对于存储过程来说可以返回参数,而函数只能返回值或者表对象。3. 存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于from 关键字的后面。4. 当存储过程和函数被执行的时候,sql manager会到 procedure cache中去取相应的查询语句, 如果在 procedure cache里没有相应的查询语句,sql manager就会

7、对存储过程和函数进行编译。8 、维护数据库的完整性和一致性,你喜欢用触发器还是自写业务逻辑?为什么?尽可能使用约束,如check,主键,外键,非空字段等来约束,这样做效率最高,也最方便。其次是使用触发器,这种方法可以保证,无论什么业务系统访问数据库都可以保证数据的完整新和一致性。最后考虑的是自写业务逻辑,但这样做麻烦,编程复杂,效率低下。9 、什么是内存泄漏?一般我们所说的内存泄漏指的是堆内存的泄漏。堆内存是程序从堆中为其分配的,大小任意的,使用完后要显示释放内存。当应用程序用关键字new等创建对象时,就从堆中为它分配一块内存,使用完后程序调用free或者 delete释放该内存,否则就说该内

8、存就不能被使用,我们就说该内存被泄漏了。10 、sqlserver服务器中,给定表table1 中有两个字段id 、lastupdatedate, id 表示更新的事务号,lastupdatedate表示更新时的服务器时间,请使用一句sql 语句获得最后更新的事务号select id from table1 where lastupdatedate =( selectmax(lastupdatedate) from table1 ) 11 、 写出一条sql 语句:取出表 a 中第 31到第 40 记录( sqlserver, 以自动增长的id 作为主键 , 注意: id可能不是连续的)解 1

9、: selecttop10*from a where id notin (selecttop30 id from a) 解 2: selecttop10*from a where id ( selectmax(id) from ( selecttop30 id from a )as a ) 12 、如下的两个表,如下图所示,写出执行图下sql语句的结果select*from table1 a,table2 b where a.id = b.id 13 、为管理岗位业务培训信息,建立3 个表 :s (s#,sn,sd,sa)s#,sn,sd,sa 分别代表学号、学员姓名、所属单位、学员年龄c (

10、c#,cn )c#,cn 分别代表课程编号、课程名称sc ( s#,c#,g )s#,c#,g 分别代表学号、所选修的课程编号、学习成绩1. 使用标准sql 嵌套语句查询选修课程名称为税收基础的学员学号和姓名select s#,sn from s where s# in( selects#from c,sc where c. c#=sc. c#and cn =n 税收基础 - 加 n 就表示字符串用 unicode 方式存储)2. 使用标准sql 嵌套语句查询选修课程编号为02 的学员姓名和所属单位select s.sn,s.sd from s,sc where s.s#=sc. s#and

11、sc.c#=023. 使用标准 sql 嵌套语句查询不选修课程编号为 02的学员姓名和所属单位select sn,sd from s where s#not in( selects#from sc wherec#=02) 4. 使用标准 sql 嵌套语句查询选修全部课程的学员姓名和所属单位select sn,sd from s where s# in( select sc.s# from sc rightjoin c on sc.c# = c.c# group by sc.s# - 在结果集中以学生分组,分组后的 sc.c#选课数 =c.c# 课程数 即为全部课程havingcount( distinct(sc.c#) - 注意:一个学生同一门课程可能有多条成绩记录 , 需要 distinct =( selectcount( * ) from c ) - 注意: having 条件不能用count(distinct(sc.c#) = count(distinct(c.c#)

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论