SQL Server 2008数据查询之单表查询(1)

SQL Server 2008数据查询之单表查询(1),第1张

单表查询是指仅涉及一个表的查询,共有共包括5种基本 *** 作,本文先说明第一种。

以下 *** 作全部基于SQL Server 2008

在进行查询 *** 作之前首先需要建立一张二维表。如下所示:

然后点击左上角的“新建查询”:

出现下图所示界面↓↓↓↓↓↓↓↓

命令输入完成后点击“执行”

——————————接下来进行相关 *** 作——————————

(1)查询指定列

例:查询上表的Sno,Sname.

SELECT Sno,Sname

FROM Demo1_student/*Demo1_student是表名*/

获得如下结果↓↓↓↓↓↓↓↓↓↓↓

(2)查询全部列

¤方法有两种,麻烦的是依次列出所有列名,简单的是直接使用“*”号

例:查询上表的Sno,Sname,Ssex,Sage,Sdept(全部列).

SELECT Sno,Sname,Ssex,Sage,Sdept

FROM Demo1_student

等价于

SELECT *

FROM Demo1_student

(3)查询经过计算的值

¤SELECT后可以跟表中的属性列(Sno,Sname等),还可以跟表达式(算术表达式,字符串常量,函数,列属性别名);

例:计算全体学生的出生年份。

SELECT Sname,2015-Sage/*经过计算的值*/

FROM Demo1_student

SELECT Sname,'Year of Birth:',2015-Sage,LOWER(Sdept)/*LOWER表示用小写*/

FROM Demo1_student

对于无列名的列,可以使用以下方法添加列名。

SELECT Sname NAME,'Year of Birth:' BIRTH,2015-Sage BIRTHDAY,LOWER(Sdept) DEPARTMENT  /*原名和别名之间用空格隔开*/

FROM Demo1_student

注意点

select 指定表.字段 from 表1,表2

四则运算包括加减乘除

select 字段1 四则运行符号 字段2 from 表名称

语法:select 函数(字段1) from 表名称

统计函数

binary

区分大小写

语法:select 段落 from 表明 where binary 字段....................................

分组

语法

select....from 表名

where .......

group by 字段名称 #如果这里有多个字段,A,B,用,连接表示具有相同字段A以及相同字段B进行分组

having 判断内容

注意 :

排序

语法:默认为升序

ord by 字段名称

固定升序或者降序

多个条件排序主次关系

ord by 主字段,次字段

限制显示记录

对于单页表 *** 作

limit start count

对于多页 *** 作

分页原理:先查询总数据条数 设为a

确定每页数量b

总页数为c = a / b 如果除不尽则需要加1 例如 10 / 3 正确页数为4

查询语句的起始位置为s = 当前页数d 减去1 乘以每页数量

即 s = (d - 1) * b

limit s b

语法 :where 字段名称 regexp '正则表达式'

注意:正则表达式不包括特殊字符如\w

语法:select *from 表1,表2

他会把多个表每行与另外个表统统匹配上,其中会有一些脏数据,我们可以用里面值的关系进行连接

其本质就是笛卡尔积查询

区别是把,变成 join

且不能用where,要先用on根据里面值的关系拼接好了再用 where

左表中记录的无论是否有匹配关系都全部显示,右表中仅显示匹配成功的记录

语法:select *from 表1 left join,表2

右表中记录的无论是否有匹配关系都全部显示,左表中仅显示匹配成功的记录

语法:select *from 表1 right join 表2

无论是否匹配成功,两边表中的记录都要全部显示

select *from 表1 full join 表2

注意:mysql 不支持

我们要引入union

union 只能用于字段数量相同的两个表 会自动去除重复的记录

union all 则保留所有记录

select from dept left join emp on dept.id=emp.dept_id

union

select from dept right join emp on dept.id=emp.dept_id

可以完成全外连接

在三表以及三表以上查询的时候,表1 join 表2 join 表三,其意思是表1与表2连接后的表再与表3进行连接

如果三表连接时候没有用join而是用 , 进行连接表示同时查询3个表

将查找后的内容作为查找的值或者查找的对象,

如果要作为一个表当作查找对象,要对于查找后的表进行重命名语法如下

select .... from (select ....from .......) as 新名字

xists 后跟子查询 子查询有结果是为True 没有结果时为False

为true时外层执行 为false外层不执行


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9618780.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存