杏彩SQL SERVER常用语法汇总

作者:计算机专家

阅读目录

一、SQL分类

DDL—数据定义语言(CREATE,ALTEWrangler,DROP,DECLARE)

DML—数据垄断(monopoly)语言(SELECT,DELETE,UPDATE,INSERT)

DCL—数据调整语言(GRANT,REVOKE,COMMIT,ROLLBACK)

 

一、SQL分类

DDL—数据定义语言(CREATE,ALTELX570,DROP,DECLARE)

DML—数据垄断语言(SELECT,DELETE,UPDATE,INSERT)

DCL—数据调节语言(GRANT,REVOKE,COMMIT,ROLLBACK)

 

  • 一、SQL分类
  • 二、基础语句
  • 三、sql技巧
  • 四、(MS SQL Server)SQL语句导入导出大全

二、基础语句

二、基础语句

回到目录

2.1、表明:创造数据库

create database db-name

2.1、表达:创造数据库

create database db-name

一、SQL分类

DDL—数据定义语言(CREATE,ALTE揽胜极光,DROP,DECLARE)

DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT)

DCL—数据调控语言(GRANT,REVOKE,COMMIT,ROLLBACK)

 

回到目录

2.2、表达:删除数据库

drop database db-name 

2.2、表明:删除数据库

drop database db-name 

二、基础语句

2.3、说明:备份sql server

--- 创建 备份
USE master
EXEC sp_addumpdevice 'disk', 'testBack', 'c:mssql7backupMyNwind_1.dat'
--- 开始 备份
BACKUP DATABASE pubs TO testBack

2.3、说明:备份sql server

--- 创建 备份
USE master
EXEC sp_addumpdevice 'disk', 'testBack', 'c:mssql7backupMyNwind_1.dat'
--- 开始 备份
BACKUP DATABASE pubs TO testBack

2.1、表明:创立数据库

create database db-name

2.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

2.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

2.2、表明:删除数据库

drop database db-name 

2.5、表达:删除新表

drop table tabname

2.5、表达:删除新表

drop table tabname

2.3、说明:备份sql server

--- 创建 备份
USE master
EXEC sp_addumpdevice 'disk', 'testBack', 'c:mssql7backupMyNwind_1.dat'
--- 开始 备份
BACKUP DATABASE pubs TO testBack

2.6、表达:扩张多个列

Alter table tabname add column col type

注:列增添后将不能够去除。DB2中列加上后数据类型也无法更换,独一能更动的是加多varchar类型的尺寸。

2.7、表达:增多/删除主键

Alter table tabname add primary key(col)
Alter table tabname drop primary key(col)

2.8、说明:创制/删除索引

create [unique] index idxname on tabname(col….)
drop index idxname

注:索引是不行更改的,想更动必得删除重新建。

2.9、表明:创造/删除视图

create view viewname as select statement
drop view viewname

2.6、表达:扩大一个列

Alter table tabname add column col type

注:列扩展后将无法去除。DB第22中学列加上后数据类型也不能够更改,唯一能改换的是增添varchar类型的长度。

2.7、表达:增加/删除主键

Alter table tabname add primary key(col)
Alter table tabname drop primary key(col)

2.8、表达:创造/删除索引

create [unique] index idxname on tabname(col….)
drop index idxname

注:索引是不足改换的,想更动必得删除重新建。

2.9、表明:创立/删除视图

create view viewname as select statement
drop view viewname

2.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

2.10、表达:基本sql语句选取

查询:select * from table1 where 范围
插入:insert into table1(field1,field2) s(1,2)
删除:delete from table1 where 范围
更新:update table1 set field1=1 where 范围
查找:select * from table1 where field1 like ’%1%’ ---like的语法
排序:select * from table1 order by field1,field2 [desc]
总数:select count * as totalcount from table1
求和:select sum(field1) as sum from table1
平均:select avg(field1) as avg from table1
最大:select max(field1) as max from table1
最小:select min(field1) as min from table1

2.10、表达:基本sql语句选取

查询:select * from table1 where 范围
插入:insert into table1(field1,field2) s(1,2)
删除:delete from table1 where 范围
更新:update table1 set field1=1 where 范围
查找:select * from table1 where field1 like ’%1%’ ---like的语法
排序:select * from table1 order by field1,field2 [desc]
总数:select count * as totalcount from table1
求和:select sum(field1) as sum from table1
平均:select avg(field1) as avg from table1
最大:select max(field1) as max from table1
最小:select min(field1) as min from table1

2.5、表明:删除新表

drop table tabname

2.11、表明:高端查询运算

A: UNION 运算符

UNION 运算符通过整合别的四个结果表(比如 TABLE1 和 TABLE2)并消去表中别的重复行而派生出贰个结实表。

当 ALL 随 UNION 一齐利用时(即 UNION ALL),不免除重复行。

二种情景下,派生表的每一行不是源于 TABLE1 就是源于 TABLE2。

B: EXCEPT 运算符

EXCEPT 运算符通过包涵全体在 TABLE1 中但不在 TABLE第22中学的行并化解全体重复行而派生出贰个结出表。

当 ALL 随 EXCEPT 一同使用时 (EXCEPT ALL),不排除重复行。

C: INTERSECT 运算符

INTELX570SECT 运算符通过只囊括 TABLE1 和 TABLE2中都局地行并化解全数重复行而派生出三个结出表。

当 ALL 随 INTETiggoSECT 一同利用时 (INTE中华VSECT ALL),不消除重复行。

注:使用运算词的多少个查询结果行必需是一模二样的。

2.11、表达:高端查询运算

A: UNION 运算符

UNION 运算符通过结合其余多少个结实表(比如 TABLE1 和 TABLE2)并消去表中其余重复行而派生出三个结果表。

当 ALL 随 UNION 一齐使用时(即 UNION ALL),不清除重复行。

两种处境下,派生表的每一行不是缘于 TABLE1 正是源于 TABLE2。

B: EXCEPT 运算符

EXCEPT 运算符通过包涵持有在 TABLE1 中但不在 TABLE2中的行并化解全数重复行而派生出叁个结出表。

当 ALL 随 EXCEPT 一同使用时 (EXCEPT ALL),不免除重复行。

C: INTERSECT 运算符

INTERAV4SECT 运算符通过只囊括 TABLE1 和 TABLE第22中学都部分行并消除全数重复行而派生出一个结出表。

当 ALL 随 INTE摩根Plus 8SECT 一同行使时 (INTE安德拉SECT ALL),不化解重复行。

注:使用运算词的多少个查询结果行必需是一样的。

2.6、表达:扩张八个列

Alter table tabname add column col type

注:列增添后将无法去除。DB第22中学列加上后数据类型也不可能退换,独一能退换的是充实varchar类型的长短。

2.7、表达:增加/删除主键

Alter table tabname add primary key(col)
Alter table tabname drop primary key(col)

2.8、表明:创设/删除索引

create [unique] index idxname on tabname(col….)
drop index idxname

注:索引是不行改造的,想改造必得删除重新建。

2.9、表明:创立/删除视图

create view viewname as select statement
drop view viewname

2.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: 全外连接:不仅仅包含符号连接表的相称行,还包含多个一连表中的全数记录。

 

2.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: 全外连接:不止包含符号连接表的相配行,还饱含两个再而三表中的全体记录。

 

2.10、表明:基本sql语句选取

杏彩 1

查询:select * from table1 where 范围
插入:insert into table1(field1,field2) s(1,2)
删除:delete from table1 where 范围
更新:update table1 set field1=1 where 范围
查找:select * from table1 where field1 like ’%1%’ ---like的语法
排序:select * from table1 order by field1,field2 [desc]
总数:select count * as totalcount from table1
求和:select sum(field1) as sum from table1
平均:select avg(field1) as avg from table1
最大:select max(field1) as max from table1
最小:select min(field1) as min from table1

杏彩 2

补充:

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..

4)、说明:子查询(表名1:a 表名2:b)

select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3) 

5)、表达:展现小说、提交人和末段回复时间

select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b

6)、表明:外接连查询(表名1:a 表名2:b)

select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 

7)、表明:在线视图查询(表名1:a )

select * from (SELECT a,b,c FROM a) T where t.a > 1; 

8)、表明:between的用法,between限制查询数据范围时富含了边界值,not between不饱含

select * from table1 where time between time1 and time2
select a,b,c, from table1 where a not between 数值1 and 数值2

9)、表达:in 的接纳方法

select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’) 

10)、表明:两张关联表,删除主表中以前在副表中并没有的音信

delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )

11)、说明:四表联合检查难题

select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where ..... 

12)、表明:日程安顿提早陆分钟提示

SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 

13)、表达:一条sql 语句化解数据库分页

select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段

14)、说明:前10条记录

select top 10 * form table1 where 范围 

15)、表明:选拔在每一组b值一样的数额中对应的a最大的笔录的装有音信(类似那样的用法能够用来论坛每月排名榜,每月热销产品剖判,按学科战绩排行,等等.)

select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) 

16)、表明:包含拥有在 TableA 中但不在 TableB和TableC 中的行并化解全部重复行而派生出一个结果表

(select a from tableA ) except (select a from tableB) except (select a from tableC) 

17)、表达:随机抽取10条数据

select top 10 * from tablename order by newid() 

18)、表明:随机挑选记录

select newid()

19)、表明:删除重复记录

Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) 

20)、表明:列出数据Curry全数的表名

select name from sysobjects where type='U'

21)、表明:列出表里的有所的

select name from syscolumns where id=object_id('TableName') 

22)、表达:列示type、vender、pcs字段,以type字段排列,case可以方便地达成多种采取,类似select 中的case。

select type,
sum(case vender when 'A' then pcs else 0 end),
sum(case vender when 'C' then pcs else 0 end),
sum(case vender when 'B' then pcs else 0 end)
FROM tablename group by type

显示结果:

type vender pcs
电脑 A 1
电脑 A 1
光盘 B 2
光盘 A 2
手机 B 3
手机 C 3

23)、表明:开始化表table1

TRUNCATE TABLE table1 

24)、说明:选择从10到15的记录

select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc

 

补充:

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..

4)、说明:子查询(表名1:a 表名2:b)

select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3) 

5)、表明:展现小说、提交人和最终回复时间

select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b

6)、表达:外接连查询(表名1:a 表名2:b)

select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 

7)、表明:在线视图查询(表名1:a )

select * from (SELECT a,b,c FROM a) T where t.a > 1; 

8)、表明:between的用法,between限制查询数据范围时包蕴了边界值,not between不包涵

select * from table1 where time between time1 and time2
select a,b,c, from table1 where a not between 数值1 and 数值2

9)、表明:in 的利用办法

select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’) 

10)、表明:两张关联表,删除主表中一度在副表中尚无的音信

delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )

11)、表达:四表联合检查难题

select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where ..... 

12)、表达:日程安插提早五分钟提醒

SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 

13)、表明:一条sql 语句化解数据库分页

select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段

14)、说明:前10条记录

select top 10 * form table1 where 范围 

15)、表明:选用在每一组b值一样的数额中对应的a最大的笔录的具有新闻(类似那样的用法能够用来论坛每月排名的榜单,每月卖得快产品深入分析,按学科战绩排行,等等.)

select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) 

16)、表明:包蕴富有在 TableA 中但不在 TableB和TableC 中的行并解决全数重复行而派生出三个结果表

(select a from tableA ) except (select a from tableB) except (select a from tableC) 

17)、表达:随机抽取10条数据

select top 10 * from tablename order by newid() 

18)、表明:随机接纳记录

select newid()

19)、说明:删除重复记录

Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) 

20)、表明:列出数据Curry装有的表名

select name from sysobjects where type='U'

21)、表达:列出表里的保有的

select name from syscolumns where id=object_id('TableName') 

22)、表明:列示type、vender、pcs字段,以type字段排列,case能够一本万利地贯彻多种选用,类似select 中的case。

select type,
sum(case vender when 'A' then pcs else 0 end),
sum(case vender when 'C' then pcs else 0 end),
sum(case vender when 'B' then pcs else 0 end)
FROM tablename group by type

体现结果:

type vender pcs
电脑 A 1
电脑 A 1
光盘 B 2
光盘 A 2
手机 B 3
手机 C 3

23)、表达:起先化表table1

TRUNCATE TABLE table1 

24)、说明:选择从10到15的记录

select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc

 

2.11、表明:高档查询运算

A: UNION 运算符

UNION 运算符通过结合其他五个结果表(比方 TABLE1 和 TABLE2)并消去表中任何重复行而派生出二个结果表。

当 ALL 随 UNION 一同使用时(即 UNION ALL),不免除重复行。

三种情景下,派生表的每一行不是来源于 TABLE1 正是来自 TABLE2。

B: EXCEPT 运算符

EXCEPT 运算符通过富含富有在 TABLE1 中但不在 TABLE第22中学的行并化解全体重复行而派生出一个结出表。

当 ALL 随 EXCEPT 一同行使时 (EXCEPT ALL),不化解重复行。

C: INTERSECT 运算符

INTE奥迪Q3SECT 运算符通过只囊括 TABLE1 和 TABLE第22中学都一些行并消除全数重复行而派生出贰个结出表。

当 ALL 随 INTE劲客SECT 一起行使时 (INTE奥迪Q3SECT ALL),不拔除重复行。

注:使用运算词的多少个查询结果行必需是一样的。

三、sql技巧

三、sql技巧

2.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: 全外连接:不独有囊括符号连接表的相配行,还包涵四个接二连三表中的全体记录。

 

3.1、如何删除三个表中重复的笔录?

create table a_dist(id int,name varchar(20))

insert into a_dist values(1,'abc')
insert into a_dist values(1,'abc')
insert into a_dist values(1,'abc')
insert into a_dist values(1,'abc')

exec up_distinct 'a_dist','id'

select * from a_dist

 存款和储蓄进程如下:

杏彩 3杏彩 4

 1 create procedure up_distinct(@t_name varchar(30),@f_key varchar(30))
 2 --f_key表示是分组字段﹐即主键字段
 3 
 4 as
 5 begin
 6 declare @max integer,@id varchar(30) ,@sql varchar(7999) ,@type integer
 7 select @sql = 'declare cur_rows cursor for select '+@f_key+' ,count(*) from ' +@t_name +' group by ' +@f_key +' having count(*) > 1'
 8 exec(@sql)
 9 
10 open cur_rows
11 fetch cur_rows into @id,@max
12 
13 while @@fetch_status=0
14 begin
15 select @max = @max -1
16 set rowcount @max
17 select @type = xtype from syscolumns where id=object_id(@t_name) and name=@f_key
18 if @type=56
19 select @sql = 'delete from '+@t_name+' where ' + @f_key+' = '+ @id
20 if @type=167
21 select @sql = 'delete from '+@t_name+' where ' + @f_key+' = '+''''+ @id +''''
22 exec(@sql)
23 
24 fetch cur_rows into @id,@max
25 end
26 
27 close cur_rows
28 deallocate cur_rows
29 
30 set rowcount 0
31 end
32 
33 select * from systypes
34 select * from syscolumns where id = object_id('a_dist')

View Code

3.1、怎么着删除贰个表中重复的笔录?

create table a_dist(id int,name varchar(20))

insert into a_dist values(1,'abc')
insert into a_dist values(1,'abc')
insert into a_dist values(1,'abc')
insert into a_dist values(1,'abc')

exec up_distinct 'a_dist','id'

select * from a_dist

 存储进程如下:

杏彩 5杏彩 6

 1 create procedure up_distinct(@t_name varchar(30),@f_key varchar(30))
 2 --f_key表示是分组字段﹐即主键字段
 3 
 4 as
 5 begin
 6 declare @max integer,@id varchar(30) ,@sql varchar(7999) ,@type integer
 7 select @sql = 'declare cur_rows cursor for select '+@f_key+' ,count(*) from ' +@t_name +' group by ' +@f_key +' having count(*) > 1'
 8 exec(@sql)
 9 
10 open cur_rows
11 fetch cur_rows into @id,@max
12 
13 while @@fetch_status=0
14 begin
15 select @max = @max -1
16 set rowcount @max
17 select @type = xtype from syscolumns where id=object_id(@t_name) and name=@f_key
18 if @type=56
19 select @sql = 'delete from '+@t_name+' where ' + @f_key+' = '+ @id
20 if @type=167
21 select @sql = 'delete from '+@t_name+' where ' + @f_key+' = '+''''+ @id +''''
22 exec(@sql)
23 
24 fetch cur_rows into @id,@max
25 end
26 
27 close cur_rows
28 deallocate cur_rows
29 
30 set rowcount 0
31 end
32 
33 select * from systypes
34 select * from syscolumns where id = object_id('a_dist')

View Code

补充:

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..

4)、说明:子查询(表名1:a 表名2:b)

select a,b,c from a where a IN (select d from b ) 或者: select a,b,c from a where a IN (1,2,3) 

5)、表明:显示小说、提交人和最后回复时间

select a.title,a.username,b.adddate from table a,(select max(adddate) adddate from table where table.title=a.title) b

6)、表明:外接连查询(表名1:a 表名2:b)

select a.a, a.b, a.c, b.c, b.d, b.f from a LEFT OUT JOIN b ON a.a = b.c 

7)、表达:在线视图查询(表名1:a )

select * from (SELECT a,b,c FROM a) T where t.a > 1; 

8)、表达:between的用法,between限制查询数据范围时包含了边界值,not between不饱含

select * from table1 where time between time1 and time2
select a,b,c, from table1 where a not between 数值1 and 数值2

9)、表达:in 的应用办法

select * from table1 where a [not] in (‘值1’,’值2’,’值4’,’值6’) 

10)、表达:两张关联表,删除主表中早已在副表中从不的音信

delete from table1 where not exists ( select * from table2 where table1.field1=table2.field1 )

11)、表达:四表联合检查难题

select * from a left inner join b on a.a=b.b right inner join c on a.a=c.c inner join d on a.a=d.d where ..... 

12)、表明:日程布置提早五分钟提示

SQL: select * from 日程安排 where datediff('minute',f开始时间,getdate())>5 

13)、表明:一条sql 语句化解数据库分页

select top 10 b.* from (select top 20 主键字段,排序字段 from 表名 order by 排序字段 desc) a,表名 b where b.主键字段 = a.主键字段 order by a.排序字段

14)、说明:前10条记录

select top 10 * form table1 where 范围 

15)、表明:选取在每一组b值同样的数目中对应的a最大的记录的享有消息(类似这样的用法能够用来论坛每月排名的榜单,每月销路广产品剖判,按学科成绩排名,等等.)

select a,b,c from tablename ta where a=(select max(a) from tablename tb where tb.b=ta.b) 

16)、表达:包括持有在 TableA 中但不在 TableB和TableC 中的行并消除全数重复行而派生出三个结实表

(select a from tableA ) except (select a from tableB) except (select a from tableC) 

17)、表达:随机抽出10条数据

select top 10 * from tablename order by newid() 

18)、表明:随机选拔记录

select newid()

19)、表明:删除重复记录

Delete from tablename where id not in (select max(id) from tablename group by col1,col2,...) 

20)、表达:列出数据Curry具备的表名

select name from sysobjects where type='U'

21)、说明:列出表里的富有的

select name from syscolumns where id=object_id('TableName') 

22)、表明:列示type、vender、pcs字段,以type字段排列,case能够实惠地落实多重采纳,类似select 中的case。

select type,
sum(case vender when 'A' then pcs else 0 end),
sum(case vender when 'C' then pcs else 0 end),
sum(case vender when 'B' then pcs else 0 end)
FROM tablename group by type

来得结果:

杏彩 7

type vender pcs
电脑 A 1
电脑 A 1
光盘 B 2
光盘 A 2
手机 B 3
手机 C 3

杏彩 8

23)、表达:初阶化表table1

TRUNCATE TABLE table1 

24)、说明:选择从10到15的记录

select top 5 * from (select top 15 * from table order by id asc) table_别名 order by id desc

 

重临目录

3.2、查询数据的最大排序难题(只好用一条语句写)

CREATE TABLE hard (qu char (11) ,co char (11) ,je numeric(3, 0))

insert into hard values ('A','1',3)
insert into hard values ('A','2',4)
insert into hard values ('A','4',2)
insert into hard values ('A','6',9)
insert into hard values ('B','1',4)
insert into hard values ('B','2',5)
insert into hard values ('B','3',6)
insert into hard values ('C','3',4)
insert into hard values ('C','6',7)
insert into hard values ('C','2',3)

渴求查询出来的结果如下: 

qu co je
----------- ----------- -----
A 6 9
A 2 4
B 3 6
B 2 5
C 6 7
C 3 4

就是要按qu分组,每组中取je最大的前2位,且只能用一句sql语句。

select * from hard a where je in (select top 2 je from hard b where a.qu=b.qu order by je)

3.2、查询数据的最大排序难点(只可以用一条语句写)

CREATE TABLE hard (qu char (11) ,co char (11) ,je numeric(3, 0))

insert into hard values ('A','1',3)
insert into hard values ('A','2',4)
insert into hard values ('A','4',2)
insert into hard values ('A','6',9)
insert into hard values ('B','1',4)
insert into hard values ('B','2',5)
insert into hard values ('B','3',6)
insert into hard values ('C','3',4)
insert into hard values ('C','6',7)
insert into hard values ('C','2',3)

务求查询出来的结果如下: 

qu co je
----------- ----------- -----
A 6 9
A 2 4
B 3 6
B 2 5
C 6 7
C 3 4

就是要按qu分组,每组中取je最大的前2位,且只能用一句sql语句。

select * from hard a where je in (select top 2 je from hard b where a.qu=b.qu order by je)

三、sql技巧

3.3、求删除重复记录的sql语句

什么把全数同等字段的笔录删除,只留下一条。

例如,表test里有id,name字段

假定有name同样的记录 只留下一条,别的的删除。

name的内容不定,一样的记录数不定。

==============================

多个全体的实施方案:

1)将重复的记录记入temp1表:
select [标志字段id],count(*) into temp1 from [表名]
group by [标志字段id]
having count(*)>1


2)将不重复的记录记入temp1表:
insert temp1 select [标志字段id],count(*) from [表名] group by [标志字段id] having count(*)=1

3)作一个包含所有不重复记录的表:
select * into temp2 from [表名] where 标志字段id in(select 标志字段id from temp1)

4)删除重复表:
delete [表名]

5)恢复表:
insert [表名] select * from temp2

6)删除临时表:
drop table temp1
drop table temp2

3.3、求删除重复记录的sql语句

怎么把具备同等字段的记录删除,只留下一条。

例如,表test里有id,name字段

要是有name一样的记录 只留下一条,其他的去除。

name的内容不定,同样的笔录数不定。

==============================

二个完完全全的施工方案:

1)将重复的记录记入temp1表:
select [标志字段id],count(*) into temp1 from [表名]
group by [标志字段id]
having count(*)>1


2)将不重复的记录记入temp1表:
insert temp1 select [标志字段id],count(*) from [表名] group by [标志字段id] having count(*)=1

3)作一个包含所有不重复记录的表:
select * into temp2 from [表名] where 标志字段id in(select 标志字段id from temp1)

4)删除重复表:
delete [表名]

5)恢复表:
insert [表名] select * from temp2

6)删除临时表:
drop table temp1
drop table temp2

本文由杏彩发布,转载请注明来源

关键词: