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


Skicka in värden till en SP

Postades av 2004-02-24 09:16:54 - Henric Bjärehäll, i forum sql-server/msde, Tråden har 1 Kommentarer och lästs av 713 personer

Jag har problem att skicka in en massa id till min SP, hur ska jag göra?

getArticlesSearch 1
detta alternativ fungerar.

getArticlesSearch 1,2,3,4
detta alternativ fungerar inte

Vilken datatyp ska jag ha inne i SPn för att kunna ta emot flera id? Måste jag sedan konventera om den så att den passar in i "WHERE id IN"? Hur gör jag detta?

<code>
stored procedure getArticlesSearch
@pid int
as
SELECT * FROM tbl_table WHERE id IN @pid
</code>


Svara

Sv: Skicka in värden till en SP

Postades av 2004-02-24 10:06:37 - Pelle Johansson

Hej,

Du testar alternativet att skicka in 1 respektive 4 variabler. Om du tänker dig att sp:n är precis som en funktion eller subrutin så måste samma antal parametrar deklareras som du skickar in. Du använder ett IN-kommando och hade det INTE varit det så hade du kunnat skriva

getArticlesSearch '1,2,3,4'

Men inget är ju som man tänkt sig. Först får du byta ut deklarationen int till varchar, men det hjälper tyvärr inte. Det som händer här är att du skickar in en sträng och det kan inte hanteras av IN-kommandot så tyvärr får du gå två andra vägar.

1. Bygg hela sql-satsen i ditt utvecklingsverktyg och kör det med set rst = con.execute(sql)

2. Du får göra en sträng av hela din sats och flika in datat du skickar och sedan köra

<info>
create procedure getArticlesSearch
@pid varchar(2000)
as
declare @sql varchar(2000)
set @sql = 'SELECT * FROM tbl_table WHERE id IN(' + @pid + ')'
exec (@sql)
</info>

I båda fallen kommer proceduren inte vara optimerad eftersom den inte kan valideras rent syntaxmässigt och därmed även ligga cachad. En variant därmed är att skriva proceduren så den hämtar alla fält som motsvarar de id:n du vill lägga i ditt in-kommando

<info>
create procedure getArticlesSearch
@userid int
as
SELECT * FROM tbl_table WHERE id IN(
select id from tabell where userid = tbl.table.id
)


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 619
27 953
271 709
546
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