关于“无法附件数据库”过程的遇到的问题:

1、数据文件本身,具有访问权限的限制

---- 选中 数据库文件所在的文件夹---->右键菜单(属性)----> 安全 --->User用户组(赋予完整控制权限)

2、数据库版本兼容性问题

---- 数据库分离无效情况下,将整个数据库(结构+数据),导出成SQL

选中正在运行的数据库 ---->  右键菜单(任务--生成脚本) --->“高级”设置中---->将“要编写的脚本类型”设置为“架构和数据”

所谓“子查询”:

---- 将“查询语句”嵌入的其他的SQL语句中。

---- 原来由“变量”来担当的责任,您都可以考虑使用查询直接替换

---赋值语句

declare @age int

set @age = (子查询)

print @age

--- 逻辑语句中

declare @i int

set @i= 18

if @i < (子查询 )

print '成功提交!'

else

print '失败'

---其他的Select语句中

select * from [Admin]

where len(LoginPwd) < (子查询)

【注意】

子查询除了自己独立实现查询得到结果外,也可以使用父查询相关数据

“多表联查”中的注意事项:

1、主表,应该是所有表单中,相互关联性最多的那张表(与其他表有主外键关系最多的那张表)

2、在inner join的连接顺序上,遵循“连接传递原则”,将要连接的表,一定要与已经inner join连接的表,具有直接主外键关系

“多表联查”与“子查询”互替换性:

1、所有的“多表联查”都可以被“子查询”替换

2、但不是所有的“子查询”都可以被“多表联查”替换

3、适用场景:

当Select的数据来自于“多张表单”时,适合使用“多表联查”

当Where的条件来自于“多张表单”时,适合使用“子查询”

“子查询”与“父查询”的连接符号:

>、>=、<、<=、=、!=

子查询:只能返回一个结果(一行一列)

in

子查询:返回多个结果(多行一列)

Exists

子查询:可以返回任意结果

"not in"应用与“分页查询”:

--- 查询整张表,并按照每页10条分割,取出第4页的数据

declare @pageRowCount int ,@page int

set @pageRowCount =10 --每页的记录数

set @page = 2 --你要的页码

select top (@pageRowCount) * from temptable-

where id not in (select top ((@page-1) * @pageRowCount) id from TempTable)

第四章子查询(最后一个示例)

select 应到人数 =(select count(1) from Student),

实到人数= (select count(1) from Result

where Result.SubjectNo = (select SubjectNo from Subject where SubjectName = 'java')

and  Result.ExamDate = (

select max(ExamDate) from Result

where SubjectNo = (select SubjectNo from Subject where SubjectName = 'java')

)

),

缺考人数 = (select count(1) from Student) -

(select count(1) from Result

where Result.SubjectNo = (select SubjectNo from Subject where SubjectName = 'java')

and  Result.ExamDate = (

select max(ExamDate) from Result

where SubjectNo = (select SubjectNo from Subject where SubjectName = 'java')

)

)

-----------------------------------------------------------------------------------------------------------

--创建“表变量”,做数据的临时保存

declare @tb table(姓名 varchar(50),学号 int,成绩 varchar(10),是否通过 varchar(10))

insert into @tb

select Student.StudentName,

Student.StudentNo,

case

when A.StudentResult is null then '缺考'

else cast(A.StudentResult as varchar(10))

end,

case

when A.StudentResult>=60 then '是'

else '否'

end

from Student

left join

(

select * from Result

where Result.SubjectId = (

select SubjectId from Subject where SubjectName = 'java'

) --java

and    Result.ExamDate= (

select max(ExamDate) from Result where Result.SubjectId =

(select SubjectId from Subject where SubjectName = 'java')

)  --最后一次(java)

) as A  on Student.StudentNo = A.StudentNo

---从临时表中进行数据查询

select * from @tb

--统计结果

select 总人数    = (select count(1) from @tb),

通过人数 = (select count(1) from @tb where 是否通过='是'),

通过率 = cast( ((select count(1) from @tb where 是否通过='是') /cast( (select count(1) from @tb) as float)) * 100 as varchar(20)) + '%'

优化MySchool数据库(四)的更多相关文章

  1. 优化MySchool数据库设计之【巅峰对决】

    优化MySchool数据库设计 之独孤九剑 船舶停靠在港湾是很安全的,但这不是造船的目的 By:北大青鸟五道口原玉明老师 1.学习方法: 01.找一本好书 初始阶段不适合,可以放到第二个阶段,看到知识 ...

  2. 优化MySchool数据库(二)

    优化School数据库(TSQL建库建表建约束) 使用T_sql代码建库.建表.建约束: 建库: Create database HotelManagerSystem on ( ---- 数据文件-- ...

  3. 优化MySchool数据库(一)

    <优化MyShcool数据库>:能够的独立的分析|设计|创建|运营|你的独立的数据库系统 设计--->实现--->TSQL--->查询优化---->性能优化技术-- ...

  4. 优化MySchool数据库设计总结

    数据库的设计   一:什么是数据库设计? 数据库设计就是将数据库中的数据实体以及这些数据实体之间的关系,进行规范和结构化的过程. 二:为什么要实施数据库设计? 1:良好的数据库设计可以有效的解决数据冗 ...

  5. 优化MySchool数据库设计

    第一章 数据库的设计 1.E-R图中: 矩形:实体 椭圆:属性 菱形:关系 直线:连接实体,属性和关系 2.映射基数 一对多 多对一 多对多 3.范式: 第一范式:确保每列的原子性 第二范式:确保表中 ...

  6. accp7.0优化MySchool数据库设计内测笔试题总结

    1) 在SQL Server 中,为数据库表建立索引能够(C ). 索引:是SQL SERVER编排数据的内部方法,是检索表中数据的直接通道 建立索引的作用:大大提高了数据库的检索速度,改善数据库性能 ...

  7. S2--《优化MySchool数据库设计》总结

    第一章    数据库的设计 1.1  数据库设计 数据库中创建的数据库结构的种类,以及在数据实体之间建立的复杂关系是决定数据库系统效率的重要因素. 糟糕的数据库设计表现在以下两个方面: *效率低下 * ...

  8. 优化MySchool数据库(存储过程)

    什么是“存储过程”: ---- 数据库中,用于存储“业务逻辑”的技术!(T-SQL代码当做数据一样保存到数据可) 语法 : [if exists(select * from sysobjects wh ...

  9. 优化MySchool数据库(事务、视图、索引)

    事务.视图.索引: 事务:当生活逻辑中的“一个步骤”,需要使用多条SQL去完成时,必须使用事务来确保其“完整性“. 视图:简化数据库结构,方便你编写SQL语句(简化SQL语句的编写) 索引:提高“数据 ...

随机推荐

  1. ES6笔记(1) -- 环境配置支持

    系列文章 -- ES6笔记系列 虽然ES6已经发布一年多了,但在各大浏览器之中的支持度还不是很理想,在这查看ES6新特性支持度 Chrome的最新版本浏览器大部分已经支持,在Node.js环境上支持度 ...

  2. C#中方法的声明

    C#中方法的声明(四要素) 访问修饰符 :public,private(方法的默认访问修饰符) 返回值类型:void 和 非void 方法名称    : 规范是方法名称取动词,每个单词的首字母大写. ...

  3. php面向对象常见的专业术语

    类 − 定义了一件事物的抽象特点.类的定义包含了数据的形式以及对数据的操作. 对象 − 是类的实例. 成员变量 − 定义在类内部的变量.该变量的值对外是不可见的,但是可以通过成员函数访问,在类被实例化 ...

  4. CSS 居中方法集锦

    记录收集纯CSS层面实现的水平.垂直居中方法可用于块级.行内快.内联元素以及文字图片等. 水平或垂直居中 1.1 text-align 1.2 margin 1.3 line-height 1.4 p ...

  5. STM32L系列单片机内部EEPROM的读写

    STM32L系列单片机内部提供了EEPROM存储区域,但实质上,其FLASH也是EEPROM类型,只不过有一块区域被开放出来专门用作EEPROM操作而已.STM32L的EEPROM使用寿命设计为100 ...

  6. 【Remoting】.Net remoting方法实现简单的在线升级(下篇:重启exe)

    一.前言      上篇运用了.Net Remoting技术解决了本地与服务器版本对比,并下载更新包的过程. 本篇主要是应用Process,来实现重启程序的过程. 情景假设:       Revit2 ...

  7. 优化Angular应用的性能

    MVVM框架的性能,其实就取决于几个因素: 监控的个数 数据变更检测与绑定的方式 索引的性能 数据的大小 数据的结构 我们要优化Angular项目的性能,也需要从这几个方面入手. 1. 减少监控值的个 ...

  8. 如何在WinForm中发送HTTP请求

    如何在WinForm中请求发送HTTP 手工发送HTTP请求主要是调用 System.Net的HttpWebResponse方法 手工发送HTTP的GET请 求: string strURL = &q ...

  9. SQL Pretty Printer-不错的SQL格式化工具

    前言 好长时间没有写过博客了,人变懒了很多,应该说本来也不怎么勤快.但今天为了这个工具,必须得勤快一下了,天下真的没有免费的午餐. 之前使用过sql server 2000的查询设计器和Toad fo ...

  10. Xamarin.ios——First APP

    环境:MAC+Xamarin Studio 先讲讲安装吧,最普遍的方法就是去Xamarin官网,注册个账号,填写信息啥的开始下载,安装.但,在天朝的网络环境下,在下载android模块的东东时,总会下 ...