常见sql语句

时间:2024.4.21

结构化查询语句

1.简单查询

1.1Select语句基本应用

1.1.1查询所有记录

Select * from tab_name

1.1.2查询指定字段的记录

Select field1,field2,….from tab_name

1.1.3带表达式的查询

Select field1,compute(expression) from tab_name

其中expression可以是算术表达式,字符串表达式,字符串常量和函数等。

1.1.4显示列名的带表达式的查询

Select field1, compute(expression)fieldname from tab_name

在表达式compute(expression)后面添加字符串(fieldname)可以作为显示的列名,

中间不用逗号间隔。

1.1.5指定查询路径的查询

Select * from datebase.dbo.tab_name

用于访问其他数据库下的其他用户的数据表,查询路径格式为“数据库名.数据表拥有者名.数据表名”。

1.1.6指定查询结果的查询

Select top n * from tab_name

指定只从查询结果集中输出前n行,n为0到4294967295之间的整数。 Select top n percent * from tab_name

指定返回结果集的百分数,n为0到100之间的整数。

1.1.7更改列标题显示的查询

Select field1 as ‘a’, field2 as ‘b’ from tab_name

As后面以单引号标识新的列标题。其等价于

Select ‘a’=field1, ‘b’=field2 from tab_name

1.2去掉重复记录

Select distinct field1,field2,….from tab_name [where search_condition]

Distinct是关键字,将查询结果集中的重复记录去掉(即不允许出现相同的行,也即每一列都相同的行将会被去除;有些记录部分列相同不在distinct要剔除的范围),distinct后面可以是*,也可以是列名称。

1.3条件查询

1.3.1Where子句关系比较运算符如下:

= 、<>、!= 、> 、< 、<= 、>= 、!<(不小于) 、!> (不大于) !> 不大于 select * from tab where date!>’06-09-05’ !< 不小于 select * from tab where date!<’09/05/2006’ In 列表 select * from employee where age in(26,27)

not in 不在列表 select * from employee where ygname not in(‘雨晴’) between….and 介于之间 select * from employee where id between ‘001’ and ‘050’ not berween…and 不介于之间 select * from tab where id not between ‘001’ and ‘050’ like 模糊查询 select * from tab where booknames like ‘asp%’

not like 非模糊查询 select * from tab where booknames not like ‘asp%’ is null 是否为空 select * from tab where price is null

is not null 是否不为空 select * from tab where price is not null

1.3.2Where子句逻辑运算符如下:

And select * from tab where sex=‘女’ and dept=‘asp部’

Or select * from tab where sex=‘女’ or dept=‘asp部’

Not select * from tab where not dept=‘asp部’

1.4排序查询

Select fieldlist from tab where search_condition order by expression[asc|desc]

Expression:一个表达式,通常是字段名,表示根据该字段排序

[asc|desc]:asc代表升序,desc代表降序,默认按升序排列

1.5模糊查询

Like子句中的查询条件常与通配符配合使用,常用通配符如下:

_ 代表一个任意字符

Sql="select name from tab where name like'"&txt&"_'"

% 代表包含零个或多个字符的字符串

Sql="select name from tab where name like'%"&txt&"%'"

[] 代表指定范围内的一个任意字符

Sql="select name from tab where name like'_["&txt&"]%'"

此例中,第一个字符为任意字符,第二个字符为txt内多个字符中的任意一个字符,后面的字符为任意字符或字符串。

[^] 代表不在指定范围内的一个任意字符

Sql="select name from tab where name like'[^"&txt&"]%'"

Escape关键字规定转义字符

把通配符当作普通字符时需要用escape关键字规定转义字符。而转义字符后出现的第一个通配符不再具有通配符的作用,只是当作普通字符处理。

Sql="select name from tab where name like'["&txt&"]%/%'escape ‘/’"

此例中,在sql语句末用escape ‘/’来规定/为转义字符。于是第二个%为普通字符。此例表示查询以txt中的任意一个字符为开始,然后是任意字符或字符串,最后以字符%结束的name.

1.6日期和时间查询

1.6.1查询指定日期时间的数据

Sql语句中,可以使用算术运算符(例如>、<、!=、=等)比较两个日期/时间类型的数据。日期时间字符的书写要符合一定的格式,例如:‘1982-01-01 12:04:00’。Asp里写入日期/时间类型变量时,一定要将变量写在单引号之内。

1.6.2使用日期和时间函数进行查询

Sql="select name,Datetm from tab where datediff(day,Datetm,getdate())<7" Datetm是数据表中的一个项,通过datediff函数获得前一周内的记录信息。

Asp里可以用脚本函数FormatDateTime把Datetm格式化为段日期类型。FormatDateTime(rs(“Datetm”),1)。

2.高级查询

2.1分组查询

2.1.1分组查询

用group by 进行分组。指定group by时,select子句中任意非聚合表达式内的所有列都应该包含在group by列表中。聚合函数概念:如sum(a),count(*)。

注意:1,在select子句的字段列表中,除了聚合函数外,其他所出现的字段一定要在group by子句中有定义才行,例如:“group by a,b”,那么“select sum(a),c”就有问题,因为c不在group by中,但是sum(a)是聚会函数,可以不再group by 子句中。 2,select子句的字段列表中不一定要有聚合函数,但至少要用到group by子句列表中的一个项目,例如“group by a,b,c”,则“select a”是可以的。

3,group by子句不能使用字段别名。

Sql="select publish,sum(je) as totalje from tab group by publish order by totalje desc"

此例中,按照出版社的名称进行分组,把相同名称的出版社的库存金额进行相加,从而实现单列数据分组统计的功能。计算每个出版社的总库存金额然后降序排列。

2.1.2过滤分组查询

Having子句用于指定组合或聚合的搜索条件。Having通常与group by子句一起使用。如果不使用group by子句,having的行为与where子句一样。

Having参数可以包含多个过滤条件,而这些过滤条件之间是利用and或or运算符相连接的。当然也可以用not运算符来逆转一个布尔表达式。

Sql="select distinct demp,count(*) as counts,max(jbgz) as maxgz,avg(jbgz) as avggz from tab group by demp having avg(jbgz)>1500"

此例中,按照部门名称进行分组,把部门平均工资大于1500的部门信息(demp,counts,maxgz,avggz这些信息)输出。

2.2多表查询

2.2.1内连接查询

连接查询是指通过各个表之间共同列的关联性查询数据。内连接是将两个相互交叉的数据集合中重叠部分的数据行连接起来,返回表示两个数据集合之间匹配连接关系的数据行。

可以在from子句中使用inner join…on…建立内连接,也可以在where子句中指定连接条件建立内连接。

Sql="select a.uerName,b.bookName,b.Datetm from userInfor as a inner join bookInfor as b on a.uerId=b.userId"

或者

Sql="select a.uerName,b.bookName,b.Datetm from userInfor as a, bookInfor as b where a.uerId=b.userId"

2.2.2外连接查询

内部连接只连接两个表同时拥有的数据行,而外部连接是对内部连接的补充,还根据要求返还前一个(左外)或后一个(右外)数据表中非匹配行的数据。

2.2.2.1左外连接left outer join

左外连接left outer join逻辑运算符除了返回两个数据表中满足连接条件的行,它还返回任何在后一个数据表中没有匹配行的前一个数据表中的行。非匹配行的部分字段列作为空值返回。

Sql="select a.uerName,b.bookName,b.Datetm from userInfor as a left outer join bookInfor as b on a.uerId=b.userId where a.uerName like’%"&txt_name&"%’"

此例中通过在数据表userInfor和bookInfor之间建立左外连接,并可以根据输入的txt_name查询所有满足条件的用户信息—包括userName,bookName,Datetm(当该用户未购买图书,相应字段列为空值返回)。即也返回第一个表(左外)userInfor中非匹配行的数据。

2.2.2.2右外连接right outer join

右外连接是左外连接的反向连接。还返回任何在前一个数据表中没有匹配行的后一个数据表中的行。非匹配行的部分字段列作为空值返回。

Sql="select a.uerName,b.bookName,b.Datetm from userInfor as a right outer join bookInfor as b on a.uerId=b.userId where b.bookName like’%"&txt_name&"%’"

此例中通过在数据表userInfor和bookInfor之间建立右外连接,并可以根据输入的txt_name查询所有满足条件的图书信息(即使该图书没有用户名称相对应)。即也返回第二个表(右外)bookInfor中非匹配行的数据。

2.2.3使用union进行联合查询

Union运算符可以将来自多个select语句的结果组合成单一的结果集。Union进行两两合并。默认情况下,union运算符从结果集中删除重复的行;当包含all关键字时结果集将包含所有行而不会删除重复的行。语法:select_statement union [all] select_statement

使用union运算符的语句中,所有选择列表的表达式数目必须相同,数据类型也必须相同。Union的结果集列名与union运算符中第一个select语句的结果集中的列名相同,另一个select语句的结果集的列名将会被忽略。

Sql="select ygid,ygname,sex,age from employee union select userid,username,sex,age from user "

此列中,利用union运算符获得员工信息表和用户信息表中的编号、姓名、性别、年龄字段合并的结果集。

2.3聚合函数查询

聚合函数实现对一组数值执行计算并返回单一值,经常与select语句中的group by子句配合使用。聚合函数如下:

Count() 返回组()中项目的数量

Avg() 返回组中项目的平均值,null值被忽略

Sum() 返回表达式中所有值的和,只能用于数字列,null值被忽略

Min() 返回表达式的最小值,忽略null。对于字符序列,min查找排序列的最低值。 Max() 返回表达式的最大值,忽略null.对于字符序列,查找排序列的最大值。

其中avg,sum,min和max函数的表达式有all,distinct限制,All是默认值。例如avg([all|distinct]math) ,distinct指定avg操作只使用每个值的唯一实例,而不管该值出现了多少次。

2.4嵌套查询

在sql语句中又包含一个sql语句的形式称为嵌套查询。在where子句和having子句中都可以嵌套sql语句。

2.4.1普通嵌套查询

Sql="select * from chengji where english>(select english from chengji where id=’07254032’)"

2.4.2带in的嵌套查询

Sql="select bookname from bookinfor where bookname in (‘asp范例宝典’,‘vb简易教程’)"

Sql="select * from chengji where id in (select id from chengji where english>80)" 在带in的嵌套查询中,in里是另一个sql语句时,则select子句中只能指定一个列名,如本例中的id,当指定了多个列名或者星号时就会出错。

2.4.3带exists的嵌套查询

Sql="select * from chengji where exists (select * from chengji where english>80)" Exists代表存在,上例查找英语成绩大于80的所有记录。与in 不同的是,exists后面的sql语句,其select子句可以指定很多列。

2.4.4带not exists和not in的嵌套查询

not exists 和not in的嵌套查询和exists,in的嵌套查询相反。

Sql="select * from chengji where not exists (select * from student chengji.name=student.name)"

如果student和chengji里的记录有相同的name,就不被查找。

3.sql操作

3.1利用insert添加记录

Sql="insert into chengji values(‘004’,89,90,0)"

记住有多少数据项,value里面就有多少项,而且不能为空

3.2利用delete删除记录

Sql="delete from chengji where id=‘004’ "

3.3利用update修改记录

Sql="update chengji set english=89, computer=95 where id=‘004’ "

Update 内部set间是,不是and。要注意!

where

更多相关推荐:
简单SQL语句总结

简单SQL语句总结1.在查询结果中显示列名:a.用as关键字:selectnameas'姓名'fromstudentsorderbyageb.直接表示:selectname'姓名'fromstudentsord…

[数据库]简单SQL语句总结

[数据库]简单SQL语句总结全篇以学生成绩的管理为例描述。1.在查询结果中显示列名:a.用as关键字:selectnameas'姓名'fromstudentsorderbyageb.直接表示:selectnam…

SQL语句总结

Create用法:(建库,建表,建视图,建索引)1、建库:Createdatabase数据库名2、建表:Createtable表名3、建视图:Createview视图名AS查询语句4、建索引:Createind…

SQL语句总结

SQL语句总结一.模式的定义和删除1.定义模式:createscheme模式名authorization用户名Eg:定义一个学生-课程模式S-Tcreatescheme“S-T”authorizationWan…

SQL语句总结

SQL数据库语句一、对表操作1.新建数据库createdatabase数据库名2.新建表createtable表名(字段1数据类型[限制条件],字段2数据类型[限制条件]);限制条件:unique限制不能重复,…

数据库 最全的sql语句总结大全

CREATEDATABASEeduON(NAME=edu_data,FILENAME='c:/edu_data.mdf',SIZE=10M,MAXSIZE=1024M,FILEGROWTH=1M)LOGON(N…

SQL语句总结

SQL语句总结一、插入记录1.插入固定的数值语法:INSERT[INTO]表名[(字段列表)]VALUES(值列表)示例1:InsertintoStudentsvalues('Mary’,24,’mary@16…

sql总结

sql总结收藏选择出重复的字段SELECTidFROMtempWHERESELECTCOUNTFROMSELECTFROMTEMPASaaWHEREaaidTEMPidgt1INSERTINTOtemp1idS...

sql经典语句总结

经典SQL语句大全一基础1说明创建数据库CREATEDATABASEdatabasename2说明删除数据库dropdatabasedbname3说明备份sqlserver创建备份数据的deviceUSEmas...

50个经典sql语句总结

一个项目涉及到的50个Sql语句整理版1学生表StudentSSnameSageSsexS学生编号Sname学生姓名Sage出生年月Ssex学生性别2课程表CourseCCnameTC课程编号Cname课程名称...

OracleSQL语句的执行计划优化的总结

通过分析SQL语句的执行计划优化SQL总结第一章第2章并不是很重要是自己的一些想法关于如何做一个稳定高效的应用系统的一些想法第三章以后都是比较重要的附录的内容也是比较重要的我常用该部分的内容前言本文档主要介绍与...

oracle sql详细总结版语句

oraclesql语句一ORACLE的启动和关闭1在单机环境下要想启动或关闭ORACLE系统必须首先切换到ORACLE用户如下suoraclea启动ORACLE系统oraclegtsvrmgrlSVRMGRgt...

sql语句总结(21篇)