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!
ADO vs. Access
7
1058
Vastaukset
- 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 IfMoikka
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 thenIf 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
Naiset miltä kiihottuminen teissä tuntuu
Kun miehellä tulee seisokki ja ja sellainen kihmelöinti sinne niin mitä naisessa köy? :)755534Haistoin ensin tuoksusi
Käännyin katsomaan oletko se todellakin sinä , otin askeleen taakse ja jähmetyin. Moikattiin naamat peruslukemilla. Tu242476- 261957
- 551694
- 121591
Miksi kohtelit minua kuin tyhmää koiraa?
Rakastin sinua mutta kohtelit huonosti. Tuntuu ala-arvoiselta. Miksi kuvittelin että joku kohtelisi minua reilusti. Hais51388- 91307
Kyllä poisto toimii
Esitin illan suussa kysymyksen, joka koska palstalla riehuvaa häirikköä ja tiedustelin, eikö sitä saa julistettua pannaa91269"Joka miekkaan tarttuu, se siihen hukkuu"..
"Joka miekkaan tarttuu, se siihen hukkuu".. Näin puhui jo aikoinaan Jeesus, kun yksi hänen opetuslapsistaan löi miekalla71229- 141193