Solved

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

Posted on 2013-01-05
2
313 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
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

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

The Delta outage: 650 cancelled flights, more than 1200 delayed flights, thousands of frustrated customers, tens of millions of dollars in damages – plus untold reputational damage to one of the world’s most trusted airlines. All due to a catastroph…
This article shows gives you an overview on SQL Server 2016 row level security. You will also get to know the usages of row-level-security and how it works
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…
Via a live example, show how to extract information from SQL Server on Database, Connection and Server properties

729 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