T-SQL查询语句(一):单表查询
SQL基础复习03--数据查询SQL语句(单表查询)

SQL基础复习03--数据查询SQL语句(单表查询)参考教材《数据库系统:原理、设计与编程(MOOC版)》,陆鑫张凤荔陈安龙终于到查询这⼀块了。
3.4 数据查询SQL语句3.4.1 查询语句基本结构SELECT [ALL/DISTINCT] <⽬标列>[,<⽬标列>...][INTO <新表>]FROM <表名>[,<表名>...][WHERE <条件表达式>][GROUP BY <列名> [HAVING <条件表达式>]ORDER BY <列名> [ASC/DESC]];SELECT语句由多种字句组成:1. SELECT⼦句,⽤来指明从数据库表中需要查询的⽬标列。
ALL是默认操作,获取所有满⾜条件的数据⾏;DISTINCT⽤来去掉结果集中的重复数据⾏;<⽬标列>为被查询表的指定列名,可以有多个。
2. INTO⼦句,⽤来将被查询的结果集数据插⼊新表。
3. FROM⼦句,⽤来指定被查询的数据来⾃哪个表或哪些表。
多表⽤逗号分隔。
4. WHERE⼦句,⽤来给出查询的检索条件,多个条件之间可以⽤AND、OR进⾏连接。
5. GROUP BY⼦句,⽤来对查询结果进⾏分组,并进⾏分组统计等处理,在分组中,还可以使⽤HAVING关键词定义分组条件。
6. ORDER BY⼦句,⽤来对查询结果集进⾏排序。
ASC当然是升序,DESC是降序。
默认为ASC。
从SELECT语句的操作结果看,<⽬标列>实现对关系表的投影操作,WHERE <条件表达式>实现对关系表的元组选择操作。
当前Student表的全部数据:下⾯将会对该表进⾏⼀系列查询操作3.4.2 从单表读取指定列SELECT <⽬标列>[,<⽬标列>...]FROM <表名>;例3-191. 从Student表中读取学⽣的学号、姓名、专业三列数据:SELECT StudentID, StudentName, MajorFROM Student;GO2. 从Student表中查询所有列数据:SELECT *FROM Student;GO3. 只查Major数据:SELECT MajorFROM Student;GO倘若只想查出不同的专业名称,可以消除重复⾏,⽤DISTINCT:SELECT DISTINCT MajorFROM Student;GO3.4.3 从单表读取指定⾏SELECT *FROM <表名>WHERE <条件表达式>;例3-20从Student表中读取专业为“软件⼯程”,性别为“男”的学⽣数据:SELECT *FROM StudentWHERE Major='软件⼯程' AND StudentGender='男';GO3.4.4 从单表读取指定⾏和列SELECT <⽬标列> [,<⽬标列>...]FROM <表名>WHERE <条件表达式>;例3-21从Student表中读取专业为“软件⼯程”,性别为“男”的学⽣的学号、姓名、性别、专业四列的数据:SELECT StudentID, StudentName, StudentGender, MajorFROM StudentWHERE Major='软件⼯程' AND StudentGender='男';GO3.4.5 WHERE⼦句条件在WHERE⼦句条件中,可以⽤BETWEEN...AND关键词来限定列值范围,还可以⽤关键字LIKE与通配符来限定查询范围,NOT LIKE⽤于给出不在范围的条件。
SQL查询语句

WHERE ytd_sales>10000
) AS t
WHERE a.au_id=ta.au_id
AND ta.title_id=t.title_id
此例中,将SELECT返回的结果集合给予一别名t,然后再符:
<#为虚拟表,可一跨数据库创建!>
8.更改列表名显示的查询
select 字段名1 as ''A'',字段名2 as ''B'' from 表名
select "A"=字段名1,"B"=字段名2 from 表名
select 字段名1"A",字段名2"B" from 表名
Sum:计算总和
Stdev:计算统计标准偏差
Var:统计方差
13.汇总查询<Compute子句>
(1).compute:
Select 字段名列表 From 表名 [where 条件表达式] Compute 汇总表达式
Select cno,sno,degree From score Compute avg(degree)
①执行Where子句,从表中选取行;
②由Group By分组;
③执行Having子句选取满足的分组条件。
---------------------------------------{那我们如何对函数产生的值来设定条件呢?
举例来说,我们可能只需要知道哪些店的营业额有超过 $1,500。在这个情况下,
SELECT "栏位1", SUM("栏位2")
如何使用SQLSELECT语句从单个表中查询数据

如何使⽤SQLSELECT语句从单个表中查询数据在本教程中,您将学习如何使⽤SQL SELECT语句从单个表中查询数据。
1. SQL SELECT语句简介要查询表中的数据,请使⽤SQL SELECT语句。
SELECT语句包含⽤于选择列,,,以及执⾏简单计算的语法。
SELECT语句是SQL中最复杂的命令之⼀,因此,在本教程中,我们将仅介绍基础知识。
下⾯说明了从单个表中检索数据的SELECT语句的基本语法。
SELECTcolumn1, column2, column3, ...FROMtable_name;在此语法中,指定查询SELECT⼦句中的数据是使⽤逗号分隔列的列表,并在FROM⼦句中指定表名。
在评估SELECT语句时,数据库系统⾸先计算FROM⼦句,然后再计算SELECT⼦句。
如果要查询表的所有列中的数据,可以使⽤星号(*)运算符⽽不是列列表,如下所⽰。
SELECT*FROMtable_name;请注意,SQL不区分⼤⼩写。
所以数据库系统处理SELECT和select都是相同操作。
但是,为了使SQL语句更具可读性,我们将使⽤SQL关键字的⼤写字母(如SELECT和FROM)和⼩写字母(如表名和列名)等标识符。
除了SELECT和FROM⼦句之外,SELECT语句还可以包含许多其他⼦句,例如 -- ⽤于根据指定条件过滤数据ORDER BY - ⽤于对结果集进⾏排序LIMIT - ⽤于限制返回的⾏JOIN - ⽤于查询来⾃多个相关表的数据GROUP BY - ⽤于根据⼀列或多列对数据进⾏分组HAVING - ⽤于过滤分组您将在后续教程中了解这些⼦句的使⽤。
2. SQL SELECT语句⽰例我们将使⽤中的employees表进⾏演⽰。
3. SQL SELECT - 查询所有列⽰例要查询表中的所有列,请使⽤星号(*)⽽不是指定每列。
例如,以下语句从employees表中检索所有数据:SELECT*FROMemployees;执⾏上⾯⽰例代码,得到以下结果 -+-------------+------------+-----------+---------------------------+----------------+------------+--------+--------+------------+---------------+| employee_id | first_name | last_name | email | phone_number | hire_date | job_id | salary | manager_id | department_id |+-------------+------------+-----------+---------------------------+----------------+------------+--------+--------+------------+---------------+| 100 | Steven | Lee | steven.lee@ | 0532-******** | 1987-06-17 | 4 | 24000 | NULL | 9 || 101 | Neena | Wong | neena.wong@ | 0551-******* | 1989-09-21 | 5 | 17000 | 100 | 9 || 102 | Lex | Liang | lex.liang@ | 0571-******** | 1993-01-13 | 5 | 17000 | 100 | 9 || 103 | Alexander | Lee | alexander.lee@ | 020-******** | 1990-01-03 | 9 | 9000 | 102 | 6 |... ...| 201 | Michael | Zhou | michael.zhou@ | 010-******** | 1996-02-17 | 10 | 13000 | 100 | 2 || 202 | Pat | Zhou | pat.zhou@ | 0755-******** | 1997-08-17 | 11 | 6000 | 201 | 2 || 203 | Susan | Zhou | susan.zhou@ | 0755-******** | 1994-06-07 | 8 | 6500 | 101 | 4 || 204 | Hermann | Wu | hermann.wu@ | 0513-******** | 1994-06-07 | 12 | 10000 | 101 | 7 || 205 | Shelley | Wu | shelley.wu@ | 0898-******** | 1994-06-07 | 2 | 12000 | 101 | 11 || 206 | William | Wu | william.wu@ | 022-******** | 1994-06-07 | 1 | 8300 | 205 | 11 |+-------------+------------+-----------+---------------------------+----------------+------------+--------+--------+------------+---------------+40 rows in set使⽤星号(*)运算符只能⽅便地通过SQL客户端应⽤程序以交互⽅式查询数据。
tsqlquery用法

tsqlquery用法TSQQuery是T-SQL(Transact-SQL)的一个方法,用于在SQL Server数据库中执行查询语句。
它可以用于执行查询、插入、更新、删除等操作,并且能够获取返回的结果集。
TSQQuery的具体用法如下:1.创建TSQQuery对象:可以使用以下语句创建一个TSQQuery对象:```sqlDECLARE @query AS NVARCHAR(MAX);SET @query = N'SELECT * FROM TableName';```2.执行查询:使用以下语句执行查询并将结果保存到一个表变量中:```sqlDECLARE @results TABLE (Column1 INT, Column2 VARCHAR(50));INSERT INTO @resultsEXEC sp_executesql @query;```3.获取结果集:可以使用以下语句从结果集中检索数据:```sqlSELECT Column1, Column2 FROM @results;```4.参数化查询:TSQQuery还支持参数化查询,可以使用以下语句设置参数:```sqlDECLARE @param1 INT = 1;DECLARE @param2 VARCHAR(50) = 'Value';SET @query = N'SELECT * FROM TableName WHERE Column1 =@param1 AND Column2 = @param2';```然后,使用sp_executesql函数执行参数化查询。
5.错误处理:在执行TSQQuery时,可以通过使用TRY-CATCH语句块来捕获并处理可能的错误。
除此之外,TSQQuery还支持其他更高级的功能,如动态构建查询语句、执行动态查询和存储过程、处理返回的结果集等,这些功能能够极大地提高查询的灵活性和效率。
数据库T-SQL语言操作(T-SQL语句、数据库、表、视图、索引)

数据库T-SQL语⾔操作(T-SQL语句、数据库、表、视图、索引)T-SQL语⾔按⽤途分四部分1. 数据定义语⾔(CREATE,DROP,ALTER)2. 数据操作语⾔(INSERT,DELETE,UPDATE)3. 数据查询语⾔(SELECT)4. 数据控制语⾔(GRANT,REVOKE,DENY)数据类型1. 系统数据类型2. ⽤户⾃定义数据类型(建⽴⽅式:a.图形化⽅式 b.命令⽅式)1use TEST2EXEC sp_addtype sno,'varchar(10)','nonull'3EXEC sp_droptype sno变量命名规则:字母、下划线、@或#开头,但不能全为下划线、@或#不能为“关键字”,不能嵌⼊空格及其他特殊字符,如需使⽤则需要双引号或⽅括号括起1.局部变量:由⽤户声明,必须以@开头,只在定义该变量的过程中有效,局部变量必须先声明后使⽤注意:第⼀次声明变量时,其值设置为NULL。
局部变量不能使⽤“变量=变量值”的格式进⾏初始化,必须使⽤SELECT或SET语句来设置其初始值。
如果声明字符型的局部变量,⼀定要在变量类型中指明其最⼤长度,否则系统默认其长度为1。
若要声明多个局部变量,请在定义的第⼀个局部变量后使⽤⼀个逗号,然后指定下⼀个局部变量名称和数据类型。
1USE student2DECLARE@var1char(10),@var2int3SET@var1='number'4select@var2=cgrade5from sc6where sno='201810010'78print@var1+"s"2.全局变量:由系统定义,供SQL server系统内部使⽤的变量,任何程序任何时间都可以调⽤。
通常以“@@”开头。
T-SQL语句1.注释语句(1) --(2) /*……*/2.批处理--GO3.控制流程语句(1) begin...end语句(相当于C语⾔中的{} )(2) if...else语句(可嵌套)(3)case语句(多条件选择语句)(4)print语句(屏幕输出语句)(5)while语句(有条件的循环语句)(6)goto语句(⽆条件跳转语句)(7)break语句(8)continue语句4.常⽤函数(系统函数、⽤户⾃定义函数)⼀些系统函数:(1)字符串函数(2)数学函数(3)⽇期和时间函数(4)聚合函数注意:⽤户⾃定义函数:1.分类:标量值函数:返回单个值内联表值函数:返回可更新的表多语句表值函数:返回不可更新的表2.标量值函数命令⽅式创建1CREATE FUNCTION f2(@a real,@b real) 2RETURNS real3AS4BEGIN5IF@a>=@b6RETURN@a7RETURN@b8END910PRINT'最⼤值为'11PRINT dbo.f2(77,56)1CREATE FUNCTION f3(@n real)2RETURNS real3AS4BEGIN5DECLARE@i real,@sum real6SET@i=07SET@sum=08WHILE@i<@n9BEGIN10SET@i=@i+111SET@sum=@sum+@i12END13RETURN@sum14END1516PRINT dbo.f3(10)3.⾃定义函数的调⽤(1)标量值函数可以使⽤select、print、exec调⽤(2)表值函数只能⽤select调⽤4.删除⽅式drop function 函数名数据库数据库概述1.数据库常⽤对象:表、数据类型、视图、索引、存储过程、触发器系统数据库:master、model、tempdb、msdb2.数据库存储结构(数据库⽂件、数据库⽂件组):数据库⽂件:存放数据库数据和数据库对象的⽂件。
t-sql查询语句

t-sql查询语句我可以提供以下的T-SQL查询语句:1. 查询表中的所有数据:SELECT * FROM table_name;2. 查询表中指定字段的数据:SELECT column_name FROM table_name;3. 对表中的数据进行排序:SELECT column_name FROM table_name ORDER BY column_name ASC or DESC;4. 查询表中符合条件的数据:SELECT column_name FROM table_name WHERE condition;5. 对表中数据进行分组:SELECT column_name, aggregate_function(column_name) FROM table_name GROUP BY column_name;6. 在多个表之间进行连接查询:SELECT column_name FROM table1 INNER JOIN table2 ONtable1.column_name=table2.column_name;7. 对查询结果进行聚合计算:SELECT aggregate_function(column_name) FROM table_name;8. 使用子查询查询表中符合条件的子集:SELECT column_name FROM (SELECT column_name FROM table_name WHERE condition) AS sub_query;9. 使用LIKE运算符查询类似匹配的数据:SELECT column_name FROM table_name WHERE column_name LIKE 'pattern';10. 查询表中前几条数据:SELECT TOP n column_name FROM table_name;以上是一些常见的T-SQL查询语句,可以根据具体情况进行选择和使用。
SQL 单表查询

实验三单表查询一、实验目的掌握简单SQL 查询语句的应用,包括like、top、order by、compute 、聚集函数的应用。
二、实验内容1、基本查询(1)查询学生表中全体学生的全部信息。
select*from Student_20103266;(2)检索全体学生的学号、姓名。
select Sno,Snamefrom Student_20103266;2、查询时改变列标题的显示检索全体学生的学号、姓名、家庭地址信息,并分别加上“学生”、“学号”、“家庭地址”的别名信息。
select Sno'学号',Sname'姓名',Home_addr'家庭地址'from Student_20103266;3、条件查询(1)查询成绩大于80分的学生的学号及课程号、成绩。
SELECT Sno,Cno,Gradefrom SC_20103266where Grade>80;(2)查询成绩介于75~80分的学生的学号及课程号、成绩。
SELECT Sno,Cno,Gradefrom SC_20103266where Grade between 75 and 80;(3)查询选修了课程号为“002”,且成绩大于80的学生的学号。
SELECT Snofrom SC_20103266where Cno='002'AND Grade>80;(4)某些学生选修某门课程后没有参加考试,所以有选课记录,但没有考试成绩,下面我们来查一下缺少成绩的学生的学号和相应的课程号。
SELECT Sno,Cnofrom SC_20103266where Grade IS NULL;4、基于IN子句的数据查询从课程表中查询出“高数”、“C语言程序设计”的所有信息。
SELECT*FROM Course_20103266where Cname IN('高数','C语言程序设计');5、基于BETWEEN。
T-SQL语句集合及示例

《数据库应用与开发教程》书内T-SQL语句集合及示例1.创建数据库CREATE DATABASE数据库名ON PRIMARY( NAME=主数据库文件名,FILENAME=主数据库文件地址名,SIZE=主数据库文件初始大小,MAXSIZE=主数据库文件最大大小,FILEGROWTH=主数据库文件增长大小/速度)LOG ON( NAME=数据库日志文件名,FILENAME=数据库日志文件地址名,SIZE=数据库日志文件初始大小,MAXSIZE=数据库日志文件最大大小,FILEGROWTH=数据库日志文件增长大小/速度 )GO代码示例:CREATE DATABASE EXAMON PRIMARY(NAME=EMAM_DAT,FILENAME='I:\EXAM\EXAMDAT.mdf',SIZE=3mb,MAXSIZE=500mb,FILEGROWTH=1mb)LOG ON(NAME=EXAM_LOG,FILENAME='I:\EXAM\EXAMLOG.ldf',SIZE=1mb,MAXSIZE=unlimited,FILEGROWTH=10%)GO2.删除数据库基础语句:DROP DATABASE 数据库名代码示例:DROP DATABASE EXAM3.创建表基础语句:USE 数据库名 GOCREATE TABLE 表名( 列名1 数据类型 修饰条件 是否为空, 列名2 数据类型 修饰条件 是否为空, 列名3 数据类型 修饰条件 是否为空, ………… )代码示例:USE EXAM GOCREATE TABLE ADMIN( ADMINID INT PRIMARY KEY , LOGINPWD VARCHAR (50) NOT NULL, LOGINPTPE VARCHAR (10) NOT NULL )4.设置主键基础语句:ALTER TABLE 表名ADD CONSTRAINT 主键名 PRIMARY KEY (想要设置为主键的列的列名)代码示例:ALTER TABLE 表名ADD CONSTRAINT pkey_Admin PRIMARY KEY (AMDINID)5.插入数据(1)添加一行数据 基础语句:INSERT INTO 表名(列名1,列明2,列名3……) VALUES (值一,值二,值3……)代码示例:INSERT INTO ADMIN (ADMINID ,LOGINPWD ) VALUES (1,'iamthepassword')(2)将全部信息添加到另外一个表INSERT INTO 目标表名(列名1,列明2……) SELECT 列名1,列明2…… FROM 原表名6.创建备份表基础语句:SELECT*INTO备份表名FROM原始表名WHERE 0=1示例代码:SELECT*INTO ADMINBAKFROM ADMIN WHERE 0=17.更新数据基础语句:UPDATE表名SET列名=更新的值WHERE条件示例代码:UPDATE ADMIN SET LOGINPWD='password'WHERE ADMINID=18.删除数据基础语句:DELETE FROM表名WHERE条件示例代码:DELETE FROM ADMIN WHERE ADMINID=39.删除表基础语句:DROP TABLE表名示例语句:DROP TABLE ADMIN10查询语句基础语句:SELECT 列名1,列名2 FROM表名WHERE条件ORDER BY要排序的列名(ASC/DESC)示例语句:SELECT ADMINID,LOGINPWD FROM ADMIN WHERE LOGINPWD='password'ORDER BY ADMINID DESC在使用SELECT语句中,可使用*号,代表选择表中的全部列,例:SELECT * FROM ADMIN在SELECT后面加上 DISTINCT 可消除重复行,例如:SELECT DISTINCT LOGINPWD FROM ADMIN在SELECT后面加上TOP 数字,可选择前多少行的数据,例:SELECT TOP 20 * FROM ADMIN要自定义列标题名,可有3种方法:(1)列别名=列名密码=LOGINPWD(2)列名 as 列别名 LOGINPWD=密码(3)列名列别名 LOGINPWD 密码模糊查询,可用 LIKE 例如:SELEC T * FROM ADMIN WHERE LOGINPWD LIKE‘PASS%’更多函数的使用方法,请见课本P86.多表查询,可用“表名.列明”的方式,例如:SELECT Student.studentNO,Score.score1 FROM Student,Score或者采用INNER JOIN关键字关联等内连接和外连接,请见课本P97.11.创建视图基础语句:CREATE VIEW视图名ASFROM表名示例代码:CREATE VIEW V_TESTASSELECT*FROM STUDENT12.创建外键约束基础语句:ALTER TABLE表名ADD CONSTRAINT外键名FOREIGN KEY(从表列名)REFERENCES主表名(主表列名)示例代码:ALTER TABLE scoreADD CONSTRAINT FK_SCORE_STUDENTFOREIGN KEY(STUDENTNO)REFERENCES STUDENT(STUDENTNO)13.在sql中使用变量,详情请见课本P14314.创建索引基础语句:CREATE INDEX索引名ON表名(需要索引的列名)代码示例:CREATE INDEX IDX_ABC ON SCORE(STUDENTNO)15.创建存储过程基础语句:CREATE PROC存储过程名(定义变量)AsSql语句代码示例:详见课本P166,包括3种,不含参数,含参数,含输出参数的存储过程示例。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
T-SQL查询语句(一):单表查询Posted on 2008-10-07 19:54 罗一恒阅读(531) 评论(0)编辑收藏############################################查询语句--SELECT############################################查询select: 1。
单表查询2。
多表查询3。
嵌套查询分类1)单表查询2)多表查询A.连接查询B.子查询①一般子查询②相关子查询***************************************SQL查询语句《一》:单表查询1.查询全部记录:select * from table_name2.查询指定字段记录:select 字段列表from table_name3.过滤相同记录:select Distinct 字段列表from table_name<SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认为ALL。
使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。
使用distinct会减慢查询速度,数量大的查询更明显>4.带表达式的查询:select s_name,year(s_birthday) as year from table_name5.指定查询结果的查询select top n * from table_name <n值在0--429494967295间>select top n PERCENT * from table_name <n值在0--100间>(返回前/后n行,前/后n%的数据)6.指定查询路径的查询:select * from database_name.dbo.table_name形式:数据库名.数据库表拥有者.表名(可以跨越数据库和使用者进行查询)7.存储查询结果到另一个表select 字段列表into 新表名from 表名select sno,cno,degree into scorekkk from scoreselect sno,cno,degree into tempdb.#scorekkklll from score<#为虚拟表,可一跨数据库创建!>8.更改列表名显示的查询select 字段名1 as ''A'',字段名2 as ''B'' from 表名select "A"=字段名1,"B"=字段名2 from 表名select 字段名1"A",字段名2"B" from 表名9.条件查询<Where子句>select 字段名列表from 表名where 条件表达式条件表达式运算符:比较运算符(=,<,<=,>,>=,!<,!>,!=,<>)逻辑运算符(or,and,not)范围说明(between and,not between and)可选值列表(in,not in)模式匹配(like,not like)是否为空值(is null,is not null)<注:字符型字段必须用单引号,数字型字段则不用;like和not like适合字符型字段查询。
> like 子句与通配符一起使用,Like "字符串",字符串含通配符或空格%,一个或多个任意字符;_,一个任意字符;[],方括号中的任意一个字符;[^],任意一个在括号中没有的字符。
11.排序查询<Order by子句>select 字段名列表from 表名[where 条件表达式] order by 字段名表达式desc/ascselect * from Sclass order by cno asc,degree desc<使用ORDER BY子句对查询返回的结果按一列或多列排序。
ORDER BY子句的语法格式为:ORDER BY {column_name [ASC|DESC]} [,…n]其中ASC表示升序,为默认值,DESC为降序。
ORDER BY不能按ntext、text和image的数据类型进行排序。
>12.分组查询<Group by子句>select 字段名列表from 表名[where 条件表达式] group by 字段名select 字段名列表from 表名[where 条件表达式] group by 字段名Having <筛选表达式>select cno,avg(degree) as chengji from score group by cnoselect cno,avg(degree) as chengji from score group by cno Having avg(degree)>80 <字段名列表中包含聚合函数时,则计算每组的汇总值。
如果使用Group by子句,字段名列表中任一非聚合表达式内的所有列都必需包含在Group by列表中,或者Group by表达式必须与选择列表表达式完全匹配。
>筛选查询<Having子句><Having子句对Group by子句分组后的结果进行筛选,看其是否满足条件。
故此Having只能配合group by子句使用。
>当Where子句,Group by子句,Having子句同时使用时,其顺序如下:①执行Where子句,从表中选取行;②由Group By分组;③执行Having子句选取满足的分组条件。
聚合函数:使用聚合函数,实现数据统计。
AVG:计算平均数Count(*):统计查询输出的记录总数Count():统计指定列中选择的记录总数Max:最大值Min:最小值Sum:计算总和Stdev:计算统计标准偏差Var:统计方差13.汇总查询<Compute子句>(1).compute:Select 字段名列表From 表名[where 条件表达式] Compute 汇总表达式Select cno,sno,degree From score Compute avg(degree)<compute子句生成的汇总结果附加在结果集的后面,汇总表达式须用到聚合函数>(2).compute by:Select 字段名列表from 表名[where 条件表达式] order by 字段名compute 汇总表达式by 分类字段名Select sno,cno,degree From sclass Order by cno compute Avg(degree) by cnoSelect sno,cno,degree From score Order by cno Asc,degree Desccompute avg(degree) by cno<compute by子句根据by后的字段名进行分组,必须与order by子句一起使用,分类字段名必须与order by后的字段名一致。
>***************************************简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。
它们分别说明所查询列、查询的表或视图、以及搜索条件等。
完整的Select 语句用法:SELECT 字段列名[INTO 新表名]FROM 表| 视图名[WHERE 查询限定条件][GROUP BY 分组表达式][HAVING 分组条件][ORDER BY 次序表达式[ASC | DESC]](2)FROM子句FROM子句指定SELECT语句查询及与查询相关的表或视图。
在FROM子句中最多可指定256个表或视图,它们之间用逗号分隔。
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列所属的表或视图。
例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应使用下面语句格式加以限定:SELECT username,citytable.cityidFROM usertable,citytableWHERE usertable.cityid=citytable.cityid在FROM子句中可用以下两种格式为表或视图指定别名:表名as 别名表名别名例如上面语句可用表的别名格式表示为:SELECT username,b.cityidFROM usertable a,citytable bWHERE a.cityid=b.cityidSELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。
例如:SELECT a.au_fname+a.au_lnameFROM authors a,titleauthor ta(SELECT title_id,titleFROM titlesWHERE ytd_sales>10000) AS tWHERE a.au_id=ta.au_idAND ta.title_id=t.title_id此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。
WHERE子句可包括各种条件运算符:比较运算符(大小比较):>、>=、=、<、<=、<>、!>、!<范围运算符(表达式值是否在指定的范围):BETWEEN…AND…NOT BETWEEN…AND…列表运算符(判断表达式是否为列表中的指定项):IN (项1,项2……)NOT IN (项1,项2……)模式匹配符(判断值是否与指定的字符通配格式相符):LIKE、NOT LIKE空值判断符(判断表达式是否为空):IS NULL、NOT IS NULL逻辑运算符(用于多条件的逻辑连接):NOT、AND、OR1、范围运算符例:age BETWEEN 10 AND 30相当于age>=10 AND age<=302、列表运算符例:country IN (''Germany'',''China'')3、模式匹配符例:常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。
可用于char、varchar、text、ntext、datetime和smalldatetime等类型查询。