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


Filtrering av record set

Postades av 2006-06-07 16:35:13 - Jenny Lindroth, i forum visual basic - allmänt, Tråden har 2 Kommentarer och lästs av 767 personer

Skulle behöva filtrera ett recordset i VB men får inte riktigt till det. Det jag är ute efter är att få in (x = true/false OR x = null) AND (y = true/false OR y = null) AND (z = ...) osv

Får då följande felmedd:
Run-time error '3001':
Arguments are of the wrong type, are out of acceptable range, or are inconflict with one another.

Har även testat att kolla (x <> not true/false) AND (y <> not true/false) osv men då fungerar inte NULL-kontrollen (dvs de rader som har värdet NULL filtrerars bort).

Finns det någon annan möjlighet el måste jag göra någon annan lönsing?

Tack tack i förhand!

/Jenny




Svara

Sv: Filtrering av record set

Postades av 2006-06-07 19:19:03 - Andreas Hillqvist

Från MSDN:
<info>
# There is no precedence between AND and OR. Clauses can be grouped within parentheses. However, you cannot group clauses joined by an OR and then join the group to another clause with an AND, like this:

(LastName = 'Smith' OR LastName = 'Jones') AND FirstName = 'John'

# Instead, you would construct this filter as

(LastName = 'Smith' AND FirstName = 'John') OR (LastName = 'Jones' AND FirstName = 'John')

</info>

Här kommer ett litet exempel:

Option Explicit

Private Sub Command1_Click()
Dim rs As ADODB.Recordset
Dim fields As Variant
Dim values As Variant
Dim x As Variant, y As Variant, z As Variant
    Set rs = New ADODB.Recordset
    rs.fields.Append "x", adBoolean, , adFldIsNullable
    rs.fields.Append "y", adBoolean, , adFldIsNullable
    rs.fields.Append "z", adBoolean, , adFldIsNullable
    rs.Open
    
    fields = Array("x", "y", "z")
    values = Array(Null, False, True)
    For Each x In values
        For Each y In values
            For Each z In values
                rs.AddNew fields, Array(x, y, z)
            Next
        Next
    Next
    
    rs.MoveFirst
    rs.Filter = "(X = True AND Y = False) OR " + _
                "(X = True AND Y = Null) OR " + _
                "(X = Null AND Y = False) OR " + _
                "(X = Null AND Y = Null)"
    ListRecordset rs
    
    
    
End Sub

Private Sub ListRecordset(rs As ADODB.Recordset)
Dim field As ADODB.field
    Debug.Print "-------------------------------------------"
    For Each field In rs.fields
        Debug.Print field.Name,
    Next
    Debug.Print
    Debug.Print "-------------------------------------------"
    Do Until rs.EOF
        For Each field In rs.fields
            Debug.Print field.Value,
        Next
        Debug.Print
        rs.MoveNext
    Loop
End Sub


Svara

Sv:Filtrering av record set

Postades av 2006-06-08 17:31:22 - Jenny Lindroth

Jättebra tips! Dock är det så att jag har 7 olika parametrar att kolla så det blir lite för många kombinationer att få ihop. Funderar nu på att jobba med ett temporärt recordset o sen fylla det "riktiga" efter att ha gjort diverse kontroller (mha if-satser istället). Så nu ska jag bara klura ut hur jag gör det på ett bra sätt :)


Svara

Nyligen

  • 19:55 kick-off med fokus på hälsa?
  • 19:53 kick-off med fokus på hälsa?
  • 16:24 Föreslå en skönhetsklinik online
  • 16:23 Föreslå en skönhetsklinik online
  • 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

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 725
27 958
271 751
498
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