`
weitao1026
  • 浏览: 1057980 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论
阅读更多

  本人经常使用Sql Server数据库,总结了一些常用的Sql Server语法含增删查改,存储过程,触发器等语法。提供新手学习及语法查找,文件简短,省去大量查找资料时间,不足之处有待完善。

                                      
                                                                  --常用Sql Server 语法大全
--建数据库命令
if exists (select * from sys.databases where name='test')
drop database test       --如存在相同名称数据库则删除数据库
Go
create database test on primary(
name=N'test',            --数据库名称
filename=N'D:\test.mdf', --文件地址
size=3MB,                --初始大小3MB(不能小于3MB)
maxsize=unlimited,       --文件最大容量值
filegrowth=1MB           --文件增长率
)
log on                   --数据库日志文件
(
name=N'test_log',        --日志文件名称
filename=N'D:\test_log.ldf',--日志文件地址
size=1MB,                --日志文件初始大小1MB
maxsize=1GB,             --日志文件最大容量值
filegrowth=10%           --日志文件增长率
)
                               --数据类型
--bit--smallint--int --char--float--double
--nchar--datetime--smalldatetime--varchar--nvarchar--image
--money--smallmoney--binary--varbinary--text--decimal(3,3)
--建表
if exists(select * from sys.objects where name='mytest' and type='U')
drop table mytest
go
create table mytest
(
id int identity(1,1) primary key,         --主键自增
[name] varchar(50) unique,                --唯一值不能重复
[sex] varchar(2) not null default('男'),  --默认为’男‘
address varchar(343) not null,            --不能为空
age smallint check(age<120 and age>0),     --约束不能大于120小于0岁
date datetime
)
insert into mytest([name],[sex],address,age,date) values('yi','男','于璐璐',39,getdate())
insert into mytest([name],[sex],address,age,date) values('yib','男','于璐璐',3,getdate())
insert into mytest([name],[sex],address,age,date) values('yibi','女','于璐璐',34,getdate())
insert into mytest([name],[sex],address,age,date) values('yibin','女','于璐璐',25,getdate())
insert into mytest([name],[sex],address,age,date) values('yibing','男','易津锐',30,getdate())
insert into mytest([name],[sex],address,age,date) values('yibing2','男','易津锐',26,getdate())
insert into mytest([name],[sex],address,age,date) values('y2','男','津锐',26,getdate())

go
--显示年龄在20-30之间的信息
select * from mytest where id not in(select id from mytest where age<30 and age>20)
select * from mytest where id not in(select id from mytest where age between 20 and 30)


--显示重复的记录方法一

select count(*) 相同个数 address from mytest group by address having count(address)>1
--显示重复的记录方法二

select a.* from mytest a where exists(
select 1 from mytest b where a.id<>b.id and a.address=b.address )

--显示重复的记录方法三
select distinct t.id,t.[name], max(t.address) from mytest t, mytest t2
group by t.id,t2.id,t.address,t2.address,t.[name] having t.id<>t2.id and t.address=t2.address

--显示重复的记录方法四
select distinct t1.* from mytest t1,mytest t2 where t1.id<>t2.id and t1.address=t2.address
--select * from 表名
--GROuP BY  姓名
--HAVING COUNT(姓名)>=2
--显示重复的记录方法五

select * from mytest where
--显示重复的记录个数方法
select count(*) 相同个数,a.address from (select t.* from mytest t where exists(select id from mytest t2 where t.id<>t2.id and t.address=t2.address))as a
group by a.address
--显示自定义序列号
select row_number() over(order by date ) 序列号,* from mytest

select * from mytest t1 where exists(select 1 from mytest t2 where t1.id<>t2.id and t1.address=t2.address)

select * from mytest where address like'_津%'      --模糊查询%%,_%,%_
select * from mytest where date between'2011-09-22 16:01:07.678' and '2011-09-29' --规定范围之间取值
select * from mytest where date >'2011-09-25 16:01:07.678' and date<'2011-09-26' --规定范围之间取值
select distinct * from mytest                      --distinct消除重复记录
select * from mytest order by id asc               --升序
select * from mytest order by id desc              --降序
select id,sex,age,count(*) as 个数,address from mytest group by sex,age,address,id
having id='1'  --分组
                              --数据查询
select t.*,t2.* from mytest t left join mytest t2 on t.id=t2.id--左连接
select t.*,t2.* from mytest t right join mytest t2 on t.id=t2.id--右连接
select t.*,t2.* from mytest t full join mytest t2 on t.id=t2.id--完全连接
select * from mytest where id not in(select id from mytest where id>2 and sex='女')--字查询
select * from mytest where id in(select id from mytest where id>2 and sex='女')--字查询
select * from mytest where exists(select id from mytest where id>2 and sex='女')--字查询
select * from mytest where not exists(select id from mytest where id>2 and sex='女')--字查询
select * from mytest where id < any(select id from mytest where id>2 and sex='女')--字查询
select * from mytest where id < all(select id from mytest where id>2 and sex='女')--字查询
< any--小于查询结果的某个值  >=any <=any <>any >any
< all--小于查询结果的所有值  >=all <=all <>all >all
select * from mytest union select * from mytest
--联合查询,自动过滤重复值,获取两表的并集,按第一列进行排序,合并两表的数据,前提两表结构必须相同
select * from mytest union all select * from mytest--联合查询,不过滤重复值,不排序
select * from mytest intersect select * from mytest
--联合查询,自动过滤重复值,获取两表的交集,同时存在的数据,进行排序
select id,[name],[sex],address,age into mytest3 from mytest
--select into语法,将mytest表复制备份到mytest3表中
--行列转换
select * from mytest3
--方法一case函数
select id,address,age,
   (case sex when '男' then [name] else'' end) 男,
   (case sex when '女' then [name] else'' end) 女
from mytest
--方法一case函数
select id,address,age,
   (case  when sex='男' then [name] else'' end) 男,
   (case  when sex='女' then [name] else'' end) 女
from mytest
--方法二pivot函数
select * from mytest pivot(max([name]) for sex in(男,女))a
--方法三left join左连接
select r.id,address,age,男,女 from mytest r
left join
(select id,[name] as 男 from mytest where sex='男') t on r.id=t.id
left join
(select id,[name] as 女 from mytest where sex='女') t2 on r.id=t2.id


                                --高级T_sql
--定义变量
declare @str varchar(30)
set @str='123'     --赋值
print @str         --打印输出
select @str        --表形式输出
--全局变量@@形式
 select @@identity
 select @@connections
--函数
select abs(-23.44)    --取绝对值23.44
select ceiling(34.56) --返回大于等于参数的最小整数35
select floor(34.56)   --返回小于等于参数的最大整数34
select round(2312.32534,2)--四舍五入运算,2为保留的小数位2312.33000
--字符串
select ltrim(' 234')  --去掉左边空格
select charindex('a','s3dda33')--返回字符'a'在字符串's3dda33'中的位置5,从1开始计数
select len('234wefwef')--返回字符串的长度9
select substring('we我rweff',3,5)--从字符串位置3开始截取5个字符返回'我rwef'
select stuff('we我rweff',3,5,'已替换掉了')--从字符串位置3开始替换五个后面参数的字符输出‘we已替换掉了f’
--时间函数
--datepart时间参数表达式
--yy,yyyy(1753-9999)--年份
--qq,q   (1-4)--季度
--mm,m   (1-12)月份
--dy,y   (1-366)一年的第几天
--dd,d   (1-31)一月的第几天
--wk,ww  (1-7)星期几
--hh     (0-23)小时
--mi,n   (0-59)分钟
--ss,s   (0-59)秒
--ms     (0-999)毫秒
select getdate()    --获得当前时间
select dateadd(yy,3,'2011-2-2')--为yy年份添加整数3输出2014-02-02 00:00:00.000
select dateadd(mm,3,'2011-2-2')--为mm月份添加整数3输出2011-05-02 00:00:00.000
--时间差函数
select datediff(yy,'1922-1-3','2011-2-3')--返回两个时间参数的年份的时间差输出89
select datediff(mm,'1922-1-3','2011-2-3')--返回两个时间参数的月份的时间差输出1069
select datename(yyyy,'2011-2-3')         --返回年份
select datename(mm,'2011-2-3')           --返回月份
select datename(ww,'2011-2-3')           --返回星期几
select datepart(ss,'2011-2-3 23:44:09')  --返回秒整数
select day('2011-2-3 23:44:09')          --返回天数
select month('2011-2-3 23:44:09')        --返回月数
select year('2011-2-3 23:44:09')         --返回年数
--系统函数
select cast(233.44 as int)--cast函数强制将整数233.44转换整数233输出
select convert(varchar,getdate(),101) as '101'--convert将时间转换为字符输出
--聚合函数
 sum(),max(),min(),avg(),count(),
begin
end--程序运行范围
--case 表达式语法
select distinct id,address,age,
   (case sex when '男' then [name] else'' end) 男,
   (case sex when '女' then [name] else'' end) 女
from mytest
                             --建立视图
create view v_test
as
select *from mytest --建立视图v_test
                             --建立索引
create index sex on mytest(sex)--在mytest表的sex字段上建立了索引
create unique index id on mytest(id)--在mytest表的id字段上建立了唯一索引
create clustered index sex2 on mytest(id)--在mytest表的id字段上建立了聚集索引
create nonclustered index sex3 on mytest(id)--在mytest表的id字段上建立了非聚集索引
                             --建立存储过程
if exists(select 1 from sys.objects where [name]='insertest' and type='P')
drop procedure insertest
go
create procedure insertest
   @name varchar(30),
   @sex varchar(2)='男',   --默认值为男
   @address varchar(200),
   @age int=25             --指定默认值为25
as
begin
   insert into mytest([name],[sex],address,age) values(@name,@sex,@address,@age)
end
go
exec insertest '李利利','男','榆林路93弄2号211室',90  --exec执行存储过程
                          --返回类型的存储过程
go
if exists(select 1 from sys.objects where [name]='insertest2' and type='P')
drop procedure insertest2
go
create procedure insertest2
   @name varchar(30),
   @sex varchar(4)='男',   --默认值为男
   @address varchar(200),
   @age int=25,            --指定默认值为25
   @id int output         --定义返回类型
as
begin
   insert into mytest([name],[sex],address,age) values(@name,@sex,@address,@age)
   set @id=@@identity      --将自增字段数据赋值给@id并返回  
end
go
declare @putid int
exec insertest2 '王利利','男','XX路',90,@putid output  --exec执行存储过程
print cast(@putid as varchar)                  --将@putid转换为varchar输出             
                            --带事务存储过程
go
if exists(select 1 from sys.objects where [name]='insertest3' and type='P')
drop procedure insertest3
go
create procedure insertest3
   @name varchar(30),
   @sex varchar(2)='男',   --默认值为男
   @address varchar(200),
   @age int=25,            --指定默认值为25
   @id int output          --定义返回类型
as
begin try                  --开始监视程序
   begin tran              --准备事务
    insert into mytest([name],[sex],address,age) values(@name,@sex,@address,@age)
    set @id=@@identity     --将自增字段数据赋值给@id并返回  
   commit tran             --不出错则提交事务
end try                    --结束监视程序
begin catch  
   set @id=-1             --程序出错处理开始
   rollback tran           --程序出错则回滚事务,不执行插入表sql语句
end catch                  --程序出错处理结束

                           --建立触发器
--inserted表,在执行(插入)insert或(更新)update时之前保留的一个副本
--deleted表,存储在(删除)delete或(更新)update时保留所删除数据的一个副本

--                  inserted表与deleted表的关系图

--触发器类型   |         inserted表              |          deleted表
--insert      | 存储所插入的记录的副本           |            无
--update      | 存储更新了的记录的副本           |  存储更新前的原始记录的副本
--delete      |        无                       |  存储所删除的原始记录的副本

if exists(select * from sys.all_objects where [name]='triggtest' and [type]='TR')
drop trigger triggtest
go
create trigger triggtest
on mytest                   --触发器建立对象在mytest表上
for insert,update,delete    --建立插入,修改,删除类型触发器
as
begin
    delete from trigtesttab --先删除监视表trigtesttab
    insert into trigtesttab --插入数据
    select count(name),avg(age),getdate() from mytest
    group by age            --age分组
end
  --测试语句
  insert into mytest([name],[sex],address,age) values('pt58','h','t',55)
  delete from mytest where id='1'

--建立触发器状态监视表
create table trigtesttab
(
namecount int,
ageavg int,
date datetime
)
select * from mytest
select * from trigtesttab
                            --建立列级触发器
if exists(select * from sys.all_objects where [name]='triggtest2' and [type]='TR')
drop trigger triggtest2
go
create trigger triggtest2
on mytest                   --触发器建立对象在mytest上
for update                  --建立修改触发器  
as
if update([name])           --在[name]字段上建立列级修改触发器
begin
  print'不能修改[name]列'
  rollback tran
end
--测试
update mytest  set [name]='123' where id='3'    --无法修改成功

--删除具有主外键关系的触发器
create table tuser
(
id int primary key identity(1,1),
uname varchar(50),
utele varchar(100)
)
go
create table torder
(
id int primary key identity(1,1),
pname varchar(50),
price decimal(5,2),
number int,
tuser_id int foreign key  references tuser(id)--ON DELETE CASCADE 加上关键字可自动连级删除
)
go
insert into tuser values('yi','1342424425')
insert into tuser values('yibin','13436546747')
insert into tuser values('yijinrui','13436546747')
go
insert into torder values('net编程','213','1',1)
insert into torder values('PHP编程','123','1',1)
insert into torder values('Java编程','323','1',2)
insert into torder values('Vb编程','323','1',2)
insert into torder values('jQuery编程','323','2',2)
go
select * from torder
select * from tuser
go
select uname,pname,price,number from torder,tuser where torder.tuser_id=tuser.id

go
create procedure insertuser
   @uname varchar(50),
   @utele varchar(100)
as
   insert into tuser values(@uname,@utele)
go
exec insertuser 'li','11133544'
go
drop trigger deletetuser on tuser
instead of delete         --建立instead of类型的delete触发器替代delete执行语句
as
declare @uid int          --定义tuser的id变量
begin  try
 select @uid=id from deleted   --获得删除tuser表的id
 delete from torder where tuser_id=@uid  --删除torder表的引用id号@uid
 delete from tuser where id=@uid     --执行主表的删除动作
end try
begin catch
   rollback tran
end catch
go
--测试
delete from torder where id=1
delete from tuser where id=1
go
year | quarter | month | week | day | hour | minute | second | millisecond
declare @date varchar,@date2 varchar
set @date='2011-2-12 6:34:06'
set @date2='2012-12-10'
select cast(datediff(year,@date,@date2) as varchar)+'年'+
       cast(datediff(month,'2011-2-12 6:34:06','2012-12-10') as varchar)+'月'+
       cast(datediff(day,'2011-2-12 6:34:06','2012-12-10') as varchar)+'天'+
     cast(cast(datediff(hour,'2011-2-12 6:34:06','2012-12-10') as int)%24 as varchar)+'小时'+
     cast(cast(datediff(minute,'2011-2-12 6:34:06','2012-12-10') as int)%60 as varchar)+'分'+
     cast(cast(datediff(second,'2011-2-12 6:34:06','2012-12-10') as int)%60 as varchar)+'秒'
 as 时间差 from tuser

分享到:
评论

相关推荐

    SQL Server语法大全

    根据提供的文件信息,本文将对SQL Server中的数据操纵语言(Data Manipulation Language, DML)与数据定义语言(Data Definition Language, DDL)的关键概念及其语法进行深入解析。以下是对这些概念的详细解释: ##...

    SqlServer常用语法[参考].pdf

    SqlServer常用语法 Sql Server是一种关系型数据库管理系统,具有强大的数据存储和管理功能。为了更好地使用SqlServer,需要掌握一些基本的语法和约束。 一、约束种类 在SqlServer中,约束是一种限制或规则,用于...

    SQL Server 到 Oracle 的SQL 语法自动翻译器源码

    该转换过程负则将SQL Server的 一些语法特性翻译为Oracle支持的形式,也包括常用的函数, 支持复杂的SQL,例如嵌套/子查询等。 这是小弟为了一个Oracle项目的应急之作,我们的系统(Delphi的三层架构)一直运行...

    sql server语法笔记整理

    SQL Server是一种广泛使用的关系型数据库管理系统,由微软公司开发,提供了强大的数据...经典SQL语句大全.doc和SQL语法基础.doc文档将更深入地探讨这些概念,提供丰富的实例和练习,助你在SQL Server的世界里游刃有余。

    sqlserver2005的常用语法

    以下是一些关于SQL Server 2005常用语法的关键知识点: 1. **数据库安装**:安装SQL Server 2005涉及一系列步骤,包括选择安装类型(如企业版、标准版等)、配置服务器实例、设置网络协议和身份验证模式,以及安装...

    Mysql和Sqlserver常用功能语法比对

    Mysql和Sqlserver常用功能语法比对,了解两个数据库功能区别

    SQL SERVER 语句大全.rar

    这个"SQL SERVER 语句大全.rar"压缩包文件很可能包含了关于SQL Server中各种常用查询语句、数据操作、事务处理、索引管理、视图创建等核心知识点的详细资料。 一、SQL Server基本语法 SQL Server支持标准的SQL语法...

    ORACLE与SQLSERVER中的语法区别

    ORACLE 与 SQL SERVER 中的语法区别 在数据库管理系统中,ORACLE 和 SQL Server 是两个常用的关系数据库管理系统。虽然它们都使用 SQL 语言,但是它们之间存在一些语法上的区别。这篇文章将详细介绍 ORACLE 和 SQL ...

    常用sqlserver知识讲解

    ### 常用SQL Server知识讲解 #### 一、系统数据类型详解 SQL Server提供了丰富的数据类型以满足不同场景下的需求。以下是对SQL Server中几种常用数据类型的详细介绍: ##### 1. 整数数据类型 整数数据类型是SQL ...

    SQLServer与Oracle语法差异汇总.docx

    在SQL Server中,虽然不常用,但也可以实现类似功能,只是没有内置的`DUAL`表。 总的来说,Oracle和SQL Server在语法上的差异反映了它们设计理念的不同,了解这些差异对于开发人员在跨平台的数据库操作中至关重要,...

    SQL Server 和 MySql 语法和关键字的区别——用于SQLServer到MySql的转换

    SQL Server 和 MySql 语法和关键字的区别——用于 SQLServer 到 MySql 的转换 SQL Server 和 MySql 是两种常用的关系型数据库管理系统,但是它们之间存在一定的语法和关键字差异。这些差异使得开发者在从 SQL ...

    Access与sql_server_语法差异.doc

    Access 和 SQL Server 都是常用的数据库管理系统,但它们在语法上存在一些差异,本文将对 Access 和 SQL Server 的语法差异进行总结和比较。 日期函数 Access 中的 Date() 函数对应 SQL Server 中的 getdate() ...

    SQLserver常用语句大全

    SQL Server 常用语句大全 本资源摘要信息涵盖了 SQL Server 中常用的语句大全,包括数据操作、数据定义、数据控制、事务控制、程序化 SQL 等方面的知识点。 一、数据操作 * SELECT 语句:从数据库表中检索数据行...

    SQL语法大全中文版.rar_sql_sql 语法_sql server_sql 语法_sql语法

    以下是对SQL语法大全中文版的一些核心知识点的详细阐述: 1. **数据定义语言(DDL)**:这部分包括创建、修改和删除数据库对象的语句。例如,`CREATE DATABASE`用来创建新的数据库,`ALTER TABLE`用于修改已有表的...

    sql server客户端连接工具

    1. **SQL Server Management Studio (SSMS)**:这是最常用的SQL Server客户端工具,它集成了数据库管理、查询、设计和调试等多种功能。SSMS提供了一个集成环境,用户可以编写、测试和执行T-SQL语句,管理数据库实例...

    15个常用的SQL Server高级语法

    这里我们将深入探讨标题中提到的15个常用SQL Server高级语法,以提升你的数据库操作能力。 1. **CASE...END** 语句: CASE...END 语句在SQL Server中提供了类似C#中的switch-case逻辑,允许根据不同的条件返回不同...

    常用SQLserver语句集锦

    在SQL Server数据库管理系统中,SQL(Structured Query Language)是一种用于管理关系数据库的标准语言。它包括数据查询、数据更新、数据插入和数据删除等操作。以下是一些常用的SQL语句及其详细解释: 1. **INSERT...

    SQL_Server_2000常用命令,语法使用方法

    SQL Server 2000 常用命令、语法使用方法 SQL Server 2000 是一个功能强大且广泛使用的关系数据库管理系统,本文将对 SQL Server 2000 的常用命令和语法使用方法进行详细的介绍。 一、数据记录筛选 在 SQL Server...

    SQL server存储过程语法及实例

    SQL Server存储过程是SQL Server中为了完成特定功能的SQL语句集,可以看作是一个或多个SQL语句的封装,用于实现特定的业务逻辑或功能,可以包含逻辑控制、数据处理等代码。存储过程可以简化复杂的操作、增强性能、...

    SQL语法优化大全

    在"sqlserver2000经典脚本"这个压缩包中,很可能包含了SQL Server 2000的常用脚本和示例,包括但不限于创建表、索引、视图、触发器、存储过程等,以及性能优化相关的查询和脚本。通过学习和实践这些脚本,可以深入...

Global site tag (gtag.js) - Google Analytics