控件中国网现已改版,您看到的是老版本网站的镜像,系统正在为您跳转到新网站首页,请稍候.......
中国最专业的商业控件资讯网产品咨询电话:023-67870900 023-67871946
产品咨询EMAIL:SALES@COMPONENTCN.COM

Sqlserver与Mysql触发器之间的差别

作者:未知 出处:cnblog 2013年06月25日 阅读:

 今天练习sqlserver,一开始感觉应该像Oracle,Mysql语法差不多,但是经过一下午的奋战,才感觉原来这三个数据库就是有区别啊,

 
我原来学习触发器的时候用的是Mysql,感觉还行,但是今天采用的是sqlserver,就感觉差别就是很大了。
 
今天将部分代码展示给大家看看,
 
下面显示的是触发器用到的两个表
 
 
--创建sc表
CREATE TABLE [sc](
  [ScId] int  NOT NULL,
  [SNo] int  NOT NULL ,
  [CNo] int NOT NULL ,
  [Score] int DEFAULT NULL ,
  PRIMARY KEY ([ScId])
);
--添加履历表
CREATE TABLE score_record (
  SrId int NOT NULL,
  SNo int NOT NULL ,
  CNo int NOT NULL ,
  OldScore int NOT NULL ,
  NewScore int NOT NULL ,
  UpdateTime datetime NOT NULL ,
  PRIMARY KEY (SrId),
); 
 
下面显示的是Mysql写的触发器
 
 
--Mysql写的触发器
--创建触发器,将修改前后的成绩插入到履历表  
DROP TRIGGER IF EXISTS `trigger_sr`;
DELIMITER //
CREATE TRIGGER `trigger_sr` AFTER UPDATE ON `sc`
 FOR EACH ROW BEGIN 
INSERT INTO score_record
SET SNo = new.SNo,
CNo = new.CNo,
OldScore = old.Score,
NewScore = new.Score,
UpdateTime = NOW() ;
END
//
DELIMITER ; 
 
下面显示的是Sqlserver写的触发器
 
 
--Sqlserver写的触发器
--创建触发器,将修改前后的成绩插入到履历表
CREATE TRIGGER trigger_sr  
on sc  for update
as
declare @SNo int,@CNo int,@OldScore int,@NewScore int,@UpdateTime datetime
BEGIN 
    Select @OldScore=Score From Deleted;
    select @UpdateTime=getdate();
    Select @SNo=SNo,@CNo=CNo,@NewScore=Score From inserted;
    INSERT INTO score_record(SNo,CNo,OldScore,NewScore,UpdateTime)
    values(@SNo,@CNo,@OldScore,@NewScore,@UpdateTime)
END这个只是触发器之间的差别,像储存过程,自定义函数等一定还有很大的区别,不过,现在的感觉是学完一种数据库语言,其他的数据库学起来也是那样吧。
 

热推产品

  • ActiveReport... 强大的.NET报表设计、浏览、打印、转换控件,可以同时用于WindowsForms谀坔攀戀Forms平台下......
  • AnyChart AnyChart使你可以创建出绚丽的交互式的Flash和HTML5的图表和仪表控件。可以用于仪表盘的创......
首页 | 新闻中心 | 产品中心 | 技术文档 | 友情连接 | 关于磐岩 | 技术支持中心 | 联系我们 | 帮助中心 Copyright-2006 ComponentCN.com all rights reserved.重庆磐岩科技有限公司(控件中国网) 版权所有 电话:023 - 67870900 传真:023 - 67870270 产品咨询:sales@componentcn.com 渝ICP备12000264号 法律顾问:元炳律师事务所 重庆市江北区塔坪36号维丰创意绿苑A座28-5 邮编:400020
在线客服
在线客服系统
在线客服
在线客服系统