ADO vs. Access

MRA

Pientä apua pyydetään. Kun lähetän parametrinä sql-lausekkeen ASP-sivulla Recordset objektille käyttämällä metodia Open ja sql lausekkeessa käytän LIKE avainsanaa ADO:lla yhtään tulosta ei synny mutta kun kokeilen aivan samaa kyselyä suoraan Accessista, toimii loistavasti. Mikä on pielessä, onko se ODBC-ajuri vai ADO:n dll joka tuottaa ongelmia? Apuva!

7

1103

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • aspisti

      Moikka

      Et ilmeisesti saa minkäänlaista virheilmoitusta mistään???

      Laita koodi, mitä tarkoitat, niin katsotaan mitä sieltä löytyy.

      T.Aspisti

      • MRA

        Ei tule minkäänlaista virheilmoitusta, vaan recordset-objekti ei palauta yhtään tulosta kun taas Accesissa tuloksia löytyy.

        Homma toimii tähän tapaan:

        Set rec = Server.CreateObject("ADODB.Recordset")

        rec.Open sqllauseke, dsnyhteys

        If Not (rec.BOF And rec.EOF) Then
        'koodia
        Else
        Response.Write "Ei tietueita"
        End If


      • aspisti
        MRA kirjoitti:

        Ei tule minkäänlaista virheilmoitusta, vaan recordset-objekti ei palauta yhtään tulosta kun taas Accesissa tuloksia löytyy.

        Homma toimii tähän tapaan:

        Set rec = Server.CreateObject("ADODB.Recordset")

        rec.Open sqllauseke, dsnyhteys

        If Not (rec.BOF And rec.EOF) Then
        'koodia
        Else
        Response.Write "Ei tietueita"
        End If

        Moikka

        Tarkasta, missä järjestyksessä muodostat ja availet yhteyden, recorsetin ja missä laitat sql-kyselyn sekä sql-lauseen syntaksi. jos noi ovat varmasti oikein niin sitten mietis mitä toi If lause tarkoittaa

        If Not (rec.BOF And rec.EOF)
        Jos ei ole(rec.alussa ja rec.lopussa)

        Voivatko molemmat ehdot täyttyä jos tietueita löytyy???

        En tiedä mitä oikein olet tekemässä, mutta
        muuttaisin If;iä sillai että ensimmäinen ehto pois, eli laittaisin näin

        If Not rec.EOF then


      • MRA
        aspisti kirjoitti:

        Moikka

        Tarkasta, missä järjestyksessä muodostat ja availet yhteyden, recorsetin ja missä laitat sql-kyselyn sekä sql-lauseen syntaksi. jos noi ovat varmasti oikein niin sitten mietis mitä toi If lause tarkoittaa

        If Not (rec.BOF And rec.EOF)
        Jos ei ole(rec.alussa ja rec.lopussa)

        Voivatko molemmat ehdot täyttyä jos tietueita löytyy???

        En tiedä mitä oikein olet tekemässä, mutta
        muuttaisin If;iä sillai että ensimmäinen ehto pois, eli laittaisin näin

        If Not rec.EOF then

        If Not (rec.BOF And rec.EOF)

        tarkoittaa että kursori ei osoita tyhjään, eli tuloksia löytyy 1..N kappaletta, mutta asia ei liity tähän koska käytän tätä kontrollia aina ja se toimii. Sql-lauseke on oikein kuten aiemmin sanoin ja se toimii Accessissa. dsnyhteys -muuttuja on oikein muodostettu koska samaa muuttujaa käytän monessa muussa yhteyden luonnissa ja niissà se toimii. Siispä ihmeteltäväksi jää miksi kysely ei palauta tuloksia ADO:lla vaikka kaikki tuntuu olevan kondiksessa.


      • Ellit
        MRA kirjoitti:

        If Not (rec.BOF And rec.EOF)

        tarkoittaa että kursori ei osoita tyhjään, eli tuloksia löytyy 1..N kappaletta, mutta asia ei liity tähän koska käytän tätä kontrollia aina ja se toimii. Sql-lauseke on oikein kuten aiemmin sanoin ja se toimii Accessissa. dsnyhteys -muuttuja on oikein muodostettu koska samaa muuttujaa käytän monessa muussa yhteyden luonnissa ja niissà se toimii. Siispä ihmeteltäväksi jää miksi kysely ei palauta tuloksia ADO:lla vaikka kaikki tuntuu olevan kondiksessa.

        Kerro kuitenkin se SQL-lause. ADO ja ODBC asettavat tietyt SQL-asetukset kuten SET ANSINULL ON/OFF, näin ainakin SQL Serverillä. Erityisesti kiinnostaa mitä on LIKE:n jälkeen, pitäisi olla jotakin näin:

        SELECT * FROM Customer WHERE FirstName LIKE 'Elli%'

        -lainausmerkit eivät välttämättä kelpaa (riippuu asetuksista), käytä heittomerkkejä
        -Huomaa % lopussa, driver / ADO saattaa täyttää kentän välilyönneillä, eli ilman prosenttia näin:
        ... LIKE 'Elli ' ja sitten pitää tietty olla oikea määrä välilyöntejä.


      • Ellit
        Ellit kirjoitti:

        Kerro kuitenkin se SQL-lause. ADO ja ODBC asettavat tietyt SQL-asetukset kuten SET ANSINULL ON/OFF, näin ainakin SQL Serverillä. Erityisesti kiinnostaa mitä on LIKE:n jälkeen, pitäisi olla jotakin näin:

        SELECT * FROM Customer WHERE FirstName LIKE 'Elli%'

        -lainausmerkit eivät välttämättä kelpaa (riippuu asetuksista), käytä heittomerkkejä
        -Huomaa % lopussa, driver / ADO saattaa täyttää kentän välilyönneillä, eli ilman prosenttia näin:
        ... LIKE 'Elli ' ja sitten pitää tietty olla oikea määrä välilyöntejä.

        Niin tuossa jälkimmäisessä stringissä eivät näy loppuun laittamani apaut 40 välilyntiä:

        ... LIKE 'Elli______________________________'


      • MRA
        Ellit kirjoitti:

        Kerro kuitenkin se SQL-lause. ADO ja ODBC asettavat tietyt SQL-asetukset kuten SET ANSINULL ON/OFF, näin ainakin SQL Serverillä. Erityisesti kiinnostaa mitä on LIKE:n jälkeen, pitäisi olla jotakin näin:

        SELECT * FROM Customer WHERE FirstName LIKE 'Elli%'

        -lainausmerkit eivät välttämättä kelpaa (riippuu asetuksista), käytä heittomerkkejä
        -Huomaa % lopussa, driver / ADO saattaa täyttää kentän välilyönneillä, eli ilman prosenttia näin:
        ... LIKE 'Elli ' ja sitten pitää tietty olla oikea määrä välilyöntejä.

        Homma toimii kiitos vaan avusta. Microsoft Jet-ajurilla kuitenkin käytetään %-merkkiä eikä *-merkkiä jolla Accessissa toimii Like-komento.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Poliisi: Kymmenhenkinen pohjalaisperhe ollut vuoden kateissa kansainvälinen etsintäkuulutus Poliis

      Poliisi: Kymmenhenkinen pohjalaisperhe ollut vuoden kateissa – kansainvälinen etsintäkuulutus Poliisi pyytää yleisön apu
      Maailman menoa
      282
      2584
    2. Tässä totuus jälleensyntymisestä - voit yllättyä

      Jumalasta syntyminen Raamatussa ei tässä Joh. 3:3. ole alkukielen mukaan ollenkaan sanaa uudestisyntyminen, vaan pelkä
      Jälleensyntyminen
      300
      1379
    3. Mitään järkeä?

      Että ollaan erillään? Kummankin pää on kovilla.
      Ikävä
      108
      1251
    4. En kadu sitä, että kohtasin hänet

      mutta kadun sitä, että aloin kirjoittamaan tänne palstalle. Jollain tasolla se saa vain asiat enemmän solmuun ja tekee n
      Ikävä
      83
      1241
    5. Noniin rakas

      Annetaanko pikkuhiljaa jo olla, niin ehkä säilyy vienot hymyt kohdatessa. En edelleenkään halua sulle tai kenellekään mi
      Ikävä
      97
      1198
    6. Oisko mitenkään mahdollisesti ihan pikkuisen ikävä..

      ...edes ihan pikkuisen pikkuisen ikävä sulla mua??.. Että miettisit vaikka vähän missähän se nyt on ja oiskohan hauska n
      Ikävä
      58
      1185
    7. Lapuan sanomissa käy rytinä

      Pistivät sitten päätoimittajan pihalle
      Lapua
      45
      1053
    8. Helena Koivu : Ja kohta mennään taas

      Kohta kohtalon päivä lähestyy kuinka käy Helena Koivulle ? Kenen puolella olet? Jos vastauksesi on Helenan niin voisi
      Kotimaiset julkkisjuorut
      71
      946
    9. Au pair -työ Thaimaassa herättää kiivasta keskustelua somessa: "4cm torakoita, huumeita, tauteja..."

      Au pairit -sarjan uusi kausi herättää keskustelua Suomi24 Keskustelupalvelussa. Mielipiteitä ladataan puolesta ja vastaa
      Tv-sarjat
      22
      900
    10. Oot ihana

      Toivottavasti nähdään sattumalta jonain kesäpäivänä♥️🥺🫂
      Ikävä
      33
      797
    Aihe