sql子查询语句举例(SQL 数据库常用命令及语法举例)
本文目录
- SQL 数据库常用命令及语法举例
- 结合本次实验数据库,举例说明子查询可以出现在查询语句的哪些子句中
- 求SQL子查询语句
- 关于多表子查询的sql语句
- 求关于ORACLE中sql语句的子查询,select中的子查询详解,最好有个例子来叙述执行的步骤,谢谢!
- SQL数据库常用命令及语法举例
- SQL查询语句中,什么叫子查询
- 数据库 SQL语句 子查询执行过程
SQL 数据库常用命令及语法举例
SQL2000常用命令,语法使用方法
(1) 数据记录筛选:
sql=“select * from 数据表 where 字段名=字段值 order by 字段名 [desc]“
sql=“select * from 数据表 where 字段名 like ’%字段值%’ order by 字段名 [desc]“
sql=“select top 10 * from 数据表 where 字段名 order by 字段名 [desc]“
sql=“select * from 数据表 where 字段名 in (’值1’,’值2’,’值3’)“
sql=“select * from 数据表 where 字段名 between 值1 and 值2“
(2) 更新数据记录:
sql=“update 数据表 set 字段名=字段值 where 条件表达式“
sql=“update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式“
(3) 删除数据记录:
sql=“delete from 数据表 where 条件表达式“
sql=“delete from 数据表“ (将数据表所有记录删除)
(4) 添加数据记录:
sql=“insert into 数据表 (字段1,字段2,字段3 …) values (值1,值2,值3 …)“
sql=“insert into 目标数据表 select * from 源数据表“ (把源数据表的记录添加到目标数据表)
(5) 数据记录统计函数:
AVG(字段名) 得出一个表格栏平均值
COUNT(*|字段名) 对数据行数的统计或对某一栏有值的数据行数统计
MAX(字段名) 取得一个表格栏最大的值
MIN(字段名) 取得一个表格栏最小的值
SUM(字段名) 把数据栏的值相加
引用以上函数的方法:
sql=“select sum(字段名) as 别名 from 数据表 where 条件表达式“
set rs=conn.execute(sql)
用 rs(“别名“) 获取统的计值,其它函数运用同上。
(5) 数据表的建立和删除:
CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… )
例:CREATE TABLE tab01(name varchar(50),datetime default now())
DROP TABLE 数据表名称 (永久性删除一个数据表)
4. 记录集对象的方法:
rs.movenext 将记录指针从当前的位置向下移一行
rs.moveprevious 将记录指针从当前的位置向上移一行
rs.movefirst 将记录指针移到数据表第一行
rs.movelast 将记录指针移到数据表最后一行
rs.absoluteposition=N 将记录指针移到数据表第N行
rs.absolutepage=N 将记录指针移到第N页的第一行
rs.pagesize=N 设置每页为N条记录
2、更改表格
ALTER TABLE table_name
ADD COLUMN column_name DATATYPE
说明:增加一个栏位(没有删除某个栏位的语法。
ALTER TABLE table_name
ADD PRIMARY KEY (column_name)
说明:更改表得的定义把某个栏位设为主键。
ALTER TABLE table_name
DROP PRIMARY KEY (column_name)
说明:把主键的定义删除。
3、建立索引
CREATE INDEX index_name ON table_name (column_name)
说明:对某个表格的栏位建立索引以增加查询时的速度。
4、删除
DROP table_name
DROP index_name
二、的资料形态 DATATYPEs
smallint
16 位元的整数。
interger
32 位元的整数。
decimal(p,s)
p 精确值和 s 大小的十进位整数,精确值p是指全部有几个数(digits)大小值,s是指小数
点后有几位数。如果没有特别指定,则系统会设为 p=5; s=0 。
float
32位元的实数。
double
64位元的实数。
char(n)
n 长度的字串,n不能超过 254。
varchar(n)
长度不固定且其最大长度为 n 的字串,n不能超过 4000。
graphic(n)
和 char(n) 一样,不过其单位是两个字元 double-bytes, n不能超过127。这个形态是为
了支援两个字元长度的字体,例如中文字。
vargraphic(n)
可变长度且其最大长度为 n 的双字元字串,n不能超过 2000。
date
包含了 年份、月份、日期。
time
包含了 小时、分钟、秒。
timestamp
包含了 年、月、日、时、分、秒、千分之一秒。
三、资料操作 DML (Data Manipulation Language)
资料定义好之后接下来的就是资料的操作。资料的操作不外乎增加资料(insert)、查询资料(query)、更改资料(update) 、删除资料(delete)四种模式,以下分 别介绍他们的语法:
1、增加资料:
INSERT INTO table_name (column1,column2,...)
valueS ( value1,value2, ...)
说明:
1.若没有指定column 系统则会按表格内的栏位顺序填入资料。
2.栏位的资料形态和所填入的资料必须吻合。
3.table_name 也可以是景观 view_name。
INSERT INTO table_name (column1,column2,...)
SELECT columnx,columny,... FROM another_table
说明:也可以经过一个子查询(subquery)把别的表格的资料填入。
2、查询资料:
基本查询
SELECT column1,columns2,...
FROM table_name
说明:把table_name 的特定栏位资料全部列出来
SELECT *
FROM table_name
WHERE column1 = xxx
[AND column2 》 yyy] [OR column3 《》 zzz]
三)交叉连接
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到结果集合中的数
据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查询条件的数据行数。
例,titles表中有6类图书,而publishers表中有8家出版社,则下列交叉连接检索到的记录数将等
于6*8=48行。
SELECT type,pub_name
FROM titles CROSS JOIN publishers
ORDER BY type
UNION运算符可以将两个或两个以上上SELECT语句的查询结果集合合并成一个结果集合显示,即执行联合查询。UNION的语法格式为:
select_statement
UNION [ALL] selectstatement
[UNION [ALL] selectstatement][…n]
其中selectstatement为待联合的SELECT查询语句。
ALL选项表示将所有行合并到结果集合中。不指定该项时,被联合查询结果集合中的重复行将只保留一
行。
联合查询时,查询结果的列标题为第一个查询语句的列标题。因此,要定义列标题必须在第一个查询语
句中定义。要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。
在使用UNION 运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选
择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。在自动转换时,对于数值类
型,系统将低精度的数据类型转换为高精度的数据类型。
在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。例如:
查询1 UNION (查询2 UNION 查询3)
INSERT语句
用户可以用INSERT语句将一行记录插入到指定的一个表中。例如,要将雇员John Smith的记录插入到本例的表中,可以使用如下语句:
INSERT INTO EMPLOYEES valueS
(’Smith’,’John’,’1980-06-10’,
’Los Angles’,16,45000);
通过这样的INSERT语句,系统将试着将这些值填入到相应的列中。这些列按照我们创建表时定义的顺序排列。在本例中,第一个值“Smith”将填到第一个列LAST_NAME中;第二个值“John”将填到第二列FIRST_NAME中……以此类推。
我们说过系统会“试着”将值填入,除了执行规则之外它还要进行类型检查。如果类型不符(如将一个字符串填入到类型为数字的列中),系统将拒绝这一次操作并返回一个错误信息。
如果SQL拒绝了你所填入的一列值,语句中其他各列的值也不会填入。这是因为SQL提供对事务的支持。一次事务将数据库从一种一致性转移到另一种一致性。如果事务的某一部分失败,则整个事务都会失败,系统将会被恢复(或称之为回退)到此事务之前的状态。
回到原来的INSERT的例子,请注意所有的整形十进制数都不需要用单引号引起来,而字符串和日期类型的值都要用单引号来区别。为了增加可读性而在数字间插入逗号将会引起错误。记住,在SQL中逗号是元素的分隔符。
同样要注意输入文字值时要使用单引号。双引号用来封装限界标识符。
对于日期类型,我们必须使用SQL标准日期格式(yyyy-mm-dd)
结合本次实验数据库,举例说明子查询可以出现在查询语句的哪些子句中
经典SQL语句大全
下列语句部分是Mssql语句,不可以在access中使用。
SQL分类:
DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE)
DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT)
DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)
首先,简要介绍基础语句:
1、说明:创建数据库
CREATE DATABASE database-name
2、说明:删除数据库
drop database dbname
3、说明:备份sql server
--- 创建 备份数据的 device
USE master
EXEC sp_addumpdevice ’disk’, ’testBack’, ’c:\mssql7backup\MyNwind_1.dat’
--- 开始 备份
BACKUP DATABASE pubs TO testBack
4、说明:创建新表
create table tabname(col1 type1 [not null] [primary key],col2 type2 [not null],..)
根据已有的表创建新表:
A:create table tab_new like tab_old (使用旧表创建新表)
B:create table tab_new as select col1,col2… from tab_old definition only
5、说明:
删除新表:drop table tabname
6、说明:
增加一个列:Alter table tabname add column col type
注:列增加后将不能删除。DB2中列加上后数据类型也不能改变,唯一能改变的是增加varchar类型的长度。
7、说明:
添加主键:Alter table tabname add primary key(col)
说明:
删除主键:Alter table tabname drop primary key(col)
8、说明:
创建索引:create [unique] index idxname on tabname(col….)
删除索引:drop index idxname
注:索引是不可更改的,想更改必须删除重新建。
9、说明:
创建视图:create view viewname as select statement
删除视图:drop view viewname
10、说明:几个简单的基本的sql语句
选择:select * from table1 where 范围
插入:insert into table1(field1,field2) values(value1,value2)
删除:delete from table1 where 范围
更新:update table1 set field1=value1 where 范围
查找:select * from table1 where field1 like ’%value1%’ ---like的语法很精妙,查资料!
排序:select * from table1 order by field1,field2 [desc]
总数:select count * as totalcount from table1
求和:select sum(field1) as sumvalue from table1
平均:select avg(field1) as avgvalue from table1
最大:select max(field1) as maxvalue from table1
最小:select min(field1) as minvalue from table1
11、说明:几个高级查询运算词
A: UNION 运算符
UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表。当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行。两种情况下,派生表的每一行不是来自 TABLE1 就是来自 TABLE2。
B: EXCEPT 运算符
EXCEPT 运算符通过包括所有在 TABLE1 中但不在 TABLE2 中的行并消除所有重复行而派生出一个结果表。当 ALL 随 EXCEPT 一起使用时 (EXCEPT ALL),不消除重复行。
C: INTERSECT 运算符
INTERSECT 运算符通过只包括 TABLE1 和 TABLE2 中都有的行并消除所有重复行而派生出一个结果表。当 ALL 随 INTERSECT 一起使用时 (INTERSECT ALL),不消除重复行。
注:使用运算词的几个查询结果行必须是一致的。
12、说明:使用外连接
A、left outer join:
左外连接(左连接):结果集几包括连接表的匹配行,也包括左连接表的所有行。
SQL: select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c
B:right outer join:
右外连接(右连接):结果集既包括连接表的匹配连接行,也包括右连接表的所有行。
C:full outer join:
全外连接:不仅包括符号连接表的匹配行,还包括两个连接表中的所有记录。
其次,大家来看一些不错的sql语句
1、说明:复制表(只复制结构,源表名:a 新表名:b) (Access可用)
法一:select * into b from a where 1《》1
法二:select top 0 * into b from a
2、说明:拷贝表(拷贝数据,源表名:a 目标表名:b) (Access可用)
insert into b(a, b, c) select d,e,f from b;
3、说明:跨数据库之间表的拷贝(具体数据使用绝对路径) (Access可用)
insert into b(a, b, c) select d,e,f from b in ‘具体数据库’ where 条件
例子:..from b in ’“&Server.MapPath(“.“)&“\data.mdb“ &“’ where..
求SQL子查询语句
不用子查询就能出结果啊
select a.userid,a.name,sum(money) as money from a, b where a.userid=b.userid and freeze=’true’ group by a.userid,a.name
------------------
排序就在语句后加
order by a.userid asc
你查不到结果?
这个a.DeptID=1 是什么?不会是写错了吧
如果这个代表freeze的话。。。。一定要放到表b内!
==========================
Select a.UserID, a.Name, Sum(b.Money) As Money
From a, b
Where a.DeptID=1 And b.UserID=a.UserID And b.freeze=’true’
Group By a.UserID, a.Name
order by a.userid asc
关于多表子查询的sql语句
一般情况下没错,但是最好把“=“改成 “in“。
为什麽呢?因为你不能保证
(select top 1 H.fid from H where H.time》’2012-10-29
00:00:00’ group by H.fid order by
count (H.fid) desc )的结果只有一个值,举个例子:有两个帖子都回覆了10次,其他帖子都在10次以下,这时候你的这个子查询的结果是两个h.fid,也就是那两个回覆10次的(并列第一),而不是一个!
求关于ORACLE中sql语句的子查询,select中的子查询详解,最好有个例子来叙述执行的步骤,谢谢!
嵌套的子查询值一般都是唯一的,也就是只有一个值,不过,也有多个值。
如:select a.id,a.name from test a where a.id=(select id from testname where name=’张三’)
当子查询是多个值时为条件时:
select a.id,a.name from test a where a.id in (select id from testname where name=’张三’)
执行步骤都是先查出子查询的值,然后,把子查询值作为条件值,放到主查询的条件中。
SQL数据库常用命令及语法举例
下面是一些常用的SQL语句,虽然很基础,可是却很值得收藏,对于初学者非常实用
SQL常用命令使用方法:
(1) 数据记录筛选:
sql=“select * from 数据表 where 字段名=字段值 order by 字段名 [desc]“
sql=“select * from 数据表 where 字段名 like ’%字段值%’ order by 字段名 [desc]“
sql=“select top 10 * from 数据表 where 字段名 order by 字段名 [desc]“
sql=“select * from 数据表 where 字段名 in (’值1’,’值2’,’值3’)“
sql=“select * from 数据表 where 字段名 between 值1 and 值2“
(2) 更新数据记录:
sql=“update 数据表 set 字段名=字段值 where 条件表达式“
sql=“update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式“
(3) 删除数据记录:
sql=“delete from 数据表 where 条件表达式“
sql=“delete from 数据表“ (将数据表所有记录删除)
(4) 添加数据记录:
sql=“insert into 数据表 (字段1,字段2,字段3 …) values (值1,值2,值3 …)“
sql=“insert into 目标数据表 select * from 源数据表“ (把源数据表的记录添加到目标数据表)
(5) 数据记录统计函数:
AVG(字段名) 得出一个表格栏平均值
COUNT(*|字段名) 对数据行数的统计或对某一栏有值的数据行数统计
MAX(字段名) 取得一个表格栏最大的值
MIN(字段名) 取得一个表格栏最小的值
SUM(字段名) 把数据栏的值相加
引用以上函数的方法:
sql=“select sum(字段名) as 别名 from 数据表 where 条件表达式“
set rs=conn.excute(sql)
用 rs(“别名“) 获取统的计值,其它函数运用同上。
(5) 数据表的建立和删除:
CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度) …… )
例:CREATE TABLE tab01(name varchar(50),datetime default now())
DROP TABLE 数据表名称 (永久性删除一个数据表)
4. 记录集对象的方法:
rs.movenext 将记录指针从当前的位置向下移一行
rs.moveprevious 将记录指针从当前的位置向上移一行
rs.movefirst 将记录指针移到数据表第一行
rs.movelast 将记录指针移到数据表最后一行
rs.absoluteposition=N 将记录指针移到数据表第N行
rs.absolutepage=N 将记录指针移到第N页的第一行
rs.pagesize=N 设置每页为N条记录
rs.pagecount 根据 pagesize 的设置返回总页数
rs.recordcount 返回记录总数
rs.bof 返回记录指针是否超出数据表首端,true表示是,false为否
rs.eof 返回记录指针是否超出数据表末端,true表示是,false为否
rs.delete 删除当前记录,但记录指针不会向下移动
rs.addnew 添加记录到数据表末端
rs.update 更新数据表记录
参考资料
SQL常用命令.csdn[引用时间2017-12-30]
SQL查询语句中,什么叫子查询
嵌套SELECT语句也叫子查询,一个
SELECT
语句的查询结果能够作为另一个语句的输入值。子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在select
list中,作为一个字段值来返回。
1、单行子查询
:单行子查询是指子查询的返回结果只有一行数据。当主查询语句的条件语句中引用子查询结果时可用单行比较符号(=,
》,
《,
》=,
《=,
《》)来进行比较。
例:
select
ename,deptno,sal
from
emp
where
deptno=(select
deptno
from
dept
where
loc=’NEW
YORK’);
2、多行子查询:多行子查询即是子查询的返回结果是多行数据。当主查询语句的条件语句中引用子查询结果时必须用多行比较符号(IN,ALL,ANY)来进行比较。其中,IN的含义是匹配子查询结果中的任一个值即可(“IN“
操作符,能够测试某个值是否在一个列表中),ALL则必须要符合子查询的所有值才可,ANY要符合子查询结果的任何一个值即可。而且须注意ALL
和ANY
操作符不能单独使用,而只能与单行比较符(=、》、《
、》=
、《=
、《》)结合使用。
例:
1).多行子查询使用IN操作符号例子:查询选修了老师名叫Rona(假设唯一)的学生名字
sql》
select
stName
数据库 SQL语句 子查询执行过程
子查询执行过程,可以用以下例子来说明:
语句如下:
select * from score where sid in (select sid from student where 班级=’一班’)
在sql语句中,数据库先执行的是括号中的部分,得出student表中一班学生的sid,然后再在score表中选出sid为一班id的哪些学生的详细内容。
更多文章:
distinctiveness is an essential(essential怎么读)
2024年8月3日 21:35
repeat to do还是doing(英语语法直接引语变间接引语)
2024年7月15日 07:41
菜鸟教程网址(我想学习软件应用,可是我不懂代码编辑c语言,我应该怎么学习,零基础应该从那些开始学,怎么学)
2024年6月29日 03:17
augmented steam(如何评价Steam上的这款虚拟现实应用虚拟桌面)
2024年6月26日 08:10
settings在键盘上(实况足球2013setting键盘的各个键代表的意思)
2024年7月10日 14:51
爱站和chinaz,查询权重哪个比较准确?站长工具和爱站那个查询结果比较准确一点
2024年7月16日 00:59
《炉石传说》中,各职业常见combo及经典combo有哪些?如何令comboBox不能输入,只能选择
2024年7月2日 02:41
trunc函数怎么样(Oracle round()函数与trunc()函数区别介绍)
2024年4月6日 17:05
yml船公司官网货物跟踪(X-Press Feeders Group船公司介绍)
2024年7月21日 09:11
oracle19c和11g的兼容性(oracle 11g安装出现兼容性问题)
2024年7月3日 11:09
defines(《群星》修改defines.lua数值后无法进入游戏怎么办)
2023年12月13日 07:40
学生信息管理系统查询(如何从全国中小学学籍系统查询学生学籍信息)
2024年7月11日 16:49