2022年SQL查询语句精华大全 .pdf
《2022年SQL查询语句精华大全 .pdf》由会员分享,可在线阅读,更多相关《2022年SQL查询语句精华大全 .pdf(10页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、一、简单查询简单的 Transact-SQL 查询只包括选择列表、FROM 子句和 WHERE 子句。它们分别说明所查询列、查询的表或视图、以及搜索条件等。例如,下面的语句查询testtable 表中姓名为“张三”的 nickname 字段和 email 字段。SELECT nickname,email FROM testtable WHERE name=张三 (一)选择列表选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变量和全局变量)等构成。1、选择所有列例如,下面语句显示testtable 表中所有列的数据:SELECT*FROM tes
2、ttable 2、选择部分列并指定它们的显示次序查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。例如:SELECT nickname,email FROM testtable 3、更改列标题在选择列表中,可重新指定列标题。定义格式为:列标题=列名列名列标题如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列标题:SELECT 昵称=nickname,电子邮件=email FROM testtable 4、删除重复行SELECT 语句中使用ALL 或 DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认为 ALL。使用 D
3、ISTINCT选项时,对于所有重复的数据行在SELECT 返回的结果集合中只保留一行。5、限制返回的行数使用 TOP n PERCENT 选项限制返回的数据行数,TOP n 说明返回 n 行,而 TOP n PERCENT时,说明n 是名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 10 页 -表示一百分数,指定返回的行数等于总行数的百分之几。例如:SELECT TOP 2*FROM testtable SELECT TOP 20 PERCENT*FROM testtable(二)FROM 子句FROM 子句指定SELECT 语句查询及与查询相关的表或视图。在FROM 子句中最多
4、可指定256 个表或视图,它们之间用逗号分隔。在 FROM 子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列所属的表或视图。例如在 usertable和 citytable 表中同时存在cityid 列,在查询两个表中的cityid时应使用下面语句格式加以限定:SELECT username,citytable.cityid FROM usertable,citytable WHERE usertable.cityid=citytable.cityid 在 FROM 子句中可用以下两种格式为表或视图指定别名:表名as 别名表名别名例如上面语句可用表的别名格式表示
5、为:SELECT username,b.cityid FROM usertable a,citytable b WHERE a.cityid=b.cityid SELECT 不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询数据。例如:SELECT a.au_fname+a.au_lname FROM authors a,titleauthor ta(SELECT title_id,title FROM titles WHERE ytd_sales10000)AS t WHERE a.au_id=ta.au_id AND ta.title_id=t.title_id 此例
6、中,将SELECT 返回的结果集合给予一别名t,然后再从中检索数据。(三)使用 WHERE 子句设置查询条件WHERE 子句设置查询条件,过滤掉不需要的数据行。例如下面语句查询年龄大于20 的数据:SELECT*FROM usertable 名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 10 页 -WHERE age20 WHERE 子句可包括各种条件运算符:比较运算符(大小比较):、=、=、=、!、!=10 AND age、=、=、!和。3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。例,
7、下面使用等值连接列出authors 和 publishers 表中位于同一城市的作者和出版社:SELECT*FROM authors AS a INNER JOIN publishers AS p ON a.city=p.city 又如使用自然连接,在选择列表中删除authors 和 publishers 表中重复列(city 和 state):SELECT a.*,p.pub_id,p.pub_name,p.country FROM authors AS a INNER JOIN publishers AS p ON a.city=p.city(二)外连接内连接时,返回查询结果集合中的仅是符
8、合查询条件(WHERE 搜索条件或HAVING 条件)和连接条件的行。而采用外连接时,它返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左外连接时)、右表(右外连接时)或两个边接表(全外连接)中的所有数据行。如下面使用左外连接将论坛内容和作者信息连接起来:SELECT a.*,b.*FROM luntan LEFT JOIN usertable as b ON a.username=b.username 下面使用全外连接将city 表中的所有作者以及user表中的所有作者,以及他们所在的城市:SELECT a.*,b.*FROM city as a FULL OUTER JOI
9、N user as b ON a.username=b.username(三)交叉连接交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。例,titles 表中有 6 类图书,而publishers 表中有 8 家出版社,则下列交叉连接检索到的记录数将等于 6*8=48 行。SELECT type,pub_name FROM titles CROSS JOIN publishers ORDER BY typeSQL 核心语句(非常实用的几个技巧)插入数据向表中添加一个新记录,
10、你要使用SQL INSERT 语句。这里有一个如何使用这种语句的例子:INSERT mytable(mycolumn)V ALUES(,some data?)这个语句把字符串?some data?插入表 mytable 的 mycolumn 字段中。将要被插入数据的字段名师资料总结-精品资料欢迎下载-名师精心整理-第 6 页,共 10 页 -的名字在第一个括号中指定,实际的数据在第二个括号中给出。INSERT 语句的完整句法如下:INSERT INTO table_name|view_name(column_list)DEFAULT VALUES|Values_list|select_stat
11、ement 如果一个表有多个字段,通过把字段名和字段值用逗号隔开,你可以向所有的字段中插入数据。假设表 mytable 有三个字段first_column,second_column,和 third_column。下面的 INSERT语 句添加了一 条 三个字段 都有 值的完整记 录:INSERT mytable(first_column,second_column,third_column)VALUES(,some data?,?some more data?,?yet more data?)注意你可以使用INSERT 语句向文本型字段中插入数据。但是,如果你需要输入很长的字符串,你应该使用
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年SQL查询语句精华大全 2022 SQL 查询 语句 精华 大全
限制150内