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


Lägger in för många poster

Postades av 2007-11-26 22:50:25 - Magnus Hallberg, i forum sql-server/msde, Tråden har 8 Kommentarer och lästs av 999 personer

Jag har gjort nåt tokigt i denna SP. det den gör är ratt lägga in massor med poster i AdvertisePics. det jag vill är att den ska lägga in de poster som finns i tempPic om det finns några. Nån som kan hjälpa mej rätt med detta?

<code>
ALTER proc [IsellItAdmin].[moveTempPic]
@userSession varchar(256),
@advertiseID int
as
set nocount on
declare @errMess varchar(100)
declare @picName varchar(150)
declare @numOfPics int
begin try
if(exists(select pic from tempPic where userSession = @userSession))
begin
select @numOfPics = count(*) from tempPic where userSession = @userSession
while(@numOfPics > 0)
begin
begin tran
select @picName = pic from tempPic where userSession = @userSession
insert into AdvertisePics(AdvertiseID, AdvertisePic)
values(@advertiseID, @picName)
delete from tempPic
where userSession = @userSession and pic = @picName
if(@@error <> 0)
begin
set @errMess = 'Det gick inte att lägga till bilderna.'
raiserror(@errMess, 16, 1)
end
else
commit tran
end
end
end try

begin catch
raiserror(@errMess, 16, 1)
rollback tran
return
end catch
</code>


Svara

Sv: Lägger in för många poster

Postades av 2007-11-27 10:14:24 - Håkan Borneland

När @numOfPics blir större än 0, och du går in i WHILE satsen blir den en evighetsloop.
Villkoret i WHILE satsen blir alltid sant, då du aldrig räknar ner @numOfPics.

/Håkan


Svara

Sv:Lägger in för många poster

Postades av 2007-11-27 13:31:26 - Magnus Hallberg

Räknar ner gör jag ju med denna rad:
delete from tempPic
where userSession = @userSession and pic = @picName

Eller? Den ska ju radera posten, alltså måste ju @numOfPics bli en mindre varvet efter?


Svara

Sv: Lägger in för många poster

Postades av 2007-11-27 13:51:40 - Håkan Borneland

Nej.
För att @numOfPics ska bli mindre måste den tilldelas ett nytt värde.
Du tilldelar numOfPics värdet med SELECT satsen före WHILE-loopen, sedan rör du den inte mer.
Den blir inte tilldelat något bara för att du tar bort något i en tabell.
SELECT-satsen som tilldelar @numOfPics värdet ligger utan för WHILE-loopen.
Om du vill fånga upp ett nytt COUNT(*) värde, efter din DELETE får du köra SELECT-satsen igen
efter DELETE, och tilldela resultatet till @numOfPics.

/Håkan


Svara

Sv:Lägger in för många poster

Postades av 2007-11-27 14:30:45 - Magnus Hallberg

Ja så dum man kan vara! Ska prova detta ikväll.


Svara

Sv: Lägger in för många poster

Postades av 2007-11-27 21:59:07 - Andreas Hillqvist

Varför inte något sådanthär:

ALTER proc [IsellItAdmin].[moveTempPic]
@userSession        varchar(256),
@advertiseID        int
as
set nocount on

DECLARE @errMess VARCHAR(100)
DECLARE @intErrorCode INT

BEGIN TRAN
	INSERT INTO AdvertisePics (AdvertiseID, AdvertisePic)
	SELECT @advertiseID, pic
	FROM tempPic
	WHERE userSession = @userSession

	IF (@intErrorCode <> 0) GOTO PROBLEM

	DELETE FROM tempPic
	WHERE userSession = @userSession

	IF (@intErrorCode <> 0) GOTO PROBLEM

COMMIT TRAN

PROBLEM:
IF (@intErrorCode <> 0) BEGIN
	ROLLBACK TRAN
	SET @errMess = 'Det gick inte att lägga till bilderna.'
	RAISERROR(@errMess, 16, 1)
END


MEn frågan är om du behöver två tabeller? Är det inte bättre/enklare med en bildtabelle med en flagga i?

Edit:
Glömde PROBLEM labeln. ÄR nu tillagd ovan.


Svara

Sv:Lägger in för många poster

Postades av 2007-11-28 12:39:14 - Magnus Hallberg

ska testa ditt förslag Andreas. Jag tänkte ha bara en tabell från början, problemet är dock att jag inte vet advertiseID när bilderna läggs in i tempPic. Alltså måste jag lägga in annonsen och få det id:t innan jag kan lägga in bilderna.


Svara

Sv: Lägger in för många poster

Postades av 2007-11-28 23:50:30 - Magnus Hallberg

Det verkar funka kanon:)


------EDIT----------

Glömde att jag skulle fråga ett par saker om din kod. Den verkar ju vara smidigare än min:) Vi fick lära oss på en kurs att det kunde bli problem med "GOTO" och att det var bättre att skriva koden så som jag ahr gjort, stämmer det? om något skulle gå fel, var ändrar du värdet på @intErrorCode?


Svara

Sv:Lägger in för många poster

Postades av 2007-11-29 18:30:28 - Andreas Hillqvist

Du kan ha rätt. Du kan ju använda:

ALTER proc [IsellItAdmin].[moveTempPic]
@userSession        varchar(256),
@advertiseID        int
as
set nocount on

SET XACT_ABORT ON;
GO

BEGIN TRAN
    INSERT INTO AdvertisePics (AdvertiseID, AdvertisePic)
    SELECT @advertiseID, pic
    FROM tempPic
    WHERE userSession = @userSession

    DELETE FROM tempPic
    WHERE userSession = @userSession

COMMIT TRAN


Eller:
ALTER proc [IsellItAdmin].[moveTempPic]
@userSession        varchar(256),
@advertiseID        int
as
set nocount on

BEGIN TRAN
    BEGIN TRY

        INSERT INTO AdvertisePics (AdvertiseID, AdvertisePic)
        SELECT @advertiseID, pic
        FROM tempPic
        WHERE userSession = @userSession

        DELETE FROM tempPic
        WHERE userSession = @userSession
    END TRY
    BEGIN CATCH
        RAISERROR('Det gick inte att lägga till bilderna.', 16, 1)
        ROLLBACK TRAN
    END CATCH;
COMMIT TRAN


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 617
27 953
271 709
5 726
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