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


Knivig sqlsats - utsökning med flera villkor på samma fält

Postades av 2005-11-04 17:48:37 - Fredrik Edström, i forum databaser, Tråden har 5 Kommentarer och lästs av 890 personer

Jag har en tabell med 2 fält, id och egenskap. Inget av fältet är unikt.
Nu vill jag få ALLA id som svarar upp till ALLA de egenskaper jag anger.
Ex
Jag söker långa, starka & blonda.

Tabellen

|--id--|--egenskap--|
| 1 | stark |
| 2 | lång |
| 1 | lång |
| 2 | blond |
| 1 | blond |

här vill jag ha 1 som svar, då 1 är både lång, stark och blond. 2 endast lång och blond

Hur skriver man en effektiv sqlsats för detta?


Svara

Sv: Knivig sqlsats - utsökning med flera villkor på samma fält

Postades av 2005-11-04 17:59:02 - Ola Lindfeldt

SELECT DISTINCT id
FROM Tabellen
WHERE egenskap IN ('a','b','c')


Svara

Sv: Knivig sqlsats - utsökning med flera villkor på samma fält

Postades av 2005-11-04 21:03:53 - Andreas Hillqvist

Förutsätter att kombinationen ID tillsamans med egenskap är unik. Ett id kan inte ha dubblet av en egenskap.

SELECT egenskaper.id
FROM egenskaper
WHERE egenskap In ("blond","lång","stark")
GROUP BY id
HAVING Count(*)=3;


tre står för antalet sökkriterier.

Du skulle kuna ta bort Having och istället sortera på antalet för att få den med flest matchande egenskaper:

SELECT TOP 1 id
FROM egenskaper
WHERE egenskap In ("blond","lång","stark")
GROUP BY id
ORDER BY Count(*) DESC, id;


Svara

Sv:Knivig sqlsats - utsökning med flera villkor på samma fält

Postades av 2005-11-05 12:58:15 - Fredrik Edström

Det där fungerade bra, TACK.
Men om jag tex vill ha de med minst 2 av de tre kriterierna uppfyllda typ blonda, starka och sedan "vad som helst". Hur gör jag då? Frågan skall alltså vara dynamisk. Antingen kan man ange EXAKT villka egenskaper man vill eller bara någon.
Provade att lägga in ett % tecken i ett av de 3, men det fungerade inte så bra:-(


Svara

Sv: Knivig sqlsats - utsökning med flera villkor på samma fält

Postades av 2005-11-05 14:25:14 - Per Persson

För att få de med minst 2 av de tre kriterierna, byt ut HAVING Count(*)=3 mot HAVING Count(*)>=2.


Svara

Sv:Knivig sqlsats - utsökning med flera villkor på samma fält

Postades av 2005-11-06 20:53:19 - Fredrik Edström

klockrent, och genom att byta ut antalet mot en variabel blir dynamiken fulländad.


Svara

Nyligen

  • 18:42 Hvor finder man håndlavede lamper
  • 18:41 Hvor finder man håndlavede lamper
  • 16:36 Allt du behöver veta om keramiskt
  • 16:14 Vem anlitar man egentligen när tak
  • 16:14 Vem anlitar man egentligen när tak
  • 16:13 Vem anlitar man egentligen när tak
  • 11:52 Noen erfaring med uttak hos Mostbe
  • 11:51 Noen erfaring med uttak hos Mostbe

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 570 654
27 958
271 741
1 338
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