Sql server 에서 감사 테이블 내의 로그 기록 변경
이 table:
CREATE TABLE GUESTS (
GUEST_ID int IDENTITY(1,1) PRIMARY KEY,
GUEST_NAME VARCHAR(50),
GUEST_SURNAME VARCHAR(50),
ADRESS VARCHAR(100),
CITY VARCHAR(50),
CITY_CODE VARCHAR(10),
COUNTRY VARCHAR(50),
STATUS VARCHAR(20),
COMMENT nvarchar(max);
대한 로깅하기:
CREATE TABLE AUDIT_GUESTS (
ID int IDENTITY(1,1) PRIMARY KEY,
GUEST_ID int,
OLD_GUEST_NAME VARCHAR(50),
NEW_GUEST_NAME VARCHAR(50),
OLD_GUEST_SURNAME VARCHAR(50),
NEW_GUEST_SURNAME VARCHAR(50),
OLD_ADRESS VARCHAR(100),
NEW_ADRESS VARCHAR(100),
OLD_CITY VARCHAR(50),
NEW_CITY VARCHAR(50),
OLD_CITY_CODE VARCHAR(10),
NEW_CITY_CODE VARCHAR(10),
OLD_COUNTRY VARCHAR(50),
NEW_COUNTRY VARCHAR(50),
OLD_STATUS VARCHAR(20),
NEW_STATUS VARCHAR(20),
OLD_COMMENT nvarchar(max),
NEW_COMMENT nvarchar(max),
AUDIT_ACTION varchar(100),
AUDIT_TIMESTAMP datetime);
내가 만들고 싶다 '는' 내 '손님' on my 트리거할 표를 모두 로깅할 변화를 AUDIT_GUESTS 표. Sql Server 2014년 Express) 에서 어떻게 합니까?
내가 시도했다.
create TRIGGER trgAfterUpdate ON [dbo].[GUESTS]
FOR UPDATE
AS
declare @GUEST_ID int;
declare @GUEST_NAME varchar(50);
declare @GUEST_SURNAME VARCHAR(50);
declare @ADRESS VARCHAR(100);
declare @CITY VARCHAR(50);
declare @CITY_CODE VARCHAR(10);
declare @COUNTRY VARCHAR(50);
declare @STATUS VARCHAR(20);
declare @COMMENT nvarchar(max);
declare @AUDIT_ACTION varchar(100);
declare @AUDIT_TIMESTAMP datetime;
select @GUEST_ID=i.GUEST_ID from inserted i;
select @GUEST_NAME=i.GUEST_NAME from inserted i;
select @GUEST_SURNAME=i.GUEST_SURNAME from inserted i;
select @ADRESS=i.ADRESS from inserted i;
select @CITY=i.CITY from inserted i;
select @CITY_CODE=i.CITY_CODE from inserted i;
select @COUNTRY=i.COUNTRY from inserted i;
select @STATUS=i.STATUS from inserted i;
select @COMMENT=i.COMMENT from inserted i;
if update(GUEST_NAME)
set @audit_action='Updated Record -- After Update Trigger.';
if update(GUEST_SURNAME)
set @audit_action='Updated Record -- After Update Trigger.';
if update(ADRESS)
set @audit_action='Updated Record -- After Update Trigger.';
if update(CITY)
set @audit_action='Updated Record -- After Update Trigger.';
if update(CITY_CODE)
set @audit_action='Updated Record -- After Update Trigger.';
if update(COUNTRY)
set @audit_action='Updated Record -- After Update Trigger.';
if update(STATUS)
set @audit_action='Updated Record -- After Update Trigger.';
if update(COMMENT)
set @audit_action='Updated Record -- After Update Trigger.';
insert into AUDIT_GUESTS
(GUEST_ID,GUEST_NAME,GUEST_SURNAME,ADRESS,CITY,CITY_CODE,COUNTRY,STATUS,COMMENT,audit_action,AUDIT_TIMESTAMP)
values(@GUEST_ID,@GUEST_NAME,@GUEST_SURNAME,@ADRESS,@CITY,@CITY_CODE,@COUNTRY,@STATUS,@COMMENT,@audit_action,getdate());
GO
그러나 오래된 새로운 값을 확인 사람이었는가부텀 작동됨 보고 싶다.
Sqlite 의 했어요.
CREATE TRIGGER [LOG_UPDATE]
AFTER UPDATE OF [GUEST_NAME], [GUEST_SURNAME], [ADRESS], [CITY], [CITY_CODE], [COUNTRY], [STATUS], [COMMENT]
ON [GUESTS]
BEGIN
INSERT INTO GUESTS_LOG
( GUEST_ID,
NAME_OLD,NAME_NEW,
SURNAME_OLD,SURNAME_NEW,
ADRESS_OLD,ADRESS_NEW,
CITY_OLD,CITY_NEW,
CITY_CODE_OLD,CITY_CODE_NEW,
COUNTRY_OLD,COUNTRY_NEW,
STATUS_OLD,STATUS_NEW,
COMMENT_OLD,COMMENT_NEW,sqlAction,DATE_TIME)
VALUES
(OLD.GUEST_ID,
OLD.GUEST_NAME,NEW.GUEST_NAME,
OLD.GUEST_SURNAME,NEW.GUEST_SURNAME,
OLD.ADRESS,NEW.ADRESS,
OLD.CITY,NEW.CITY,
OLD.CITY_CODE,NEW.CITY_CODE,
OLD.COUNTRY,NEW.COUNTRY,
OLD.STATUS,NEW.STATUS,
OLD.COMMENT,NEW.COMMENT,'record changed',datetime('now','localtime'));
END
또한 SQL server 에 이 방법을 몰라 그냥 OK 협력했습니다 전달하십시오 않습니다. 이제 막 com/go/learn_fl_cs4_learningas2_kr 거잖나.
27
4
Take a look at Simple-talk.com 에서 [팝 리베트] 이 문서 의 2. 이 모든 업데이트되도록 올드발루 로깅합니다 만드는 것으로, 일반 트리거할 안내합니다 뉴발루 열. 이 코드는 매우 일반적이며 이를 적용할 수 있습니다 또한 모든 작업을 INSERT, UPDATE, 즉, 임의의 테이블 네가 감사, 침전물 및 삭제입니다. 테이블 만 요구 사항은 감사할 수 있는 기본 키 (가장 잘 할 수 있는 테이블을 애니웨이) 이어야 합니다.
39 의 게스트 코드를 here& 관련 단축시킵니다 표.
하지만 이를 통해 다른 사람이 내가 아는 이는 수도 이전.
New", " 로깅할 마십시오. 값. 기존 표, 게스트, 새로운 가치를 갖고 있다. # 39 고객의 DB 크기, 데이터, 그리고 ll %s/dbase/ext_table. you& 연산뿐 엔트리여야 너무 빠르게 성장할 것으로 이쪽요.
예를 들어, 내가 이 설치 및 최소화됨 (i) 이 있지만, 이것은 you& 클리닝했습니다. # 39 표, d 필요한 로그오프했다가 변경:
게스트 표 값 변화를 경우 (예: 게스트 이름), 단순히 그 전체 데이터 행을 로그오프한 데이터베이스에구성원을 로그 / 감사 그대로 사용하여 테이블을 촉발제였군. 네 명이 현재 데이터 테이블 표에 로그 / 감사 이전 데이터가 있다.
Select 문에 다음 데이터를 얻기 위해 양쪽 모두에서 표:
최고 (最古) 의 최신 정보와 데이터의 테이블에 나올 것이라고 같았다, 첫 번째 행, 어떤 창조되었으되 & 있다. 마지막 행은 현재 데이터 있다. 무엇이 달라졌습니까 바꿔놓은 확인할 수 있습니다, 정보기술 (it), 그들이 변경했다.
내가 선택적으로 사용할 수 있는 기능을 통해 어떤 값을 루프 레코드세트 (클래식 ASP), 단 표시되었는지 웹 페이지에 달라졌다. 이 돌격은 숭배자들로부터도 감사 추적 볼 수 있으므로 사용자가 어떤 시간이 지남에 따라 달라졌다.
이것은 코드 2 개의 버그가 수정되었습니다. 버그 픽스 로이 남어 대해 언급한 것은 처음 있는 수락됨 이 질문의 답을. 스택 오버플로 bug 는 pageref http://support. [버그 트리거할 에서 코드] [1]. 여러 단어를 이름에 대한 @Fandango68 및 수정 있는 열 두 번째 의해 발견됐다.
[1]: https://chat.stackexchange.com/transcript/message/34774768 # 34774768
39 이 슬라이드에서는 안녕하슈 It& 아주 간단합니다.
@OLD_GUEST_NAME = d. 삭제된 guest_name 속도입니다.4.
이 변수 값을 저장할 수 있는 기존 삭제된 후 스맥랜드의 삽입할 수 있습니다.
예를 들어, -