美文网首页T-Sql
2018年9月17日.NET笔试面试题

2018年9月17日.NET笔试面试题

作者: 墨弄笔 | 来源:发表于2018-09-16 10:02 被阅读1422次

    说一下 SQLServer 中索引的两种类型。

    • 聚簇(或者叫做聚集,cluster)索引和非聚簇索引。
    • 字典的拼音目录就是聚簇(cluster)索引,笔画目录就是非聚簇索引。这样查询“G 到 M 的汉字”就非常快,而查询“6 划到 8 划的字”则慢。
    • 聚簇索引是一种特殊索引,它使数据按照索引的排序顺序存放表中。
    • 聚簇索引类似于字典,即所有词条在字典中都以字母顺序排列。
    • 聚簇索引实际上重组了表中的数据,所以你只能在表中建立一个聚簇索引。

    • 当数据按值的范围查询时,聚簇索引就显得特别有用。因为所有 SQLServer 都必需先找到所查询范围的第一行,然后依次下去,直到该范围的最后一个值找到为止,并且保证了所有其他值也落在这个范围内。
    • 举一个例子,一个应用程序要查找首字母位于 G 和 P 之间的姓名列表,SQLServer 首先找到以字母 G 开头的名字,取出所有记录,直到找到以字母 P 开头的名字为止,这种方法使得查询过程非常高效。
    • 进行大量数据改动的表不适宜用聚簇索引,因为 SQLServer 将不得不在表中维护行的次序。

    • 如果要索引的值极少,例如一个列包含的全都是 1 和 0,创建聚簇索引就不是个好主意。
    • 如果表经常由一个指定的列来排序,该列将是簇索引的最佳候选列,这是因为表中的数据已经为你排好序了。
    • 如果访问一个表并使用 BETWEEN、<、>、>=或<=操作符来返回一个范围的值时,应该考虑使用聚簇索引。

    如何处理百万条数据的优化?

    • 对于经常进行检索的字段创建索引,对于经常进行范围查询的一个字段创建聚簇索引。
    • 当有大量数据进行插入的时候进行批量插入。
    • 把一些代码用存储过程进行重写(当一个逻辑有多行 SQL 要执行的时候用存储过程可以优化速度,可以避免客户端和 SQLServer 之间多次交互)。
    • 加分:集群、读写分离、分区、分表。

    ADO.NET 中的五个主要对象。

    • Connection
    • 主要是开启程序和数据库之间的连接。没有利用连接对象将数据库打开,是无法从数据库中取得数据的。
    • Close 和Dispose 的区别,Close 以后还可以 Open,Dispose 以后则不能再用。

    • Command
    • 主要可以用来对数据库发出一些指令,例如可以对数据库下达查询、新增、修改、删除数据等指令,以及调用存在数据库中的存储过程等。
    • 这个对象是架构在 Connection 对象上,也就是 Command 对象是透过连接到数据源。

    • DataAdapter
    • 主要是在数据源以及 DataSet 之间执行数据传输的工作,它可以透过 Command 对象下达命令后,并将取得的数据放入 DataSet 对象中。
    • 这个对象是架构在 Command 对象上,并提供了许多配合 DataSet 使用的功能。

    • DataSet
    • 这个对象可以视为一个暂存区(Cache),可以把从数据库中所查询到的数据保留起来,甚至可以将整个数据库显示出来,DataSet 是放在内存中的。
    • DataSet 的能力不只是可以储存多个 Table 而已,还可以透过DataAdapter 对象取得一些例如主键等的数据表结构,并可以记录数据表间的关联。
    • DataSet 对象可以说是ADO.NET 中重量级的对象,这个对象架构在 DataAdapter 对象上,本身不具备和数据源沟通的能力;也就是说我们是将 DataAdapter 对象当做 DataSet 对象以及数据源间传输数据的桥梁。
    • DataSet 包含若干 DataTable、DataTableTable 包含若干 DataRow。

    • DataReader
    • 当我们只需要循序的读取数据而不需要其它操作时,可以使用 DataReader 对象。
    • DataReader 对象只是一次一条向下循序的读取数据源中的数据,这些数据是存在数据库服务器中的,而不是一次性加载到程序的内存中的,只能(通过游标)读取当前行的数据,而且这些数据是只读的,并不允许作其它的操作。
    • 因为 DataReader在读取数据的时候限制了每次只读取一条,而且只能只读,所以使用起来不但节省资源而且效率很好。
    • 使用DataReader 对象除了效率较好之外,因为不用把数据全部传回,故可以降低网络的负载。

    • 综合
    • ADO.NET 使用 Connection 对象来连接数据库,使用 Command 或 DataAdapter 对象来执行 SQL 语句,并将执行的结果返回给 DataReader 或 DataAdapter ,然后再使用取得的 DataReader 或 DataAdapter 对象操作数据结果。

    相关文章

      网友评论

        本文标题:2018年9月17日.NET笔试面试题

        本文链接:https://www.haomeiwen.com/subject/nouxnftx.html