Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Kopiera in post i samma tabell?

Postades av 2008-07-23 17:22:07 - Magnus Hallberg, i forum sql-server/msde, Tråden har 1 Kommentarer och lästs av 1204 personer

Jag skulle behöva göra följande:

Kopiera en post, uppdatera ett fält, sätta in den i den ursprungliga tabellen igen.

Jag har försökt med SELECT INTO men det går ju inte att göra på en existerande tabell(eller har jag missat nåt?)

Nån som har förslag på hur jag kan lösa detta? Kopierar in koden så är det kanske lättare att förstå.
<code>
ALTER PROC copyPodCastItem
@newPath VARCHAR(150),
@oldPath VARCHAR(150)
AS
IF(EXISTS(SELECT itemID FROM podCastItem WHERE link = @oldPath))BEGIN
BEGIN TRAN
SELECT podCastInfoID, title, link, uniqueIdent, [desc], length, typeID, categoryID, pubDate
INTO podCastItem_copy FROM podCastITem
WHERE link = @oldPath
IF(@@error <> 0)GOTO noInsert

UPDATE podCastItem_copy
SET
link = @newPath,
uniqueIdent = @newPath
WHERE link = @oldPath
IF(@@error <> 0)GOTO noInsert

SELECT * INTO podCastItem
FROM podCastItem_copy
IF(@@error <> 0) GOTO noInsert

DROP TABLE podCastItem_copy
COMMIT TRAN
END
ELSE GOTO noFound

noFound:
RAISERROR('Det gick inte att hitta posten.', 16, 1)
RETURN

noInsert:
ROLLBACK TRAN
RAISERROR('Det gick inte att hitta posten.', 16, 1)
RETURN
</code>


Svara

Sv: Kopiera in post i samma tabell?

Postades av 2008-07-23 17:57:33 - Magnus Hallberg

Så dum i hu...t jag är. Glömde ju att man kan öra så här:)

<code>
ALTER PROC copyPodCastItem
@newPath VARCHAR(150),
@oldPath VARCHAR(150)
AS
IF(EXISTS(SELECT itemID FROM podCastItem WHERE link = @oldPath))BEGIN
BEGIN TRAN
CREATE TABLE podCastItem_copy
(
podCastInfoID INT,
title VARCHAR(50),
link VARCHAR(150),
uniqueIdent VARCHAR(150),
[desc] VARCHAR(500),
length INT,
typeID INT,
categoryID INT,
pubDate DATETIME
)

INSERT INTO podCastItem_copy (podCastInfoID, title, link, uniqueIdent, [desc], length, typeID, categoryID, pubDate)
SELECT podCastInfoID, title, @newPath, @newPath, [desc], length, typeID, categoryID, pubDate
FROM podCastITem
WHERE link = @oldPath
IF(@@error <> 0)GOTO noInsert

INSERT INTO podCastItem (podCastInfoID, title, link, uniqueIdent, [desc], length, typeID, categoryID, pubDate)
SELECT podCastInfoID, title, link, uniqueIdent, [desc], length, typeID, categoryID, pubDate
FROM podCastITem_copy
IF(@@error <> 0)GOTO noInsert

DROP TABLE podCastItem_copy
COMMIT TRAN
RETURN
END

ELSE GOTO noFound

noFound:
RAISERROR('Det gick inte att hitta posten.', 16, 1)
RETURN

noInsert:
ROLLBACK TRAN
RAISERROR('Det gick inte att kopiera posten.', 16, 1)
RETURN
</code>


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 615
27 953
271 709
5 567
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies