文章目录
T-SQL的组成
- 数据定义语言(DDL,Data Definition Language)
- 数据操纵语言(DML,Data Manipulation Language)
- 数据控制语言(DCL,Data Control Language)
T-SQL基础运算符
比较运算符
核心作用主要用作用快速的条件查询
运算符 | 作用 |
---|---|
= | 判断相等 |
> | 大于 |
< | 小于 |
>= | 大于等于 |
<= | 小于等于 |
!= <> | 不等于 |
! | 非 |
逻辑运算符
运算符 | 作用 |
---|---|
ALL | 如果一个比较集中全部都是TRUE,则值为TRUE |
ANY | 如果一个比较集中任何一个为TRUE,则值为TRUE |
AND | 如果两个布尔表达式均为TRUE,则值为TRUE |
OR | 如果任何一个布尔表达式是TRUE,则值为TRUE |
BETWEEN | 如果操作数是在某个范围内(可取上下限),则值为TRUE |
LIKE | (模糊查询)如果操作数匹配某个模式的话,则值为TRUE |
IN | 如果操作数与一个表达式列表中的某个相等的话,则值为TRUE |
NOT | 对任何其他布尔运算符的值取反 |
SOME | 如果一个比较集中的某些为TRUE的话,则值为TRUE |
EXISTS | 如果子查询包含任何行,则值为TRUE |
SQL 通配符
在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符。可以理解为和C#中学习过的正则的元字符类似
通配符 | 描述 |
---|---|
% | 替代一个或多个字符 |
_ | 仅替代一个字符 |
[a,b,d],[a-d] | 字符列中的任何单一字符 |
[ ^a,b,c] 或者 [!b] | 不在字符列中的任何单一字符 |
SELECT查询语句
对查询结果的字段重新命名(AS)
SELECT 字段1名 AS '重命名1',字段2名 AS '重命名2',.... FROM 表名
SELECT StuID AS '学号',SubID AS '科目ID',Score AS '分数' FROM Score
多表连接查询-内联接(JOIN ON)
内联接查询可以为将数据库中多张表通过其内部关系进行查询,得到一张新的有用的"表",这个新表是内联接查询的结果并不存在
注意:多张表要保证表与表之间的字段有某种特殊意义的联系
SELECT Sname AS '姓名',SubName AS '科目',Score AS '分数' FROM Score JOIN Student ON Score.StuID=Student.SID JOIN Subject ON Score.SubID=Subject.SubID
按排列顺序查询(ORDER BY)
排序查询肯定是先排序再查询
将查询结果按照某个指定字段以升序(例如:数字按照从小到大)、降序这两种方式进行重新排列显示。
SELECT <字段> FROM 表名 [WHERE条件] ORDER BY <指定列名> ASC/ DESC,<指定列名> ASC/ DESC
升序:使用关键字ASC,如果在查询语句中ORDER BY排序之后未声明任何关键字则默认是升序ASC
降序:使用关键字DESC
SELECT Sname AS '姓名',SubName AS '科目',Score AS '分数' FROM Score JOIN Student ON Score.StuID=Student.SID JOIN Subject ON Score.SubID=Subject.SubID WHERE SubName='C#'ORDER BY Score DESC
注意:排序查询语句中的升序或降序不是仅有一个字段
TOP查询指定行
使用TOP可以从结果中查询出指定的前多少行
SELECT TOP(数量) <列名> FROM 表名
从表中查询前多少行,由括号中的数量决定
SELECT TOP(3) Sname AS '姓名',SubName AS '科目',Score AS '分数' FROM Score JOIN Student ON Score.StuID=Student.SID JOIN Subject ON Score.SubID=Subject.SubID WHERE SubName='C#'