SQL格式化工具 SQL语句大全

     
 
SELECT ca.proj_id AS proj_id, ca.ca_name AS proj_name, ca.ca_date_start AS proj_start, ca.ca_date_end AS proj_end,(SELECT COUNT(*) FROM rotations r WHERE r.proj_id = proj_id AND r.r_status = 'R' GROUP BY r.proj_id) r_count, (SELECT count(*) FROM rotations r WHERE r.proj_id = proj_id AND r.channel_id = 24 ) r_rtb_count FROM projs ca, clients c, proj_auth caa WHERE ca.client_id = 12345 AND ca.client_id = c.client_id AND ca_type = 'zzz' AND c.agency_id = 0 AND ca.client_id = NVL( caa.client_id, ca.client_id ) AND proj_id = NVL( caa.proj_id, proj_id ) AND caa.contact_id = 7890

工具介绍

创建数据库

if exists (select * from sysdatabases where name='databaseName')
drop database databaseName
go
Create DATABASE databasename
on primary --默认就属于primary文件组,可省略
(
/*--数据文件的具体描述--*/
name='databasename_data', --主数据文件的逻辑名称
filename='D:databasename_data.mdf', --主数据文件的物理名称
size=10mb, --主数据文件的初始大小
maxsize=100mb, --主数据文件增长的最大值
filegrowth=10% --主数据文件的增长率
)
log on
(
/*--日志文件的具体描述,各参数含义同上--*/
name='databasename_log', -- 日志文件的逻辑名称
filename='所存目录:databasename_log.ldf', -- 日志文件的物理名称
size=数值mb, --日志文件的初始大小
filegrowth=数值mb--日志文件的增长值
)

删除数据库

   drop database databasename

备份sql server

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

创建新表

create table tabname(col1 type1 [not null] [primary key] identity(起始值,递增量)
,col2 type2 [not null],..)--primary key为主键 identity表示递增数量
根据已有的表创建新表:
go
use 原数据库名
go
select * into 目的数据库名.dbo.目的表名 from 原表名(使用旧表创建新表)
create table tab_new as select col1,col2… from tab_old definition only

创建序列

create sequence SIMON_SEQUENCE
minvalue 1 -- 最小值
maxvalue 999999999999999999999999999 -- 最大值
start with 1 -- 开始值
increment by 1 -- 每次加几
cache 20;

删除表

drop table tabname --这是将表连同表中信息一起删除但是日志文件中会有记录

删除表中信息

delete from table_name --这是将表中信息删除但是会保留这个表

增加一个列

Alter table table_name add column_name column_type [default 默认值] --在表中增加一列,[]内的内容为可选项

删除一个列

Alter table table_name drop column column_name--从表中删除一列

添加主键

Alter table tabname add primary key(col)
说明:删除主键:Alter table tabname drop primary key(col)

创建索引

create [unique] index idxname on tabname
drop index idxname on tabname   --删除索引
注:索引是不可更改的,想更改必须删除重新建。

创建视图

create view viewname as select statement
drop view viewname --删除视图

基本的sql语句

(1) 数据记录筛选:
select * from 数据表
where 字段名=字段值
order by 字段名 [desc] --按某个字段值降序排列。默认升序ASC
select * from 数据表
where 字段名 like '%字段值%'
order by 字段名 [desc]
select top 10 * from 数据表
where 字段名=字段值
order by 字段名 [desc]
select top 10 * from 数据表 order by 字段名 [desc]
select * from 数据表 where 字段名
in ('值1','值2','值3')"
select * from 数据表 where 字段名 between 值1 and 值2"
(2) 更新数据记录:
update 数据表 set 字段名=字段值 where 条件表达式"
update 数据表 set 字段1=值1,字段2=值2,字段n=值n where 条件表达式"
(3) 删除数据记录:
delete from 数据表 where 条件表达式"
delete from 数据表" --将数据表所有记录删除
(4) 添加数据记录:
insert into 数据表 (字段1,字段2,字段3) values (值1,值2,值3)"
insert into 目标数据表 select * from 源数据表" --把源数据表的记录添加到目标数据表
(5) 数据记录统计函数:
AVG(字段名) --得出一个表格栏平均值
COUNT( 字段名)  --对数据行数的统计或对某一栏有值的数据行数统计
MAX(字段名) --取得一个表格栏最大的值
MIN(字段名) 取得一个表格栏最小的值
SUM(字段名) 把数据栏的值相加
引用以上函数的方法:
select sum(字段名) as 别名 from 数据表 where 条件表达式"
select distinct * from table1  --查询去除重复值
(6) 数据表的建立和删除:
CREATE TABLE 数据表名称(字段1 类型1(长度),字段2 类型2(长度))
(7) 单列求和:
SELECT SUM(字段名) FROM 数据表