在视图中查询数据的时候,会不会使用实体表中的列上的索引呢?会 。。。。

测试结果

测试脚本

DECLARE @len INT =100;
WHILE @len>0
BEGIN INSERT INTO Teachers
( TeacherName, Sex, MoneyPay )
VALUES (
CAST(@len AS NVARCHAR), -- TeacherName - nvarchar(50)
NULL, -- Sex - bit
10000 -- MoneyPay - decimal
) SET @len-=1;
END go DECLARE @len INT =1000;
WHILE @len>0
BEGIN INSERT INTO Students
( StuName, Address, Birthday )
VALUES ( CAST(@len AS NVARCHAR )+'-'+CAST(@len AS NVARCHAR ), -- StuName - nvarchar(50)
N'', -- Address - nvarchar(200)
GETDATE() -- Birthday - datetime
) SET @len-=1;
END go DECLARE @len_t INT =1;
DECLARE @len_stu INT =1;
WHILE @len_t<=100
BEGIN
SET @len_stu=@len_t; WHILE @len_stu>0
BEGIN
INSERT INTO TeachAndStudent
( TeacherId, StudentId, CreateTime )
VALUES ( @len_t, -- TeacherId - int
@len_stu, -- StudentId - int
GETDATE() -- CreateTime - datetime
)
SET @len_stu-=1;
END SET @len_t+=1;
END
------------test:--------------
--SELECT * FROM Teachers
--GO
--SELECT * FROM Students
--GO
--SELECT COUNT(*) FROM TeachAndStudent
GO
--CREATE VIEW VTeacherAndStudents
--AS
--SELECT
--a.id AS tid,
--c.Id AS stuid,
--a.TeacherName AS tname,
--c.StuName AS sname -- FROM Teachers A
--INNER JOIN TeachAndStudent B ON B.TeacherId=A.Id
--LEFT JOIN Students C ON C.Id = B.StudentId GO SELECT * FROM VTeacherAndStudents a
WHERE a.tid>10 AND a.tid<20

【额 原来ms sqlserver 中的视图果然是“虚表”哈】的更多相关文章

  1. Ms SQLServer中的Union和Union All的使用方法和区别

    Ms SQLServer中的Union和Union All的使用方法和区别 SQL UNION 操作符 UNION 操作符用于合并两个或多个 SELECT 语句的结果集. 请注意,UNION 内部的 ...

  2. MS SQLSERVER中如何快速获取表的记录总数

    在数据库应用的设计中,我们往往会需要获取某些表的记录总数,用于判断表的记录总数是否过大,是否需要备份数据等.我们通常的做法是:select count(*) as c from tableA .然而对 ...

  3. SQLServer中在视图上使用索引(转载)

    在SQL Server中,视图是一个保存的T-SQL查询.视图定义由SQL Server保存,以便它能够用作一个虚拟表来简化查询,并给基表增加另一层安全.但是,它并不占用数据库的任何空间.实际上,在你 ...

  4. Sqlserver中的视图

    一.视图的基本知识 什么是视图:视图是从一个或多个表导出的虚拟的表,具有普通表的结构,物理上是不存在的.视图是动态的数据的集合,数据是随着基表的更新而更新. 视图的优点: ①在多表查询时,查询方便. ...

  5. 在MS SQLSERVER中如何最快的速度清空所有用户表的数据

    有时候我们需要清空数据库中所有用户表的数据,如果一张表一张表的清空的话,遇到一个庞大的数据系统估计得崩溃了.  用游标加上用变量来引用表名就可以做到这一点. 用变量来引用表名对表操作可以用在存储过程中 ...

  6. 在项目中迁移MS SQLServer到Mysql数据库,实现MySQL数据库的快速整合

    在开发项目的时候,往往碰到的不同的需求情况,兼容不同类型的数据库是我们项目以不变应万变的举措之一,在底层能够兼容多种数据库会使得我们开发不同类型的项目得心应手,如果配合快速的框架支持,那更是锦上添花的 ...

  7. SQLServer中使用索引视图

    在SQL Server中,视图是一个保存的T-SQL查询.视图定义由SQL Server保存,以便它能够用作一个虚拟表来简化查询,并给基表增加另一层安全.但是,它并不占用数据库的任何空间.实际上,在你 ...

  8. C#批量插入数据到Sqlserver中的四种方式

    我的新书ASP.NET MVC企业级实战预计明年2月份出版,感谢大家关注! 本篇,我将来讲解一下在Sqlserver中批量插入数据. 先创建一个用来测试的数据库和表,为了让插入数据更快,表中主键采用的 ...

  9. MS SQLServer 批量附加数据库 分类: SQL Server 数据库 2015-07-13 11:12 30人阅读 评论(0) 收藏

    ************************************************************ * 标题:MS SQLServer 批量附加数据库 * 说明:请根据下面的注释 ...

随机推荐

  1. JS 输出对象的属性以及方法[转载]

    <script>var obj  = {attribute:1,method:function() {alert("我是函数");}}for (var i in obj ...

  2. 你真的会玩SQL吗?Top和Apply

    原文:你真的会玩SQL吗?Top和Apply 本章预先想写一些Top和Apply基本的用法,但好像没什么意义,所以删掉了一些无用的东西,只留下几个示例,以保证系列的完整性. Top和Apply解决的常 ...

  3. 【Xamarin挖墙脚系列:IOS现有的设备SDK /OS/硬件一览】

    附件下载: http://pan.baidu.com/s/1o7rsrUE

  4. win7 奇怪的temp用户

    在C:\Users\TEMP 有个temp用户,win+r打开的也是 C:\Users\TEMP>,而不是C:\User\Administrator. 以下文章转自: http://hi.bai ...

  5. FVANCOP/ChartNew.js

    FVANCOP/ChartNew.js FVANCOP/ChartNew.js

  6. WebBrowserProgramming - Python Wiki

    WebBrowserProgramming - Python Wiki Web Browser Programming in Python

  7. Django 从零開始

    1.下载安装django 方法1: pip install Django==1.6.5 測试是否成功安装 : ~$ python import django ~$ (1, 6, 5, 'final', ...

  8. Redis 命令参考

    Redis 命令参考 http://redis.readthedocs.org/en/latest/index.html

  9. android面试题之五

    二十六.什么情况会导致Force Close ?如何避免?能否捕获导致其的异常? 抛出运行时异常时就会导致Force Close,比如空指针.数组越界.类型转换异常等等. 捕获:可以通过logcat查 ...

  10. java学习笔记day06---匿名内部类

    1.匿名内部类:其实就是内部类的简化形式,它所体现的就是一个类或者接口的子类对象.前提:     内部类必须继承或实现外部类或接口. 格式:    new 父类&接口(){};    其实就是 ...