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ång SP

Postades av 2007-11-17 00:46:48 - Magnus Hallberg, i forum sql-server/msde, Tråden har 3 Kommentarer och lästs av 972 personer

Jag har en SP som blev rätt lång och som jag tror går att korta ner en hel del. Det jag vill göra med den är att sätta in en annons, sen kan man ha max fem bilder till annonsen som ska in i en annan tabell. Detta körs då givetvis i en transaktion. SP fungerar som den är men jag tycker att det borde gå att lösa insättningen av bilderna på ett annat sätt än jag har gjort. Är ju alltid bra om man får lära sej nåt nytt också:) jag har funderat på om det inte skulle gå att köra någon while eller nåt? Så här ser den ut idag:

<code>
alter proc addAdvertise
@typeOfCustomerID int,
@lanID int,
@categoryID int,
@typeOfAdvertiseID int,
@name varchar(50),
@mail varchar(150),
@phone varchar(20),
@cellPhone varchar(20),
@zipCode varchar(6),
@header varchar(100),
@text text,
@price money,
@password varchar(20),
@pic1 varchar(150) = null,
@pic2 varchar(150) = null,
@pic3 varchar(150) = null,
@pic4 varchar(150) = null,
@pic5 varchar(150) = null
as

set nocount on
declare @errMess varchar(100)
declare @returnID int
begin try
begin tran
insert into Advertises(typeOfCustomerID, lanID, categoryID, typeOfAdvertiseID, [name], mail, phone, cellPhone, zipCode, header, [text], price, isApproved, password, inDate)
values(@typeOfCustomerID, @lanID, @categoryID, @typeOfAdvertiseID, @name, @mail, @phone, @cellPhone, @zipCode, @header, @text, @price,
'False', @password, getdate())
if(@@rowcount <> 1)
begin
set @errMess = 'Det gick inte att lägga in annonsen, var god försök igen.'
raiserror(@errMess, 16, 1)
end
else
begin
select @returnID = @@identity
if(@pic1 is null)
begin
commit tran
return @returnID
end
else
begin
insert into AdvertisePics(AdvertiseID, AdvertisePic)
values(@returnID, @pic1)
if(@@rowcount <> 1)
begin
set @errMess = 'Det gick inte att lägga in annonsen, var god försök igen.'
raiserror(@errMess, 16, 1)
end
else
begin
if(@pic2 is null)
begin
commit tran
return @returnID
end
else
begin
insert into AdvertisePics(AdvertiseID, AdvertisePic)
values(@returnID, @pic2)
if(@@rowcount <> 1)
begin
set @errMess = 'Det gick inte att lägga in annonsen, var god försök igen.'
raiserror(@errMess, 16, 1)
end
else
begin
if(@pic3 is null)
begin
commit tran
return @returnID
end
else
begin
insert into AdvertisePics(AdvertiseID, AdvertisePic)
values(@returnID, @pic3)
if(@@rowcount <> 1)
begin
set @errMess = 'Det gick inte att lägga in annonsen, var god försök igen.'
raiserror(@errMess, 16, 1)
end
else
begin
if(@pic4 is null)
begin
commit tran
return @returnID
end
else
begin
insert into AdvertisePics(AdvertiseID, AdvertisePic)
values(@returnID, @pic4)
if(@@rowcount <> 1)
begin
set @errMess = 'Det gick inte att lägga in annonsen, var god försök igen.'
raiserror(@errMess, 16, 1)
end
else
begin
if(@pic5 is null)
begin
commit tran
return @returnID
end
else
begin
insert into AdvertisePics(AdvertiseID, AdvertisePic)
values(@returnID, @pic5)
if(@@rowcount <> 1)
begin
set @errMess = 'Det gick inte att lägga in annonsen, var god försök igen.'
raiserror(@errMess, 16, 1)
end
else
begin
commit tran
return @returnID
end
end
end
end
end
end
end
end
end
end
end
end try

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

En sak som inte fungerar är "return @returnID" varför gör det inte det? Jag måste verkligen få med id tillbaka.

--------------------------EDIT-------------------------
Det där med return löste jag. hade ju missat att ha med "select @returnID", när jag ändrade till detta så fungerade det.
<code>
set @returnID = @@identity
select @returnID
</code>
Resten av koden ser likadan ut. Kvarstår gör dock om det går att lösa insättningen av bilderna på nåt enklare sätt?


Svara

Sv: Lång SP

Postades av 2007-11-17 11:24:17 - Ola Lindfeldt

Du kan ju bryta ut den här koden

if(@pic1 is null)
begin

-----

end

till en egen procedure eller function

så att du helt enkelt kör fem st anrop

execute MyInsert @Id1, @pic1
execute MyInsert @Id1, @pic2
execute MyInsert @Id1, @pic3
....


Svara

Sv:Lång SP

Postades av 2007-11-17 13:55:48 - Magnus Hallberg

Ja det var smart, det ska jag prova. jag återkommer om jag får problem.


Svara

Sv: Lång SP

Postades av 2007-11-18 12:37:39 - Magnus Hallberg

Funkade klockrent!


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 730
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