Solved

trigger on insert to update column if contain top 2012 and replace by top 2013

Posted on 2013-01-05
2
309 Views
Last Modified: 2013-01-05
i have the following table

/****** Script for SelectTopNRows command from SSMS  ******/
SELECT TOP 1000 [ActionId]
      ,[Text]
      ,[UserId]
      ,[type]
      ,[ActionTypeId]
  FROM [HITV_Filtration].[TvUser].[Sendsms]
  where Text like '%top5 2012%'
  order by actionid desc


i want to replace each new record inserted in [HITV_Filtration].[TvUser].[Sendsms]
contain '%top5 2012%' and replace only the top5 2012 by top5 2013

the Text is like : vote to 23232 for top5 2012  XXXX
it should be replacd by vote to 23232 for top5 2012 XXX

??? i should care on update the primarykey is actionid

please can anyone help me on write this function
0
Comment
Question by:afifosh
2 Comments
 
LVL 1

Author Comment

by:afifosh
ID: 38747509
CREATE TABLE [TvUser].[Sendsms](
      [ActionId] [bigint] NOT NULL,
      [Text] [varchar](4000) NULL,
      [UserId] [int] NULL,
      [type] [tinyint] NULL,
      [ActionTypeId]  AS (CONVERT([tinyint],(7),(0))),
 CONSTRAINT [PK_Message] PRIMARY KEY CLUSTERED
(
      [ActionId] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]

GO
CREATE TRIGGER dbo.tri_Test_Insert_Trigger
ON [TvUser].[Sendsms] FOR INSERT
AS
BEGIN
    UPDATE T
    SET Text = // replace function ??
    FROM
        INSERTED I
    INNER JOIN dbo.[TvUser].[Sendsms]  T ON
        T.ActionId = I.ActionId

WHERE .. TEXT LIKE ;%TOP5 2012%'
END
GO


please help :S
0
 
LVL 75

Accepted Solution

by:
Anthony Perkins earned 500 total points
ID: 38747690
the Text is like : vote to 23232 for top5 2012  XXXX
it should be replacd by vote to 23232 for top5 2012 XXX
I suspect you meant:
the Text is like : vote to 23232 for top5 2012  XXXX
it should be replacd by vote to 23232 for top5 2013 XXX

If that is the case then try it like this:
UPDATE  T
    SET     [Text] = REPLACE([Text], 'TOP5 2012', 'TOP5 2013')
    FROM    INSERTED I
            INNER JOIN dbo.[TvUser].[Sendsms] T ON T.ActionId = I.ActionId
    WHERE   [Text] LIKE '%TOP5 2012%'

Open in new window

0

Featured Post

Live: Real-Time Solutions, Start Here

Receive instant 1:1 support from technology experts, using our real-time conversation and whiteboard interface. Your first 5 minutes are always free.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Oracle DB monitor SW 21 48
Sql server function help 15 28
SSIS with VPN COnnection 2 70
Query Syntax 17 32
In this article I will describe the Detach & Attach method as one possible migration process and I will add the extra tasks needed for an upgrade when and where is applied so it will cover all.
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
This videos aims to give the viewer a basic demonstration of how a user can query current session information by using the SYS_CONTEXT function
Via a live example, show how to setup several different housekeeping processes for a SQL Server.

785 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question