SQL Server ---T-SQl基本语句
T-SQL 是 SQL-Server 的结构化查询语言。
基本数据操作语言.
基础语句
先创建表 我后面的列子都是用的这一个表,列名啥的 就大概看看吧~~ 纯粹为了学习语句,语法~~所以先创建个表吧~
1.SELECT语句
注意 : 最好选择想要的列,不要因为省事用 “ * ” 去选择所有的列,因为这样检索的数据会比你实际需要的数据多 ,实际使用中也会降低应用程序 和 网络 的使用 性能。
where 子句
不加限制条件的查询在填充 列表框和组合框 时非常有用,并且在其他想要提供域列表的情况下也非常有用。
在where子句中运算顺序NOT、AND、OR是酱紫的。
In 左边表达式 和 右边任意值匹配时 返回TURE。常用于子查询。
Order by 子句
决定数据的输出顺序,会选择系统开销最小的方法来输出查询结果
DECS 降序 ASC 升序
Group by 子句
用于聚合信息。
如果不使用group by 子句,那么 sum函数将返回指定列的所有行之和。用了group by ,sum函数返回的是每一组的和(ps:图里最后一行忘记删掉了~没用~)
注意:使用Group by子句时,select 列表中所有列必须是聚合列 要么就是 Group by 中包含的列。
如果在select 列表中用了聚合列,那么select 列表必须只包含聚合列,否则 必须有一个 Group by子句。
有点晕么 没关系 来翻一下
就是说 select 聚合,聚合 from XX where xx 列都是聚合列 可以不用 Group by
但是 select ID, 聚合 from XX where xx Group By 因为不都是聚合列,所以要有 Group by
下面那句 同理可证。
A.聚合函数
聚合函数独立使用时,聚合函数只是用于聚合整个结果集 就像图里的第三条语句那样。但是和Group by 一起使用时会很强大。
B.AVG 平均数
C.MAX/MIN 最大值/最小值
当求最大值和最小值时,为了分辨 列,可以使用AS关键字。虽然AS关键列是可选的,但是一为了程序可读性,二为了编写代码符合ANSI/ISO标准。
D.COUNT(表达式 / * )
计算查询中返回的行数
分为2种情况 第一种count(*)时
第二种count(表达式)时
写这个时候碰到一点问题,关于主键约束,唯一约束的定义用法,回来专门写一篇好好研究下。
好,可以看见我写了两个不同的表达式,既然每一行都有列,那为什么出来的结果不一样?
这里就是要注意的地方了。
注意:除了COUNT(*)函数外,所有的聚合函数都忽略NULL值。
COUNT函数和GROUP BY函数一起使用时
E.使用HAVING 子句给分组设置条件
如果要将查询条件放到分组后,可以用HAVing
注意:HAVING子句仅用于带有GROUP BY子句的查询语句。where子句应用于某一行,而having子句应用于分组的聚合值。
F.使用for xml语句输出XML
这里以后会放一个专门介绍的链接,在这不做过多介绍。
G.通过option子句利用提示
这里以后会放一个专门介绍的链接,在这不做过多介绍。
H.distinct和all谓词
这两个与重复数据的处理有关。
上图 秒懂~
这样就可以筛选出 不重复的数据,在实际操作中这样会让返回的数量 大大的减小,而且下面的语句也比上面的语句执行速度要快。这里以后会有个链接来讨论为什么会更快。
在聚合函数也可以使用distinct,语法:Select COUNT(distinct ID)from 表名。
ALL的含义刚好和distinct相反,所以他表示的就是除了distinct之外的情况。现在就需要了解就好, 以后会放一个专门介绍的链接,在这不做过多介绍。
2.使用insert语句添加数据
into 关键字可加可不加,加了就是为了增强语句可读性。随意~
注意:在插值时有三种情况下,列不能设置为null值
1.列定义为默认值。
2.列定义为接受某种形式的系统生成值。比如说identity值
3.插入数据时已经提供了该列的值。
(存储过程sp_help功能给出任意数据库对象、用户自定义数据类型或sql server数据类型的信息。如图:查看course表属性)
insert into ...select语句
如果要插入的数据块儿是从以下获得:
- 数据库中的另一个表
- 同一服务器上一个完全不同的数据库
- 来自另一sql server的异类查询或其他数据
- 同一表
insert into 需要插数据的表 Select 列名 from 输出数据的表 where ID between AND ;
3.用update语句更改数据
update 表名 set 列名 =‘更新的值’ where 列名 =‘老的值’或者是 需要更改的那列的随意列名和随意列名的值
注意:有一些列是不能更新或者不建议更新的,比如timestamp 还有主键最好不要更新。
3.DELETE语句
注意:sql server 是不允许删除作为外键约束被引用的行。如果一行使用了外键引用另一行(无论是否在同一个表),都要先删除被引用行后才能删除引用行。
本章总结完毕 光看可不行 一定要动手敲一敲~~~~由于很多后面都会再详细介绍 所以以后介绍到了会再来这边添加相应链接~ 如此带来不便敬请谅解~~~~~~~
SQL Server ---T-SQl基本语句的更多相关文章
- PowerDesigner反向数据库时遇到[Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句。SQLSTATE = 37错误解决方法
逆向工程中,有时会出现如下错误 ... [Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句 SQLSTATE = 37000 解决方案: 1. ...
- SQL Server Profiler监控执行语句
SQL Server Profiler监控执行语句,这个功能主要用在实时的监控对数据库执行了什么操作,从而及时有效的跟踪系统的运行. 常规配置选项,名称.模板.保存到文件(可以复用). 事件选择,可以 ...
- SQL Server FOR XML PATH 语句的应用---列转行
经常在论坛看到高手使用了 for xml path,由于是搜索一下,记录了详细的使用方法.在SQL Server中利用 FOR XML PATH 语句能够把查询的数据生成XML数据,下面是它的一些应用 ...
- SQL Server中的流控制语句
begin···end 该语句定义sql代码块,通常在if和while语句中使用 declare @num int ; ; begin ; print 'hello word' end if···el ...
- SQL Server参数化SQL语句中的like和in查询的语法(C#)
sql语句进行 like和in 参数化,按照正常的方式是无法实现的 我们一般的思维是: Like参数化查询:string sqlstmt = "select * from users whe ...
- Linux下用freetds执行SQL Server的sql语句和存储过程
Linux下用freetds执行SQL Server的sql语句和存储过程 http://www.linuxidc.com/Linux/2012-06/61617.htm freetds相关 http ...
- sql server的sql 语句中的列名包含[]时候,把]替换成]]就可以
sql server的sql 语句中的列名包含[]时候,把]替换成]]就可以eg: create table p.e_LOG_WebServer ( [BSCFlg] int, ), ) ); sel ...
- SQL Server集成服务最佳实践:语句优化
SQL Server集成服务(SQL Server Integration Services,SSIS)在其前辈DTS(Data Transformation Services,数据转换服务) ...
- SQL Server查看Sql语句执行的耗时和IO消耗
原文:SQL Server查看Sql语句执行的耗时和IO消耗 在做系统过程中,经常需要针对某些场景进行性能优化,那么如何判定性能优化的效果呢?肯定需要知道优化之前Sql语句的耗时和优化之后Sql语句的 ...
- 【SQL Server DBA】维护语句:删除并创建外键约束、获取建表语句
原文:[SQL Server DBA]维护语句:删除并创建外键约束.获取建表语句 1.删除外键约束,建立外键约束 先建立3个表: /* drop table tb drop table tb_b dr ...
随机推荐
- Eclipse 下的 Maven的安装及配置
http://jingyan.baidu.com/article/295430f136e8e00c7e0050b9.html
- PHPCMS V9里加入JS时生成首页出错
有次在首页中加入JS,确认JS没有问题,但是在后台生成首页的时候一直出错. 查了半天才发现原来是JS里的“{}”问题,V9里调用内容也是用的大括号,冲突了. 解决方法是在“{”前面和后面分别加一个空格 ...
- 推荐几个Dynamic Crm的大神博客
ghostbear的博客:http://blog.csdn.net/ghostbear/article/category/1072859 ghostbear大神的博客是新手学习Dynamics Crm ...
- 可选参数、命名参数、.NET的特殊类型、特性
1.可选参数和命名参数 1.1可选参数 语法: [修饰符] 返回类型 方法名(必选参数n,可选参数n) 注意: 1.必选参 ...
- iOS获取WIFI的IP、子网掩码,以及域名转IP
获取WIFI需要的头文件: #import "GetCurrentIP.h" #import <ifaddrs.h> #import <arpa/inet.h&g ...
- GC机制总结
一.为什么需要GC 应用程序对资源操作,通常简单分为以下几个步骤: 1.为对应的资源分配内存 2.初始化内存 3.使用资源 4.清理资源 5.释放内存 应用程序对资源(内存使用)管理的方式,常见的一般 ...
- [ABP框架]动态web Api的拦截用法。
先进行配置 首先这种需求,一般发生在APP端,我们给APP,不会给所有项目系统的接口给他们用.我们系统有200个接口,但是APP的需求只会用20个.那么这个需求也就应运而生了. 以上为API文件夹中为 ...
- 【Android Developers Training】 80. 管理网络使用
注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...
- eclipse在多modules项目结构下避免模块间依赖引用的场景
这个在单一classLoader时,不会有问题.如果多classloader下会有问题. 假设工程有两个模块,module2 依赖module1 当我们执行mvc eclipse:eclipse后,然 ...
- 遇到ANDROID “call to opengl es api with no current context”错误
延迟线程执行 Timer timer=new Timer();//实例化Timer类 timer.schedule(new TimerTask(){ public void run(){ buyed( ...