蜀山赵氏SQL手册

现在做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'

-------------------------------------------------------------------------------------------------

不多贵在是自己总结的,多少当时也有一点成就感。谢谢各位赏脸了!

 


 

你可能感兴趣的:(数据库,sqlserver,sql语句,休闲,数据库文档)