位置: 编程技术 - 正文

SQL Server简单查询示例汇总(sql server简单查询)

编辑:rootadmin

推荐整理分享SQL Server简单查询示例汇总(sql server简单查询),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server如何查询,sql server简单查询,sql server语句查询,sql server简单查询,sql server怎样查询数据,sql server简单查询实验目的,sql server简单查询实验原理及要求,sql server简单查询实验原理及要求,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

本节我们讲讲一些简单查询语句示例以及需要注意的地方,简短的内容,深入的理解。

EOMONTH

在SQL Server 的教程示例中,对于Sales.Orders表的查询,需要返回每月最后一天的订单。我们普遍的查询如下

但是在SQL Server 出现了新的函数直接返回每个月最后一天的订单,通过EOMONTH函数即可,将

WHERE orderdate = DATEADD(MONTH, DATEDIFF(MONTH, '', orderdate), '')

替换为

如上简单而粗暴。

HAVING AND WHERE

我们利用Sales.OrderDetails表来查询总价(qty*unitprice)大于的订单,且按照总价排序。

通过此例我们来说说WHERE和HAVING的区别,下面的示例是等同的

但是利用聚合函数时能等同吗?

二者的区别我们总结一下:

(1)WHERE能够用在UPDATE、DELETE、SELECT语句中,而HAVING只能用在SELECT语句中。

(2)WHERE过滤行在GROUP BY之前,而HAVING过滤行在GROUP BY之后。

(3)WHERE不能用在聚合函数中,除非该聚合函数位于HAVING子句或选择列表所包含的子查询中。

说了这么多,关于WHERE和HAVING的区别,其实WHERE的应用场景更多,我们归根结底一句话来概括的HAVING的用法即可。

SQL Server简单查询示例汇总(sql server简单查询)

HAVING仅仅在SELECT语句中对组(GROUP BY)或者聚合函数(AGGREGATE)进行过滤

INSERT TOP分析

当将查询出的数据插入到表中,我们其实有两种解决方案。

方案一

方案二

方案一是需要查询几条就插入几条,方案二则是查询所有我们需要插入几条数据,接下来我们来看看二者不同以及二者性能问题,创建查询表并插入数据。

需要插入的两个表

方案一的插入

方案二的插入

接下来查询方案一和方案二的数据

我们对方案一和方案二插入数据之前我们对查询的数据是进行了降序,此时我们能够很明显的看到方案一中的查询数据确确实实是降序,而方案二则忽略了降序,这是个很有意思的地方,至此我们看到了二者的不同。

二者性能比较

在插入数据时我们对其进行开销分析如下:

到这里我们能够知道利用INSET TOP (N)比INSERT … SELECT TOP (N)性能更好,同时SELECT TOP(N)会对查询出的数据排序进行忽略。至此我们可以得出如下结论

结论:INSERT TOP (N)比INSERT … SELECT TOP (N)插入数据性能更好。

COUNT(DISTINCT) AND COUNT(ALL)

关于DISTINCT就不用多讲,此关键字过滤重复针对的是所有列数据一致才过滤而不是针对于单列数据一致才过滤,我们看看COUNT(DISTINCT)和COUNT(ALL)查询出的数据是一致还是不一致呢?我们首先创建测试表

插入如下测试数据

接下来我们进行如下查询

此时我们能够很清楚的看到COUNT(colName)和COUNT(ALL colName)的结果是一样的,其实COUNT(ALL colName)是默认的选项且包括所有非空值,换句话说ALL根本不需要我们去指定。

标签: sql server简单查询

本文链接地址:https://www.jiuchutong.com/biancheng/320230.html 转载请保留说明!

上一篇:浅谈SQL Server交叉联接 内部联接(sql server join)

下一篇:SQL Server附加数据库报错无法打开物理文件,操作系统错误5的图文解决教程(sql server附加数据库出错)

  • 小规模纳税人进项可以抵扣吗
  • 城镇土地使用税纳税义务发生时间
  • 企业所得税申报表A类
  • 公司之间房产过户免税条件
  • 税收的三个基本要素是
  • 现金折扣销售退回的会计分录
  • 经营性租赁购入会计分录
  • 即征即退增值税需要缴纳所得税吗
  • 个人公司转让协议怎么写
  • 进项税额转出年末要结转吗
  • 哪些票据可以抵扣个人所得税
  • linux CentOS/redhat 6.5 LVM分区使用详解
  • 上年预收账款算不算本年收入
  • php 时间差
  • php字符串赋值
  • 偿还债券本金和利息
  • 支付厂房租金计入什么科目
  • DWHeartbeatMonitor.exe进程是什么意思 DWHeartbeatMonitor是安全的进程吗
  • php 操作mysql
  • 员工出差垫钱
  • php中的正则表达式怎么使用
  • 无极框架下载
  • bootstrap 栅格
  • react 入门教程
  • 暂估入库少了
  • 条形码费用属于哪个科目
  • 小规模销售收入超过500万
  • 织梦程序
  • 已付款收到发票
  • 营业收入比销售商品收到的现金大
  • 采购原材料凭证是什么
  • 增值税冲红后附加税如何申报
  • 企业所得税的纳税调整项和比例
  • 机械租赁属于什么科目
  • 其他债权投资减值为什么不影响所有者权益
  • 预付发票能入账吗
  • 计提坏账准备如何做会计分录
  • 手机开个人劳务票怎么开
  • 上月的普票下月可以记账么
  • 赠送的商品如何开发票
  • 进项转出分录需要盖章吗
  • 过路费怎么抵扣进项税额报表怎么填
  • 房产税减按70%的政策
  • 电商会计怎么做账
  • 收到预付卡的发票是否可以报销呢?
  • 购买机器的会计分录
  • 连锁店会计处理流程
  • 工厂不开票怎么办
  • 标准成本法计算公式图
  • sql server自动增长方式
  • MySql 5.6.36 64位绿色版安装图文教程
  • sqlserver 通用分页存储过程
  • rsyslog 8.11.0 (v8-stable) 发布
  • win8.1使用技巧
  • ubuntu git not found
  • mac音频设置在哪里
  • winpe如何安装驱动
  • win7鼠标点了没反应
  • linux c命令
  • win7诊断策略服务未运行是电脑问题还是网络
  • 如何手动修复模糊图片
  • mac如何打印文件
  • linux如何使用gcc编程
  • window10耳机有电流
  • unity3ds
  • 查看进程使用的端口
  • css样式分为
  • Linux文本处理工具的实验总结
  • shell for循环执行命令
  • 每天自动重启命令
  • 常用的批处理命令
  • jquery控制滚动条位置
  • javascript web开发
  • python网络爬虫项目步骤
  • 让你略表情包
  • jquery获取url地址
  • 成都高新区办理社保在哪里?
  • 河南新乡地税局罗姓病逝
  • 税务公文字体
  • 东风小康和重庆金康
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设