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

1080

    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. Miehille kysymys

      Onko näin, että jos miestä kiinnostaa tarpeeksi niin hän kyllä ottaa vaikka riskin pakeista ja osoittaa sen kiinnostukse
      Tunteet
      132
      3807
    2. Miksi kaivattusi on

      erityinen? ❤️‍🔥
      Ikävä
      85
      1895
    3. Olen tosi outo....

      Päättelen palstajuttujen perusteella mitä mieltä minun kaipauksen kohde minusta on. Joskus kuvittelen tänne selkeitä tap
      Ikävä
      15
      1741
    4. Haluaisin jo

      Myöntää nämä tunteet sinulle face to face. En uskalla vain nolata itseäni enää. Enkä pysty elämäänkin näiden kanssa jos
      Ikävä
      54
      1402
    5. Ylen uutiset Haapaveden yt:stä.

      Olipas kamalaa luettavaa kaupungin irtisanomisista. Työttömiä lisää 10 tai enempikin( Mieluskylän opettajat). Muuttavat
      Haapavesi
      123
      1284
    6. VENÄJÄ muuttanut tänään ydinasetroktiinia

      Venäjän presidentti Vladimir Putin hyväksyi tiistaina päivitetyn ydinasedoktriinin, kertoo uutistoimisto Reuters. Sen mu
      Maailman menoa
      96
      1258
    7. Kotkalainen Demari Riku Pirinen vangittu Saksassa lapsipornosta

      https://www.kymensanomat.fi/paikalliset/8081054 Kotkalainen Demari Riku Pirinen vangittu Saksassa lapsipornon hallussapi
      Kotka
      37
      1229
    8. Nainen olet valoni pimeässä

      valaiset tietäni tietämättäsi ❤️
      Ikävä
      70
      1146
    9. Mitä toivot

      Tulevilta päiviltä?
      Ikävä
      69
      1023
    10. Hommaatko kinkkua jouluksi?

      Itse tein pakastimeen n. 3Kg:n murekkeen sienillä ja juustokuorrutuksella. Voihan se olla, että jonkun pienen, valmiin k
      Sinkut
      102
      985
    Aihe