现在做IT的各个要求是全能,这个是百分之百不现实的。如何能够在最短的时间内,找到自己想要的东西。其实最好的是自己将以前看过的东西进行一个总结。现在我贴出我很早以前写的SQL帮助手册。都是很基础的东西,主要是格式。
希望对于那些业余要搞搞SQLSERVER的朋友一些帮助吧。
-------------------------------------------------------------------------------------------------
在SQL语句中 CASE 与高级语言SWITCH 适用一个条件判断有多个值的情况分别执行不同操作
case... when
commit 结束当前事务
在里面还用到了 comment on 添加注释
comment on table 添加表注释
comment on column 添加列注释
格式如下
comment on table 表名 is '注释';
主键primary key
添加格式
insert into 表名(字段名) values ('插入内容'),
添加主键
insert into 表名 primary key not null
添加主键格式2
add primary key (表名)
identity属性
作用 创建一个标识列
identity [(seed,increment)] 默认状态为identity(1,1)
--seed的作用是装在到表中第一行所使用的值
--increment 作为增量值
select max(字段名) from 表名
--判断字段名组里字段最大的值
升序和降序排列:
order by ...desc
降序排列
order by ...asc
升序排列
实例 :
select * from 表名 order by 字段 desc 从大到小排列
select * from 表名 order by 字段 asc 从小到大排列
继续实例
select 列名 from 表名 order by 字段 desc
alter 修改
alter table 表名 add 字段 date--类型
alter table 表名
删除字段
delete from 表名 where 条件
各种计算语句
select avg(字段名),max(字段名),min(字段名),sum(字段名),max(字段名)-min(字段名)
--avg 求平均数 max 最大值 min 最小值 sum 求和 max-min 求值之间
update语句
update 表名 set 字段名 where 字段名=‘ ’
求最大值max()
实例求年龄最大的员工姓名
selcet name from person where age=(select age from person where max(age))3
消息 4145,级别 15,状态 1,第 2 行
在应使用条件的上下文(在 ')' 附近)中指定了非布尔类型的表达式。 有错
as 别名
格式:
select 列名(s) from 表名 as 别名 表的语法
select 列名(s) as 别名 from 表名 列的语法
实例:
select 别名.orderID, 别名.lastname,别名.fristname from 表名 as 别名 where 别名.orderID='字段名' where 别名.lastname='字段名'
--作用在于简化编写过程。。。。。。
注意事项:
在使用alter table 表名 add 字段名 --字段名后面不能使用 not null 在添加新字段的时候必须使字段可以为空设置
添加个删除主键名
alter table book_2 add constraint 约束名 primary key(列名)
--constraint 约束 意思就是添加约束名及主键
alter table book_2 drop constraint 约束名
--删除约束名 取消主键约束
查询用昵称显示列名
select 昵称=列名 from 表名
SELECT ColumnList FROM TableA inner join tableB on linkList
用于执行TableA和TableB之间的严格约束关系,即内联关系,就是说linkList中提出的等于的约束关系,是左右对等的 比如
a.code=b.code,那么a中的code必须在b中存在并且等于
如果是Left join,那么 a.code=b.code,就是a.code未必存在于b中,如果存在,则执行对等关系
inner join内联
left join左联
right join右联
cross join交叉联
full join
on 后面跟着条件
不重复显示查询结果语句
union 和SELECT DISTINCT Date
实例:
SQL语句1 union SQL语句2
如果一个语句中存在重复信息则使用select distinct data
实例:
select distinct 列名 from 表名
使用 full join 实例
select 字段名 from 表名 full join 表名2 on 表名.字段名=表名2.字段名2
top语句
实例:
select top 排名 * from 表名
按照百分比例取条数
select top 数字 percent * from 表名
--percent 是百分数
LIKE与[]的使用实例
select 列名 from 表名 where 列名 like '[开头字母或数字]%'
以指定字母或数字开头的列名输出
select 列名 from 表名 where 列名 like '%[开头字母或数字]%'
包含有指定字母或数字的列名输出
select 列名 from 表名 where 列名 like '[!/^开头字母或数字]%'
不包含指定字母或数字的列名输出
in操作符的应用
实例说明
select * from 表名 where 列名 in ('列名包含字段')
输出结果 为制定包含字段的列名全部信息
貌似和select 包含字段的列名 from 表名 相等 在未知情况下用in解决
between范围语句
实例说明
select * from 表名 where 列名 between '范围1' and '范围2'
由于数据库处理差异不同可能存在 包含范围1 不包含 范围2 包含范围1和2 不包含范围1和2 的情况出现
inner join内联实例
select 别名.列名 from 表名 as 别名
inner join 表名2 as 别名
on 别名.主键名=别名.主键名2
group by 别名.列名
备份附件 into / into ... in
实例
select 列名/*
into 新表名
from 旧表名
select 列名/*
into 数据库名.dbo.新表名
from 数据库名.dbo.旧表名
--将旧表中的字段信息调入另一个数据库中并创建新表
SELECT 表名.列名,表名.列名
INTO 新表名
FROM 旧表名
INNER JOIN 列名
ON 表名.主键名=表名2.主键名
--为新表添加旧表中的特定信息
date类型
integer(size)
int(size)
smallint(size)
tinyint(size)
仅容纳整数。在括号内规定数字的最大位数。
decimal(size,d)
numeric(size,d)
容纳带有小数的数字。
"size" 规定数字的最大位数。"d" 规定小数点右侧的最大位数。
char(size) 容纳固定长度的字符串(可容纳字母、数字以及特殊字符)。
在括号中规定字符串的长度。
varchar(size) 容纳可变长度的字符串(可容纳字母、数字以及特殊的字符)。
在括号中规定字符串的最大长度。
date(yyyymmdd) 容纳日期。
not null 如果不想字段中插入数值就无法更新和插入新数据
unique 添加约束 每个表可以添加多条约束 但是 主键 primary key 只能增加一条
删除约束
实例:
alter 表名 drop constraint 列名
外键设置
了解外键作用:
1. FOREIGN KEY 约束用于预防破坏表之间连接的动作。
2. FOREIGN KEY 约束也能防止非法数据插入外键列,因为它必须是它指向的那个表中的值之一。
实例:
CREATE TABLE 表名
(
列名 int NOT NULL PRIMARY KEY,
列名 int NOT NULL,
列名 int FOREIGN KEY REFERENCES 表名1(主键名)
)
check 约束
对表和列进行约束 约束范围是限定列的值
实例:
CREATE TABLE 表名
(
列名 int NOT NULL check (列名>0),
列名 int NOT NULL,
列名 int NOT NULL,
)
--check>0表示列名值必须大于零才能被输入
CREATE TABLE 表名
(
列名 date NOT NULL,
列名 date NOT NULL,
列名 date,
列名 date,
列名 date,
CONSTRAINT 约束名 CHECK (约束条件)
)
--命名约束和 定义多个约束
alter table 表名 add check (列名条件)
--为存在的列名添加check 约束
alter table 表名 add constraint 约束名 check (列名条件)
--添加约束名和约束条件
default约束
说明:default 约束用于向列中插入默认值,如果没有其他规定则向新纪录插入默认值
getdate()参数 可以用于插入系统值
实例
orderdate date default getdate()
index索引
创建一个索引
实例:
create index 索引名
on 表名(列名)
删除索引
drop index 表名.索引名
显示与特定时间所查天数
Select datediff (day,getdate(),'2008-08-08')
建立check约束
格式:alter table 表名 add constraint 约束名 check(列名 约束条件)
实例:alter table book_2 add constraint aaaa check(b_sn between 1 and 100)
identity关键字 执行auto-increment命令
用法
create table 表名
(
列名 date primary key identity,
列名 date not null,
)
--默认地,IDENTITY 的开始值是 1,每条新纪录递增 1。
要规定 "P_Id" 列以 20 起始且递增 10,请把 identity 改为 IDENTITY(20,10)。
date函数
GETDATE() 返回当前日期和时间
DATEPART() 返回日期/时间的单独部分
DATEADD() 在日期中添加或减去指定的时间间隔
DATEDIFF() 返回两个日期之间的时间
CONVERT() 用不同的格式显示日期/时间
SQL Server 使用下列数据类型在数据库中存储日期或日期/时间值:
DATE - 格式 YYYY-MM-DD
DATETIME - 格式: YYYY-MM-DD HH:MM:SS
SMALLDATETIME - 格式: YYYY-MM-DD HH:MM:SS
TIMESTAMP - 格式: 唯一的数字
NULL函数
我们可以当它为占位符
在执行的时候我们使用IS NULL
实例:
select 列名
from 表名
where 列名 is null / where 列名 not is null
null在计算方面
实例:
SELECT 列名,含整型字段的列名*(含整型字段的列名2 +ISNULL(含整型字段的列名3,0))
FROM Products
--这里isnull的作用是将 为空的字段 以0表示 方便计算
数据类型
Character 字符串:
数据类型 描述 存储
char(n) 固定长度的字符串。最多 8,000 个字符。 n
varchar(n) 可变长度的字符串。最多 8,000 个字符。
varchar(max) 可变长度的字符串。最多 1,073,741,824 个字符。
text 可变长度的字符串。最多 2GB 字符数据。
Unicode 字符串:
数据类型 描述 存储
nchar(n) 固定长度的 Unicode 数据。最多 4,000 个字符。
nvarchar(n) 可变长度的 Unicode 数据。最多 4,000 个字符。
nvarchar(max) 可变长度的 Unicode 数据。最多 536,870,912 个字符。
ntext 可变长度的 Unicode 数据。最多 2GB 字符数据。
Binary 类型:
数据类型 描述 存储
bit 允许 0、1 或 NULL
binary(n) 固定长度的二进制数据。最多 8,000 字节。
varbinary(n) 可变长度的二进制数据。最多 8,000 字节。
varbinary(max) 可变长度的二进制数据。最多 2GB 字节。
image 可变长度的二进制数据。最多 2GB。
Number 类型:
数据类型 描述 存储
tinyint 允许从 0 到 255 的所有数字。 1 字节
smallint 允许从 -32,768 到 32,767 的所有数字。 2 字节
int 允许从 -2,147,483,648 到 2,147,483,647 的所有数字。 4 字节
bigint 允许介于 -9,223,372,036,854,775,808 和 9,223,372,036,854,775,807 之间的所有数字。 8 字节
decimal(p,s) 固定精度和比例的数字。允许从 -10^38 +1 到 10^38 -1 之间的数字。
p 参数指示可以存储的最大位数(小数点左侧和右侧)。p 必须是 1 到 38 之间的值。默认是 18。
s 参数指示小数点右侧存储的最大位数。s 必须是 0 到 p 之间的值。默认是 0。
5-17 字节
numeric(p,s) 固定精度和比例的数字。允许从 -10^38 +1 到 10^38 -1 之间的数字。
p 参数指示可以存储的最大位数(小数点左侧和右侧)。p 必须是 1 到 38 之间的值。默认是 18。
s 参数指示小数点右侧存储的最大位数。s 必须是 0 到 p 之间的值。默认是 0。
5-17 字节
smallmoney 介于 -214,748.3648 和 214,748.3647 之间的货币数据。 4 字节
money 介于 -922,337,203,685,477.5808 和 922,337,203,685,477.5807 之间的货币数据。 8 字节
float(n) 从 -1.79E + 308 到 1.79E + 308 的浮动精度数字数据。参数 n 指示该字段保存 4 字节还是 8 字节。float(24) 保存 4 字节,而 float(53) 保存 8 字节。n 的默认值是 53。 4 或 8 字节
real 从 -3.40E + 38 到 3.40E + 38 的浮动精度数字数据。 4 字节
Date 类型:
数据类型 描述 存储
datetime 从 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度为 3.33 毫秒。 8 bytes
datetime2 从 1753 年 1 月 1 日 到 9999 年 12 月 31 日,精度为 100 纳秒。 6-8 bytes
smalldatetime 从 1900 年 1 月 1 日 到 2079 年 6 月 6 日,精度为 1 分钟。 4 bytes
date 仅存储日期。从 0001 年 1 月 1 日 到 9999 年 12 月 31 日。 3 bytes
time 仅存储时间。精度为 100 纳秒。 3-5 bytes
datetimeoffset 与 datetime2 相同,外加时区偏移。 8-10 bytes
timestamp 存储唯一的数字,每当创建或修改某行时,该数字会更新。timestamp 基于内部时钟,不对应真实时间。每个表只能有一个 timestamp 变量。
其他数据类型:
数据类型 描述
sql_variant 存储最多 8,000 字节不同数据类型的数据,除了 text、ntext 以及 timestamp。
uniqueidentifier 存储全局标识符 (GUID)。
xml 存储 XML 格式化数据。最多 2GB。
cursor 存储对用于数据库操作的指针的引用。
table 存储结果集,供稍后处理。
数据库服务器
DBMS - 数据库管理系统(Database Management System)
数据库管理系统是一种可以访问数据库中数据的计算机程序。
DBMS 使我们有能力在数据库中提取、修改或者存贮信息。
不同的 DBMS 提供不同的函数供查询、提交以及修改数据。
RDBMS - 关系数据库管理系统(Relational Database Management System)
关系数据库管理系统 (RDBMS) 也是一种数据库管理系统,其数据库是根据数据间的关系来组织和访问数据的。
20 世纪 70 年代初,IBM 公司发明了 RDBMS。
RDBMS 是 SQL 的基础,也是所有现代数据库系统诸如 Oracle、SQL Server、IBM DB2、Sybase、MySQL 以及 Microsoft Access 的基础。
AVG的运用
--AVG 平均值
实例:
select avg(列名) from 表名
--求列的平均值
select 列名 from 表名 where 列名>(select AVG(列名) from 表名)
--列出大于平均数的字段名 比如列出年龄大于平均数的 人的姓名
其他的比如MAX和MIN 大家举一反三
count的运用
--count 表中所占的数列
实例:
select count(列名) from 表名
--指定的列名下字段的列数
select count(列名) from 表名 where 列名='字段名'
还有求偶数
%2=0
求奇数
%2=1
select 列名 from 表名 where 列名%2=0
group by 分组
--适合于分与求和差等计算式的常用
实例:select 列名1 sun(列名2) from 表名 group by 列名1
--结果进行分组求和。
分组求和
按照个人习惯写的 使用having 函数 加在group by后面 做为合计函数的条件语句
加having实例:
select 列名 sum(列名2)
from 表名
where 列名='字段名'
group by 列名
having sum(列名)>指定数值
--where 不能作为合计函数条件的时候用having 设置合计函数条件使用
大小写转化
ucase()
--这个很简单 点下就行了
select ucase(列名) as 列名 from 表名
--将列名转化成大写
lcase()
--转化成小写
select lcase(列名) as 列名 from 表名
len()函数
--提取列中字段所占长度
实例:
select len(列名) as 别名 from 表名
getdate()显示时间语句
实例:
select getdate() 列名 from 表名
知识点: TRUNCATE 删除表中的所有行,而不记录单个行删除操作,不能带条件
STATISTICS 显示磁盘活动量的信息。
+在程序里面是连接的意思 比如 ['+tablename+'] 是用来表示字符串
@PageSize int =5
--页面大小
@TotalCount int out
--总共的列
sp_executesql
执行可以多次重用或动态生成的 Transact-SQL 语句或批处理。Transact-SQL 语句或批处理可以包含嵌入参数。
语法
sp_executesql [@stmt =] stmt
[
{, [@params =] N'@parameter_name data_type [,...n]' }
{, [@param1 =] 'value1' [,...n] }
]
参数
[@stmt =] stmt
包含 Transact-SQL 语句或批处理的 Unicode 字符串,stmt 必须是可以隐式转换为 ntext 的 Unicode 常量或变量。不允许使用更复杂的 Unicode 表达式(例如使用 + 运算符串联两个字符串)。不允许使用字符常量。如果指定常量,则必须使用 N 作为前缀。例如,Unicode 常量 N'sp_who' 是有效的,但是字符常量 'sp_who' 则无效。字符串的大小仅受可用数据库服务器内存限制。
简单的单表分页
use zyx
go
SELECT TOP 3 *
FROM
(
SELECT ROW_NUMBER() OVER (ORDER BY b_id) AS RowNumber,* FROM book
) A
WHERE RowNumber > 3*(2-1)
RANK ( ) OVER ( [query_partition_clause] order_by_clause )
DENSE_RANK ( ) OVER ( [query_partition_clause] order_by_clause )
可实现按指定的字段分组排序,对于相同分组字段的结果集进行排序,
其中PARTITION BY 为分组字段,ORDER BY 指定排序字段
rank,row_number,desc_rank的区别
--rank根据order by的排名会出现并列的现象,在排名顺序时出现1,2,3,4,4,6,7,7,9
--desc_rank根据order by的排名会出现并列现象,但是不会不会跳过显示1,2,2,3,3,4,4
--row_number根据order by的排名不会出现并列现象1,2,3,4,5,6,7
实例
use zyp
declare @table table (b_sn varchar(50),b_name varchar(50), b_id int,count int)
insert @table
select b_sn,b_name,b_id,count(b_id) from book_2 as c
group by b_sn,b_name,b_id
select c.b_sn,c.b_name,min(c.b_id)
from
(
select a.b_sn,a.b_name,b.b_id from
(
select b_sn,b_name,max(count) as Cou from @table
group by b_sn,b_name
) as a
inner join @table as b
on a.b_sn=b.b_sn and a.b_name=b.b_name and a.cou=b.count
) as c
group by c.b_sn,c.b_name
--查询出现频率最多的分组记录(取最小值)
刚刚写的简单的动态删除记录的存储过程
create proc pghh
(
@b_sn varchar(50),@tablename varchar(50)
)
as
declare @sql varchar(50)
set @sql= ' delete ' +'from '+ @tablename + ' where '+' b_sn =''' + @b_sn+''''
exec(@sql)
exec pghh '3453', 'book_2'
实例学习下
if(@shth='' and @djh='')
begin
--取不同的发票号
create table #tmp(hh int identity(1,1),fpno varchar(20))
insert into #tmp(fpno)
select distinct(fpno) from yyjs
where ywlxdm=@ywlxdm
and (len(@dwdm)<=7 and zddm like @dwdm+'%'
or len(@dwdm)=8 and left(dwdm,8)=@dwdm
or len(@dwdm)=9 and zddm+fjh=@dwdm
or len(@dwdm)=10 and left(dwdm,10)=@dwdm
or len(@dwdm)=14 and dwdm=@dwdm)
and (comm=0 or comm=3)
and crq>=@crq1 and crq<=@crq2
and (@djlx='1'
or @djlx='2' and zyno='999999'
or @djlx='3' and zyno='999998'
or @djlx='4' and zyno not like '9%')
order by fpno
--计算出按@PageCount分页后共有多少页
declare @PageSize1 decimal(18,2)
select @PageSize1=cast(@PageSize as varchar(10))+'.00'
select @PageCount=ceiling(count(*)/@PageSize1) from #tmp
select @fpzs=count(*) from #tmp --------------------------------总的发票张数
select @yxzs=count(distinct(fpno)) from yyjs where
ywlxdm=@ywlxdm
and (len(@dwdm)<=7 and zddm like @dwdm+'%'
or len(@dwdm)=8 and left(dwdm,8)=@dwdm
or len(@dwdm)=9 and zddm+fjh=@dwdm
or len(@dwdm)=10 and left(dwdm,10)=@dwdm
or len(@dwdm)=14 and dwdm=@dwdm)
and (comm=0 or comm=3)
and crq>=@crq1 and crq<=@crq2
and c2=''
and (@djlx='1'
or @djlx='2' and zyno='999999'
or @djlx='3' and zyno='999998'
or @djlx='4' and zyno not like '9%')---------------------有效发票张数
set @chzs=@fpzs-@yxzs -------------------------------------------冲红张数
insert into T_sum_SGQDCXTB
(YHDM,YWLXDM,DWDM,DWMC,FPH,CZDM,CZMC,HTH,SHTH,FZXM,CRQ,ZL,JE,KMBT,PZBT,KKJE,N3,SFJE,KPLX,CHBZ,SGX)
select @yhdm,@ywlxdm,zddm+fjh as zddm,'',fpno,dwdm,'',hth,'',fzxm,left(crq,4)+'-'+substring(crq,5,2)+'-'+right(crq,2),isnull(sum(zl),0),isnull(sum(je),0),
isnull(sum(bzje),0),isnull(sum(n2),0),isnull(sum(kkje),0),isnull(sum(n3),0),sum(je)+sum(bzje)+sum(n2)-sum(kkje)-sum(n3),
case zyno when '999999' then '主机开票' when '999998' then '手工开票' else '补录发票' end,c2,fjh
from yyjs
where ywlxdm=@ywlxdm
and (len(@dwdm)<=7 and zddm like @dwdm+'%'
or len(@dwdm)=8 and left(dwdm,8)=@dwdm
or len(@dwdm)=9 and zddm+fjh=@dwdm
or len(@dwdm)=10 and left(dwdm,10)=@dwdm
or len(@dwdm)=14 and dwdm=@dwdm)
and (comm=0 or comm=3)
and crq>=@crq1 and crq<=@crq2
and (@djlx='1'
or @djlx='2' and zyno='999999'
or @djlx='3' and zyno='999998'
or @djlx='4' and zyno not like '9%')
and(@hth=''
or hth like '%'+@hth)
and fpno in (select fpno from #tmp where ceiling(hh/@PageSize1)=@Page)
group by zddm,fpno,dwdm,hth,fzxm,crq,zyno,c2,fjh
--处理完成后删除临时表
drop table #tmp
end
实例:
create proc phoo111
(
@hs1 varchar(50),@b_id varchar(50),@tablename varchar(50),@rownumber varchar(50),@ys1 varchar(50),@ys2 varchar(50)
)
as
declare @sql varchar(200)
set @sql='select'+' top ' + @hs1+'*'+ ' from'+ ' (select row_number() over (order by '+@b_id+') as rownumber,* from '+@tablename+') A where '+ @rownumber+ '>'+ @hs1+'*('+@ys1+'-'+@ys2+')'
exec (@sql)
简单的动态分页存储过程
增加rollback 回滚和commit 提交事务实例
实例是为现实效果 可以改下 看下效果
begin tran
declare @1 varchar(50)
declare @sql varchar(100)
set @1=1
while @1<=100
begin
-- select @sql= b_id from book_3
print @1
set @1 =@1+ 1
end
if @1=1
rollback tran
else
print 'noooo'
-------------------------------------------------------------------------------------------------
不多贵在是自己总结的,多少当时也有一点成就感。谢谢各位赏脸了!