触发器insert

触发器insertUSE [stalentzx]GO/****** Object: Trigger [dbo].[GZ_HISTORY_INSERT] Script Date: 2019/12/24 13:11:40

USE [stalentzx]
GO
/****** Object: Trigger [dbo].[GZ_HISTORY_INSERT] Script Date: 2019/12/24 13:11:40 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER TRIGGER [dbo].[GZ_HISTORY_INSERT]
ON [dbo].[ySysColumns]
AFTER INSERT–,DELETE,UPDATE
AS
BEGIN
DECLARE @TABLENAME VARCHAR(50)
DECLARE @COLNAME VARCHAR(50)
DECLARE @COLORDER INT
DECLARE @COLTYPE VARCHAR(50)

DECLARE @TABLE_SQL VARCHAR(MAX)
DECLARE @COL_STR VARCHAR(MAX)

SELECT @TABLENAME = TABLENAME , @COLNAME = COLNAME FROM INSERTED
IF @TABLENAME LIKE “GZ_PATSETDATA%” AND
ISNUMERIC(RIGHT(@TABLENAME , 4)) = 1

BEGIN

SELECT * INTO #YSYSCOLUMNS FROM YSYSCOLUMNS WHERE TABLENAME = @TABLENAME

IF EXISTS(SELECT 1 FROM YSYSCOLUMNS
WHERE TABLENAME = “C2” + RIGHT(@TABLENAME , 4)
)

BEGIN

SET @COL_STR = “”
SELECT @COL_STR = @COL_STR + “,” + COLNAME + ” ” +
(CASE WHEN COLTYPE IN (“VARCHAR”,”CHAR”)
THEN COLTYPE + “(” + CONVERT(VARCHAR(4000) , ColWidth) + “)”

WHEN COLTYPE IN (“DECIMAL” , “NUMERIC”)
THEN ColType + “(” + CONVERT(VARCHAR(4000) , ColWidth) + “,” +
CONVERT(VARCHAR(4000) , ColPrecision) + “)”
ELSE COLTYPE
END) +

(CASE WHEN ISNULL(YSYSCOLUMNS.ColDefault , “”) <> “”
THEN (CASE WHEN CHARINDEX(“,” , ColDefault) > 0
THEN ” Default ” +
SUBSTRING(ColDefault , 1 , CHARINDEX(“,” , ColDefault) – 1)
ELSE ” Default ” + ColDefault
END)
ELSE “”
END)
FROM YSYSCOLUMNS
WHERE TABLENAME=”GZ_PATSETDATA” + RIGHT(@TABLENAME , 4) AND
COLNAME = @COLNAME AND
COLNAME NOT IN(SELECT COLNAME FROM YSYSCOLUMNS
WHERE TABLENAME = “C2” + RIGHT(@TABLENAME,4) AND
COLNAME = @COLNAME
)

SELECT @TABLE_SQL = “ALTER TABLE C2″ + RIGHT(@TABLENAME,4) + ” ADD ” +
SUBSTRING(@COL_STR , 2 , 40000) + “;”

EXEC (@TABLE_SQL)

INSERT INTO YSYSCOLUMNS(TableName , ColName , ColOrder , ColType , ColWidth ,
ColPrecision , ColNull , ColDefault , DisplayLabel , DisplayWidth ,
DisplayFormat , EditFormat , ColVarify , VarifyMsg , ColVisible ,
ColProperty , ColGroup , enus , zhtw , OtherLanguage ,
RelationRule , colgroupOther)
SELECT “C2” + RIGHT(@TABLENAME , 4) , ColName , ColOrder , ColType , ColWidth ,
ColPrecision , ColNull , ColDefault , DisplayLabel , DisplayWidth ,
DisplayFormat , EditFormat , ColVarify , VarifyMsg , ColVisible ,
ColProperty , ColGroup , enus , zhtw , OtherLanguage ,
RelationRule , colgroupOther
FROM INSERTED
WHERE COLNAME NOT IN(SELECT COLNAME FROM YSYSCOLUMNS
WHERE TABLENAME = “C2” + RIGHT(@TABLENAME,4) AND
COLNAME = @COLNAME
)

END

ELSE
BEGIN
———————————–创建历史记录物理表———————————
SET @COL_STR = “”
SELECT @COL_STR = @COL_STR + “,” + ColName + ” ” +
(CASE WHEN COLTYPE IN (“VARCHAR”,”CHAR”)
THEN COLTYPE + “(” + CONVERT(VARCHAR(4000) , ColWidth) + “)”

WHEN COLTYPE IN (“DECIMAL” , “NUMERIC”)
THEN ColType + “(” + CONVERT(VARCHAR(4000) , ColWidth) + “,” +
CONVERT(VARCHAR(4000) , ColPrecision) + “)”
ELSE COLTYPE
END) +

(CASE WHEN ISNULL(YSYSCOLUMNS.ColDefault , “”) <> “”
THEN (CASE WHEN CHARINDEX(“,” , ColDefault) > 0
THEN ” Default ” +
SUBSTRING(ColDefault , 1 , CHARINDEX(“,” , ColDefault) – 1)
ELSE ” Default ” + ColDefault
END)
ELSE “”
END)
FROM YSYSCOLUMNS
WHERE TABLENAME=”GZ_PATSETDATA” + RIGHT(@TABLENAME,4)

SELECT @TABLE_SQL = “CREATE TABLE C2” + RIGHT(@TABLENAME,4) +
” (” + SUBSTRING(@COL_STR , 2 , 40000) + “);”
EXEC (@TABLE_SQL)

——由于不存在任何对应的历史表薪资项栏位描述信息,所以需建立对应的历史表描述
SELECT * INTO #YSYSTABLES FROM YSYSTABLES
WHERE TABLENAME = “GZ_PATSETDATA”+ RIGHT(@TABLENAME,4)

INSERT INTO ySysTables(TableName , TableTypeID , TableOrder , TableLabel , ACessable ,
ACessModule , TableVisible ,PRESERE , ISUSERDISPLAY , TEAMVISIBLE , ModuleID)
SELECT “C2″+RIGHT(@TABLENAME,4) , 7 , TableOrder , TableLabel+”_H” , “111” ,
“010000000000000000000000000000” , “1” , 0 , 1 , 1 , “01”
FROM #YSYSTABLES

——建立对应历史表的薪资项栏位信息描述
INSERT INTO YSYSCOLUMNS(TableName , ColName , ColOrder , ColType , ColWidth ,
ColPrecision , ColNull , ColDefault , DisplayLabel , DisplayWidth ,
DisplayFormat , EditFormat , ColVarify , VarifyMsg , ColVisible ,
ColProperty , ColGroup , enus , zhtw , OtherLanguage ,
RelationRule , colgroupOther)
SELECT “C2” + RIGHT(@TABLENAME , 4) , ColName , ColOrder , ColType , ColWidth ,
ColPrecision , ColNull , ColDefault , DisplayLabel , DisplayWidth ,
DisplayFormat , EditFormat , ColVarify , VarifyMsg , ColVisible ,
ColProperty , ColGroup , enus , zhtw , OtherLanguage ,
RelationRule , colgroupOther
FROM #YSYSCOLUMNS
END

END

END

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10388.html

(0)
上一篇 2022-12-28
下一篇 2022-12-28

相关推荐

  • 请问下python的(关于python的)

    请问下python的(关于python的)当我们进行Python学习的时候,一定要保持良好的逻辑思维能力,虽然说Python适合零基础人员学习,但是学习的时候也需要较强的思维能力。

    2023-10-27
    151
  • MySQL日志管理详解_MySQL binlog

    MySQL日志管理详解_MySQL binlog概述 日志文件记录 MySQL 数据库运行期间发生的变化,当数据库遭到意外的损害时,可以通过日志文件查询出错原因,并进件数据恢复 MySQL 日志文件可以分成以下几类: 二进制日志:记录所有更改数据的

    2023-05-14
    144
  • Python数组合并

    Python数组合并Python作为一门高效、易于学习和操作的编程语言,被广泛应用于数据处理、科学计算以及人工智能领域。在Python中,数组合并是我们经常会遇到的操作之一。本文将详细阐述Python中如何进行数组合并操作。

    2024-08-15
    30
  • mysql 为什么 SQL 语句不要过多的 join?「建议收藏」

    mysql 为什么 SQL 语句不要过多的 join?「建议收藏」第一部分 Linux上查看内存的使用情况该用什么命令 free -mh 可以看到内存或者缓存情况 total 总内存 used 已用内存 free 空闲内存 buff/cache 已使用的缓存 av…

    2023-03-18
    148
  • Redis—数据备份与恢复[通俗易懂]

    Redis—数据备份与恢复[通俗易懂]https://www.cnblogs.com/shizhengwen/p/9283973.html https://blog.csdn.net/w2393040183/article/details

    2022-12-26
    150
  • 技术分享 | 用好 MySQL 的 MRR 优化器

    技术分享 | 用好 MySQL 的 MRR 优化器作者:蒋乐兴 MySQL DBA,擅长 python 和 SQL,目前维护着 github 的两个开源项目:mysqltools 、dbmc 以及独立博客:https://www.sqlpy.com…

    2023-03-12
    167
  • Python中elif和else的区别

    Python中elif和else的区别在Python中,if语句用于判断一个条件是否成立,如果成立则执行相应的代码块。如果不成立,则可以使用elif语句来进行下一个条件的判断,如果还不成立则继续使用elif,直到有一个条件成立,或者所有条件都不成立的时候,可以使用else语句来执行其它代码块。

    2024-08-17
    30
  • 如何根据关键字匹配度排序「建议收藏」

    如何根据关键字匹配度排序「建议收藏」最近项目遇到根据关键字匹配度排序,要求关键字匹配相等排在第一,关键字匹配最左边排第二,关键字匹配最右边排第三,关键字匹配中间排最后;遇到这样查询排序场景,用MySQL如何实现?用搜索引擎Elastic

    2022-12-24
    143

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注