net面试题整理 数据库篇

net面试题整理 数据库篇

ID:34145452

大小:99.09 KB

页数:8页

时间:2019-03-04

net面试题整理 数据库篇_第1页
net面试题整理 数据库篇_第2页
net面试题整理 数据库篇_第3页
net面试题整理 数据库篇_第4页
net面试题整理 数据库篇_第5页
资源描述:

《net面试题整理 数据库篇》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、1、索引好处:(1)提高查询表内数据的速度。(2)表与表之间的连接速度加快。坏处:(1)创建索引和维护索引都会消耗时间。(2)会占用一定物理空间,占用物理空间过多会影响整个SQLServer性能。建立索引的原则:(1)主键的数据列一定要建立索引,因为主键可以加速定位到表中的某一行。(2)外键的数据列一定要建立索引,外键列通常用于表与表之间的连接,在其上创建索引可以加快表间的连接速度。(3)对于经常查询的数据列最好建立索引。索引分类:(1)聚集索引。(2)非聚集索引。(3)唯一索引。2、视图优点:(1)数据保密,对不同的用户定义不同的视图,使用户只能看到与自己相关的数据。(2)简化查询操作。(

2、3)保证数据的逻辑独立性。缺点:某些视图是不能更新数据的,union、groupby、avg、sum、max、distinct等及连接表的视图。3、存储过程存储过程是一个预编译的SQL语句,优点是允许模块化的设计,就是说只需创建一次,以后在该程序中就可以调用多次。如果某次操作需要执行多次SQL,使用存储过程比单纯SQL语句执行要快。主要优点有如下三点:(1)通过本地存储、代码预编译和缓存技术,提高数据操作的性能。(2)增加了可维护性。(3)增强了安全性。4、触发器触发器(trigger)是个特殊的存储过程,它的执行不是由程序调用,也不是手工启动,而是由事件来触发,比如当对一个表进行操作(in

3、sert,delete,update)时就会激活它执行。触发器经常用于加强数据的完整性约束和业务规则等。触发器的主要好处在于它们可以包含使用Transact-SQL代码的复杂处理逻辑。虽然触发器功能强大,能轻松可靠地实现许多复杂的功能,但必须慎用触发器,因为滥用会造成数据库及应用程序的维护困难。5、游标游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次以行或者多行前进或向后浏览数据的能力。我们可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许用户对指定位置的数据进行处理。游标包含两个部分:游标结果集(定义该游标得SELECT语句返回的

4、行的集合),游标位置(指向这个结果集某一行的当前指针)。游标的优点:1.允许程序对由查询语句Select返回的行集合中的每一行执行相同或不同的操作,而不是对整个行集合执行同一操作。2.提供基于游标位置的表中的行进行删除和更新的能力。3.游标实际上是作为面向数据库集合的数据库管理系统(DBMS)和面向行的程序设计之间的桥梁。6、什么是事务?什么是锁?事务:被绑定在一起作为一个逻辑工作单元的SQL语句分组,如果任何一个语句操作失败那么整个操作就会失败,以后操作就会回滚到操作前状态,或者是上一个节点。为了确保要么执行,要么不执行,就可以使用事务。要将有组语句作为事务考虑,就需要通过ACID测试,即

5、原子性,一致性,隔离性和持久性。锁:在所以的DBMS中,锁是实现事务的关键,锁可以保证事务的完整性和并发性。与现实生活中锁一样,它可以使某些数据的拥有者,在某段时间内不能使用某些数据或数据结构。当然锁还分级别的。7、存储过程和函数的区别1.一般来说,存储过程实现的功能要复杂一点,而函数的实现的功能针对性比较强。2.对于存储过程来说可以返回参数,而函数只能返回值或者表对象。3.存储过程一般是作为一个独立的部分来执行,而函数可以作为查询语句的一个部分来调用,由于函数可以返回一个表对象,因此它可以在查询语句中位于FROM关键字的后面。4.当存储过程和函数被执行的时候,SQLManager会到pro

6、cedurecache中去取相应的查询语句,如果在procedurecache里没有相应的查询语句,SQLManager就会对存储过程和函数进行编译。8、维护数据库的完整性和一致性,你喜欢用触发器还是自写业务逻辑?为什么?尽可能使用约束,如check,主键,外键,非空字段等来约束,这样做效率最高,也最方便。其次是使用触发器,这种方法可以保证,无论什么业务系统访问数据库都可以保证数据的完整新和一致性。最后考虑的是自写业务逻辑,但这样做麻烦,编程复杂,效率低下。9、什么是内存泄漏?一般我们所说的内存泄漏指的是堆内存的泄漏。堆内存是程序从堆中为其分配的,大小任意的,使用完后要显示释放内存。当应用程

7、序用关键字new等创建对象时,就从堆中为它分配一块内存,使用完后程序调用free或者delete释放该内存,否则就说该内存就不能被使用,我们就说该内存被泄漏了。10、SQLSERVER服务器中,给定表table1中有两个字段ID、LastUpdateDate,ID表示更新的事务号,LastUpdateDate表示更新时的服务器时间,请使用一句SQL语句获得最后更新的事务号SELECTIDFROMtable1W

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。