SQL学习(时间,存储过程,触发器)
SQL学习
- 几个操作时间的函数
- --datapart 获取时间中的年月日时分秒等部分
- select DATEPART(year,current_timestamp);
- select DATEPART(DAY,current_timestamp);
- select DATEPART(MONTH,current_timestamp);
- --dateadd 在相应时间上加上年月日时分秒等
- select CURRENT_TIMESTAMP,DATEADD(DAY,10,CURRENT_TIMESTAMP);
- select DATEADD(month,11,'2001-2-28 12:00:00') as 上帝时刻;
- --datediff 获取两时间段的差值并换算为时分秒年月日等
- select DATEDIFF(month,'2014-8-3','2015-9-10');
- --转换函数 转换类型
- --cast convert
- select ''+456;
- select ''+cast(456 as varchar);
- select ''+CONVERT(varchar,456);
- --convert时间类型转换 后面的数字即不同地区的时间表示方式
- select CURRENT_TIMESTAMP,
- CONVERT(VARCHAR,CURRENT_TIMESTAMP,111);--中国时间表示
- select CURRENT_TIMESTAMP,
- CONVERT(VARCHAR,CURRENT_TIMESTAMP,110);--美国时间表示
- --datapart 获取时间中的年月日时分秒等部分
- 简单练习
- --练习题
- use TextDB
- create table TB_CallRecord
- (
- Id int not null identity(1,1),
- CallNumber nvarchar(50),
- TelNum varchar(50),
- StartDateTime datetime null,
- EndDateTime datetime null
- )
- --主键约束
- alter table TB_CallRecord
- add constraint PK_CallRecord primary key (Id);
- --检查约束
- alter table TB_CallRecord
- add constraint CK_CallRecords check(CallNumber like '[0-9][0-9][0-9]')
- alter table TB_CallRecord
- add constraint CK_CallRecords_EndDateTime check(EndDateTime > StartDateTime)
- --默认约束
- alter table TB_CallRecord
- add constraint DF_CallRecords default(getdate()) for EndDateTime
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009DAF00A4CB80 AS DateTime), CAST(0x00009DAF00A62E94 AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009DB000D63BC0 AS DateTime), CAST(0x00009DB000D68DC8 AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009DB000E85C60 AS DateTime), CAST(0x00009DB000E92F50 AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009DB2015BB7A0 AS DateTime), CAST(0x00009DB2015C4DA0 AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009DA4014C9C70 AS DateTime), CAST(0x00009DA4014E0308 AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009DB400DAA0C0 AS DateTime), CAST(0x00009DB400DD5FE0 AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009DB200B9AB40 AS DateTime), CAST(0x00009DB200B9FC1C AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009DB8014042B8 AS DateTime), CAST(0x00009DB80141804C AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009D9A00FB9898 AS DateTime), CAST(0x00009D9A00FE6118 AS DateTime));
- INSERT TB_CallRecord ([CallNumber], [TelNum], [StartDateTime], [EndDateTime]) VALUES ('', '', CAST(0x00009D9A00FB9898 AS DateTime), CAST(0x00009D9A00FE6118 AS DateTime));
- --查看全表
- select * from TB_CallRecord;
- --输出通话时间最长的五条记录
- select top 5 *,DATEDIFF(SECOND,StartDateTime,EndDateTime) as 通话时长 from TB_CallRecord order by DATEDIFF(SECOND,StartDateTime,EndDateTime) DESC;
- --输出所有数据中拨打长途号码(对方号码以0开头)的总时长。like、sum
- SELECT SUM(DATEDIFF(SECOND,StartDateTime,EndDateTime)) from TB_CallRecord WHERE TelNum like '0%';
- --输出通话总时长最多的前三个呼叫员的编号。
- select top 3 Id,DATEDIFF(SECOND,StartDateTime,EndDateTime) as 通话时长 from TB_CallRecord order by DATEDIFF(SECOND,StartDateTime,EndDateTime) DESC;
- --输出本月拨打电话次数最多的前三个呼叫员的编号.group by,count(*)
- select top 3 CallNumber,Id,StartDateTime From TB_CallRecord where DATEPART(MONTH,StartDateTime) = 7 order by CallNumber DESC;
- --表序列化row_number()over(order by 字段) 就是将不连续的表依据某一列值排序
- select ROW_NUMBER()over(order by Id) as 序列化 ,*from TB_CallRecord;
- --练习题
- 事务
- --事务:SQL中每一条语句都是一个事务,任何错误都会导致整个事务失败
--语法:
/*
begin transaction
代码
end
*/ - begin transaction
- declare @myError int;
- update TextDB..TB_CallRecord set CallNumber = 0127897789 where CallNumber = '';
- set @myError = (select @@ERROR);
- update TextDB..TB_CallRecord set CallNumber = '' where Id = 10;
- set @myError += (select @@ERROR);
- if(@myError!=0)
- begin
- rollback transaction --回滚当前的操作
- end
- else
- begin
- commit transaction --执行当前的操作
- end
- --事务的特征:如果一个事务满足原子性,持久性,隔离性,一致性,那么这个操作则称为事务。
- --begin transaction
- select *from TextDB..TB_CallRecord;
- --事务:SQL中每一条语句都是一个事务,任何错误都会导致整个事务失败
- 存储过程
- --存储过程
- --语法:
- /*
- create proc[edure] 存储过程名字
- 参数 as 类型 [默认值|out]
- as
- begin
- 代码
- end
- */
- --例如:
- go
- create proc usp_text
- as
- begin
- begin transaction
- declare @myError int;
- update TextDB..TB_CallRecord set CallNumber = '' where CallNumber = '';
- set @myError = (select @@ERROR);
- update TextDB..TB_CallRecord set CallNumber = '' where Id = 10;
- set @myError += (select @@ERROR);
- if(@myError!=0)
- begin
- rollback transaction
- end
- else
- begin
- commit transaction
- end
- end
- --执行存储过程
- exec usp_text;
- select * from TextDB..TB_CallRecord;
- --带参数的存储过程
- go
- create proc usp_text2
- @oldnum as nvarchar(50)
- ,@newnum as nvarchar(50)
- as
- begin
- update TextDB..TB_CallRecord set CallNumber = @newnum where CallNumber = @oldnum;
- end
- --调用带参数的存储过程
- exec usp_text2 '','';
- select * from TextDB..TB_CallRecord
- --带参数和返回值的存储过程
- go
- create proc usp_text3
- @oldnum as nvarchar(50)
- ,@newnum as nvarchar(50)
- ,@isSuccess int output --使用output将函数内参数抛出给外部
- as
- begin
- declare @myError int
- update TextDB..TB_CallRecord set CallNumber = @newnum where CallNumber = @oldnum;
- set @myError = (select @@ERROR);
- if(@myError=0)
- begin
- commit
- set @isSuccess = 1
- end
- else
- begin
- rollback
- set @isSuccess = 0;
- end
- end
- --调用带参数和返回值的存储过
- declare @result int
- exec usp_text3 '','',@result output;
- select @result;
- --使用try catch
- go
- create proc usp_text4
- @oldnum as nvarchar(50)
- ,@newnum as nvarchar(50)
- ,@IsSucess int output
- as
- begin
- begin transaction
- update TextDB..TB_CallRecord
- set CallNumber = @newnum
- where CallNumber = @oldnum
- begin try
- commit
- set @IsSucess = 1;
- end try
- begin catch
- rollback
- set @IsSucess = 0;
- end catch
- end
- --调用带有try,catch的存储过程
- declare @result int
- exec usp_text4 '','',@result output;
- select @result;
- --存储过程
- 触发器
- --触发器
- --语法
- /*
- create trigger tr_类型触发器名字 on 表名
- 触发类型:after|instea of
- 操作类型:inser|delete|update
- as
- begin
- 代码
- end
- */
- --案例
- --插入数据的同时获得自动增长的Id
- select * from TextDB..TB_USER;
- insert INTO TextDB..TB_USER (userID,[password],code,lastTime)
- OUTPUT inserted.userID
- VALUES ('aaa','DDD','','2007-03-12');
- -----------
- go
- create trigger tr_delete_不会删除的表 on TextDB..TB_USER
- after
- delete
- as
- insert into TextDB..TB_USER(userID,[password],code,lastTime)
- select userID,[password],code,lastTime from deleted;
- go
- select * from TextDB..TB_USER;
- delete TB_USER
- select SUSER_NAME();
学习于蒋坤老师视频教程
- --触发器
SQL学习(时间,存储过程,触发器)的更多相关文章
- sql学习笔记--存储过程
存储过程(stored procedure)有时也称sproc,它是真正的脚本,更准确地说,它是批处理(batch),但都不是很确切,它存储与数据库而不是单独的文件中. 存储过程中有输入参数,输出参数 ...
- PL/SQL学习笔记之触发器
一:触发器响应的事件 数据库操作(DML)语句(DELETE,INSERT,UPDATE) 数据库定义(DDL)语句(CREATE,ALTER或DROP) 数据库操作(SERVERERROR,登录,注 ...
- 1.8(SQL学习笔记)触发器
一.触发器简介 当需要某些操作在某些语句执行之前或之后执行就需要使用触发器. 例如每次插入数据时进行数据校对,每次删除数据后将删除内容备份到新表. 这些操作我们希望它(某些语句)在满足某些条件时自动执 ...
- SQL学习笔记七之MySQL视图、触发器、事务、存储过程、函数
阅读目录 一 视图 二 触发器 三 事务 四 存储过程 五 函数 六 流程控制 一 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名 ...
- Oracle学习2 视图 索引 sql编程 游标 存储过程 存储函数 触发器
---视图 ---视图的概念:视图就是提供一个查询的窗口,来操作数据库中的数据,不存储数据,数据在表中. ---一个由查询语句定义的虚拟表. ---查询语句创建表 create table emp a ...
- 查看SQL SERVER 加密存储过程,函数,触发器,视图
原文:查看SQL SERVER 加密存储过程,函数,触发器,视图 create PROCEDURE sp_decrypt(@objectname varchar(50))ASbeginset noc ...
- Sql Server 查看存储过程最后修改时间
Sql Server 查看存储过程最后修改时间 select * from sys.procedures order by modify_date desc
- 2020重新出发,MySql基础,MySql视图&索引&存储过程&触发器
@ 目录 视图是什么 视图的优点 1) 定制用户数据,聚焦特定的数据 2) 简化数据操作 3) 提高数据的安全性 4) 共享所需数据 5) 更改数据格式 6) 重用 SQL 语句 MySQL创建视图 ...
- MySQL笔记---视图,存储过程, 触发器的使用入门
大二学数据库的时候,只是隐约听到老师提起过视图啊,存储过程啊,触发器啊什么的,但只是淡淡的记住了名字,后来自己做些小项目,小程序,也没有用上过,都只是简单的建表,关联表之类的,导致我对这些东西的理解只 ...
随机推荐
- 【转】NHIBERNATE的各种保存方式的区别 (SAVE,PERSIST,UPDATE,SAVEORUPDTE,MERGE,FLUSH,LOCK)
前言 今天学学习NH这个框架,在新增对象的时候,看见大神用了persist而没有用Save,心中比较疑惑,查阅资料的时候,发现这篇写的非常不错,转载供大家参考. hibernate的保存hiberna ...
- ARM linux电源管理——Cortex A系列CPU(32位)睡眠和唤醒的底层汇编实现
ARM linux电源管理——Cortex A系列CPU(32位)睡眠和唤醒的底层汇编实现 承接 http://www.wowotech.net/pm_subsystem/suspend_and_re ...
- iOS 获取蜂窝网络信号强度 包含iPhoneX XS XR XSMASX (最新)
1.虽然各种直接获取信号强度的api都被封杀了.但是还有一个另类的黑魔法可以获取到.那就是遍历UIStatusBar了 网络上有的文章写的会崩溃 比如: - (int)getSignalStrengt ...
- C++分享笔记:扑克牌的洗牌发牌游戏设计
笔者在大学二年级期间,做过的一次C++程序设计:扑克牌的洗牌发牌游戏.具体内容是:除去大王和小王,将52张扑克牌洗牌,并发出5张牌.然后判断这5张牌中有几张相同大小的牌,是否是一条链,有几个同花等. ...
- stl学习之namespace
一.为什么需要命名空间(问题提出) 命名空间是ANSIC++引入的可以由用户命名的作用域,用来处理程序中常见的同名冲突. 在 C语言中定义了3个层次的作用域,即文件(编译单元).函数和复合语句.C++ ...
- [异常笔记] zookeeper集群启动异常: Cannot open channel to 2 at election address ……
- ::, [myid:] - WARN [WorkerSender[myid=]:QuorumCnxManager@] - Cannot open channel to at election ad ...
- ACM 2000~2002
ACM 2000 输入三个字符后,按各个字符的ASCⅡ码从小打到的顺序输出这三个字符. import java.util.Scanner; public class Lengxc {public ...
- 启动pip时,< Fatal error in launcher: Unable to create process using '"' >问题的原因及解决方法
根本原因 要启动的pip程序,中指定的python程序路径不对 实例分析 我的window电脑上同时安装了python2.7和python3.6,他们的安装路径如下图: 注意图python2.7中红线 ...
- 使用什么进行app开发
HTML5+plus, Hbuilder HTML5+plus介绍 HTML5 Plus移动App,简称5+App,是一种基于HTML.JS.CSS编写的运行于手机端的App,这种App可以通过扩展的 ...
- 【转载】jquery实现勾选复选框触发事件给input赋值+回显复选框
引用:https://blog.csdn.net/rui276933335/article/details/45717461 JSP: <td class="as1"> ...