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
1100
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
Tänään pyörit ajatuksissa enemmän, kun erehdyin lukemaan palstaa
En saisi, silti toivon että sinä vielä palaat ja otetaan oikeasti selvää, hioituuko särmät ja sulaudummeko yhteen. Vuod225124- 254278
- 272441
- 342234
- 371988
- 151908
En ole koskaan kokenut
Ennen mitään tällaista rakastumista. Tiedän että kaipaan sinua varmaan loppu elämän. Toivottavasti ei tarvitsisi vain ka191587- 121521
Voi ei! Jari Sillanpää heitti keikan Helsingissä - Hämmästyttävä hetki lavalla...
Ex-tangokuningas on parhaillaan konserttikiertueella. Hän esiintyi Savoy teatterissa äitienpäivänä. Sillanpää jakoi kons211237Kerranki asiat oikein
Ilkka ja muut pienpuolueeet...teitte hyvän työn kun valitsitte pätevän henkilön virkaan eikä kepulle passelia!! Jatkakaa101164