第一篇:常见sql语句
结构化查询语句
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子句逻辑运算符如下:
Andselect * from tab where sex=‘女’ and dept=‘asp部’
Orselect * from tab where sex=‘女’ ordept=‘asp部’
Notselect * 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-0112: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常用语句
//创建临时表空间
create temporary tablespace test_temp
tempfile 'E:oracleproduct10.2.0oradatatestservertest_temp01.dbf'size 32m
autoextend on
next 32m maxsize 2048m
extent management local;
//创建数据表空间
create tablespace test_data
logging
datafile 'E:oracleproduct10.2.0oradatatestservertest_data01.dbf'size 32m
autoextend on
next 32m maxsize 2048m
extent management local;
//创建用户并指定表空间
create user username identified by password
default tablespace test_data
temporary tablespace test_temp;
//给用户授予权限
//一般用户
grant connect,resource to username;
//系统权限
grant connect,dba,resource to username
//创建用户
create user user01 identified by u01
//建表
create table test7272(id number(10),name varchar2(20),age number(4),joindate date default sysdate,primary key(id));
//存储过程
//数据库连接池
数据库连接池负责分配、管理和释放数据库连接
//
//创建表空间
create tablespace thirdspace
datafile 'C:/Program Files/Oracle/thirdspace.dbf' size 10mautoextend on;
//创建用户
create user binbin
identified by binbin
default tablespace firstspace
temporary tablespace temp;
//赋予权限
GRANT CONNECT, SYSDBA, RESOURCE to binbin
//null与""的区别
简单点说null表示还没new出对象,就是还没开辟空间
个对象装的是空字符串。
//建视图
create view viewname
as
sql
//建索引
create index indexname on tablename(columnname)
//在表中增加一列
alter table tablename add columnname columntype
//删除一列
alter table tablename drop columnname
//删除表格内容,表格结构不变
truncate table tableneme
//新增数据
insert into tablename()values()
//直接新增多条数据
insert into tablename()
selecte a,b,c
from tableabc
//更新数据 new除了对象,但是这“”表示
update tablename set columnname=? where
//删除数据
delete from tablename
where
//union语句
sql
union
sql
//case
case
when then
else
end
第三篇:SQL语句
SQL练习
一、设有如下的关系模式,试用SQL语句完成以下操作:
学生(学号,姓名,性别,年龄,所在系)
课程(课程号,课程名,学分,学期,学时)
选课(学号,课程号,成绩)
1. 求选修了课程号为“C2”课的学生学号
2. 求选修了课程号为“C2”课的学生学号和姓名
3. 求没有选修课程号为“C2”课的学生学号
4. 求选修了课程号为“C2”,又选修了课程号为“C3”课的学生学号
5.求选修了课程号为“C2”或“C3”课的学生学号
6.求选修了全部课程的学生学号
7.求至少选修了学号为“98002”的学生所学过的所有课程的学生的学号和姓名。
8.查询学生选课表中的全部数据
9.查询计算机系学生的姓名、年龄
10.查询成绩在70—80分之间的学生的学号、课程号和成绩
11.查询计算机系年龄在18—20之间且性别为“男”的学生的姓名和年龄
12.查询成绩在80分以上的学生的姓名、课程号和成绩,并按成绩的降序排列结果。
13.查询哪些课程没有人选修,要求列出课程号和课程名。
14.查询数学系成绩在80分以上的学生的学号,姓名
15.查询课程号为“C02”的课程的最高分数。
16.查询计算机系学生的最大年龄和最小年龄。
17.统计每个系的学生人数。
18.统计每门课程的选课人数和考试最高分。
19.统计每个学生的选课门数和考试总成绩,并按选课门数的升序显示结果。
20.查询总成绩超过200分的学生,要求列出学号、总成绩。
21.用子查询实现如下查询:
(1)查询选修了课程号“C01”的学生的姓名和所在系。
(2)查询数学系成绩在80分以上的学生的学号和姓名。
(3)查询计算机系考试成绩最高的学生的姓名。
22.删除选课成绩小于60分的学生的选课记录。
23.将所有选修了课程“C01”的学生的成绩加10分。
24.将计算机系所有选修了课程“计算机文化基础”课程的学生的成绩加10分。
25.创建查询学生的学号、姓名、所在系、课程号、课程名、课程学分的视图。
26.创建查询每个学生的平均成绩的视图,要求列出学生学号和平均成绩。
27.创建查询每个学生的选课学分的视图,要求列出学生学号及总学分。
第四篇:SQL语句
SQL语句,用友的SQL2000,通过查询管理器写的语句
1、查询
2、修改
3、删除
4、插入
表名:users 包含字段:id,sname,sage
查询 select * from users查询users表中所有数据
select id,sname,sage from users查询users表中id,sname,sage字段所有数据
可以限定查询条件比如:
select sname from users where sage>20查询年龄大于20岁的所有人的名字
修改 update users set sname='李四',sage=22将users表中数据都改为姓名李四,年龄22
update users set sname='李四',sage=22 where id=1限定id为1的人的信息修改为
姓名李四,年龄22
可以加where条件。
删除 delete from users where id=2删除users表中id为2的一行数据delete from users 代表删除users中所有数据
插入 insert into users(id,sname,sage)values(5,'刘三',21)插入一条数据
SQL四条最基本的数据操作语句:Insert,Select,Update和Delete。
例如:SELECT columns FROM tables;其中columns为列的名称,tables为表格名称
1、查询:select 字段名 from 表名 where 条件
查找在表(如A)中符合条件的字段
2、修改:update 表名 set 字段名=‘所要修改的内容’
修改在表(如A)中的字段的值为:所要修改的内容
3、删除: delete from 表名 where 条件
删除符合条件的表(如A)中的信息
4、插入: insert into 表名(字段名)(‘插入内容’)
在表(如A)中插入字段为:插入内容 的一条信息
第五篇:常用SQL语句
一、创建数据库
create database 数据库名
on(name='数据库名_data',size='数据库文件大小',maxsize='数据库文件最大值',filegrowth=5%,//数据库文件的增长率
filename='数据库存放的位置')
log on
(name='数据库名_log',size='数据库文件大小',maxsize='数据库文件最大值',filegrowth=5%,//数据库文件的增长率
filename='数据库存放的位置')
二、创建数据表
create table 表名
(字段名 字段类型 是否为空 primary key//是否为主键)
三、select语句
1、去除重复查询
select distinct 字段名 from 表名
2、按条件查询
select * from 表名 where 条件
3、排序desc升序/asc降序
select 字段名 from 表名 order by desc/asc
四、删除语句
delect from 表名 where 条件
五、修改语句
update from 表名 set 字段名1=‘字段值’,字段名2=‘字段值’ where 条件
六、插入语句
insert into 表名(字段名)values(字段值)//字段名与字段值一一对应
七、创建存储过程
use 数据库名
go
create proc 存储过程名
as
要存储在里面的SQL语句
八、sql分页
select top 查询的条数 *
from表名 where 主键 not in(select top 第几条开始查询 id from 表名 order by 主键)order by 主键 desc