IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Access Discussion :

Javascript sql access


Sujet :

Access

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mars 2004
    Messages : 178
    Points : 94
    Points
    94
    Par défaut Javascript sql access
    Bonjour,

    je récupère des infos depuis un slider:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    amount = document.getElementById("amount").value;
    p1 = amount.substring(0,2);	
    Pref1 = p1 * 12 // nombre de mois	
    var now = new Date();
    now.setMonth(-Pref1);
    now me donne une info du genre : Thu Jan 01 1988 08:22:37 GMT+0100(europe de l'Ouest)

    j'aimerai passer cette information dans une chaîne sql:

    Age est un champ de type date

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    sqlMain = "select Pays FROM Membres WHERE Pays LIKE '%"&str & "%' and Sex = " & "'" & genre & "'" & " and Age < " & "#" & now & "#" & "  order by Pays ASC"
    Or apparemment la chaîne ne fonctionne pas à cause du format retourné par le javascript: Thu Jan 01 1988 08:22:37 GMT+0100(europe de l'Ouest)

    comment transformer cette valeur pour être utilisable dans une chaîne SQL ?

    merci d'avance !


    ----------------------------------------------------------------------------------------------------------

    J'ai crée une page de test :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
     
    <!doctype html>
    <html lang="en">
    <head>
    	<meta charset="UTF-8" />
    	<title>TestSQL</title>
    </head>
    <body><%
     
    strAccessDB = "/Base/xx.mdb"
    DSN_BASE2 = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" & Server.MapPath(strAccessDB)
    Set CONN2 = Server.CreateObject("ADODB.Connection")
    CONN2.Open DSN_BASE2
     
    str = "Australien"
    genre = "Homme"
    pref1 = "Thu Jan 01 1988 08:22:37 GMT+0100(europe de l'Ouest)"
     
    'Set rs = Server.CreateObject("ADODB.RecordSet")
    sqlMain = "select Pays FROM Membres WHERE Pays = 'Australien' and Sex = " & "'" & genre & "'" & " and Age < " & "#" & pref1 & "#" & " order by Pays ASC" 
    rs.Open sqlMain, CONN2,3,2,1
     
    rs.close
    set rs = nothing
     
    CONN2.close
    set CONN2 = nothing %>
     
    </body>
    </html>
    cela me donne une erreur 500

  2. #2
    Membre émérite Avatar de Zekraoui_Jakani
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    1 670
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2013
    Messages : 1 670
    Points : 2 489
    Points
    2 489
    Par défaut
    A mon humble avis, "Thu Jan 01 1988 08:22:37 GMT+0100(europe de l'Ouest)" n'est pas reconnu comme date dans SQL; il faudrait donc décomposer cette info pour en extraire une date standard du style "myDate = datevalue("jan 1 1988")" pour pouvoir l'exploiter dans la chaîne sql.

    Pour décomposer le texte, il faudra utiliser les fonctions MID et InStr. Exemple avec MID:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    myStr = "Thu Jan 01 1988 08:22:37 GMT+0100(europe de l'Ouest)"
    myStr = mid(myStr,5,11)
    myDate = datevalue(myStr)
    debug.print myDate
    On peut dès lors exploiter myDate entourée de '#' dans votre SQL

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mars 2004
    Messages : 178
    Points : 94
    Points
    94
    Par défaut
    J'ai essayé le code dans ma page de test et cela fonctionne, néanmoins dans mes pages qui traitent différemment les informations cela ne marche pas: J'ai une erreur 500 ( autocompletePaysR.asp)


    indexR.asp

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
     
    <script>
     
    function autocompletePays(arg, genre, pref1, pref2){
    			var objxhr = xhr_connect()
    			if (objxhr){
    				objxhr.onreadystatechange = function(){
    					if (objxhr.readyState == 4) {
    						if (objxhr.status == 200) {
    							var retour = objxhr.responseText
    							var n = retour.substring(27, 29)
    							ret = document.getElementById("retourP")
    							retV = ret.value
     
    							if (n != "]}" && ret.value != ""){
     
    								var html = '<ul>';
    								var json = eval( '('+ retour + ')' );							
    								for (var i =0;i<8;i++){							
    									if (json.suggestions[i] != undefined){
    										html += "<li id='l' onClick='remp4(this)'><span>" + json.suggestions[i] + "</span></li>"
    									}
    								}
    								html += '</ul>'
     
    								if (html != "<ul><li id='l' onClick='remp4(this)'><span></span></li></ul>"){										
    									ret.innerHTML = html
    									ret.style.display = "block"																						
    									ret.style.zIndex = 3
    								}
    								else{
    									ret.style.display = "none"
    								}							
    							}	
    						}
    					}
    				}
    				var sql = "str="+arg+"&genre="+genre+"&pref1="+pref1+"&pref2="+pref2
    				objxhr.open("Post", "autocompletePaysR.asp", true)				
    				objxhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded; charset=utf-8');				
    				objxhr.send(sql)
    			} else {
    				alert("")
    			}
    		}
     
    function pref1(){
    					amount = document.getElementById("amount").value;
    					p1 = amount.substring(0,2);	
    					Pref1 = p1 * 12 // nombre de mois	
    					var now = new Date();
    					now.setMonth(-Pref1);	
     
    					return now;			
    				}
     
    				function pref2(){
    					amount = document.getElementById("amount").value;
    					p2 = amount.substring(5,7);	
    					Pref2 = p2 * 12 // nombre de mois	
    					var now = new Date();
    					now.setMonth(-Pref2);	
     
                                           return now;			
    				}
    </script>
     
    plus loin....
     
     
    <input type="text" id="pays" name="pays" autocomplete="off" onKeyUp="autocompletePays(this.value, contrR(), pref1(), pref2())" class="form-control">


    autocompletePaysR.asp
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
     
    <%@ CODEPAGE = 65001 %>
    <%
     
    str = UCase(request.form("str"))
    genre = request.form("genre")
    pref1 = request.form("pref1")
    pref2 = request.form("pref2")
    Dim rsMain,sqlMain,rettxt,JobOpenToArr
     
    myStr = pref1
    myStr = mid(myStr,5,11)
    myDate = datevalue(myStr)
     
    myStr2 = pref2
    myStr2 = mid(myStr2,5,11)
    myDate2 = datevalue(myStr2)
     
    strAccessDB = "/Base/xx.mdb"
    DSN_BASE2 = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" & Server.MapPath(strAccessDB)
    Set CONN2 = Server.CreateObject("ADODB.Connection")
    CONN2.Open DSN_BASE2
     
    Set rsMain = Server.CreateObject("ADODB.RecordSet")
    sqlMain = "select Pays FROM Membres WHERE Pays LIKE '%"&str & "%' and Sex = " & "'" & genre & "'" & " and Age < " & "#" & myDate & "#" & " and Age > " & "#" & myDate2 & "#" & "  order by Pays ASC" 
    rsMain.Open sqlMain, CONN2,3,2,1
     
    if Not rsMain.Eof  Then
         rettxt = "{localite:""" & str & """, suggestions:["
         JobOpenToArr = rsMain.getRows()
     
         For i = 0 to UBound(JobOpenToArr,2)          
    	     extrac = UCase(Left(JobOpenToArr(0,i), len(str)))	     
    	     if extrac = str then
    	     	rettxt = rettxt & """" & JobOpenToArr(0,i) & ""","       
    	     end if
         Next
     
         rettxt = left(rettxt,len(rettxt)-1)
         rettxt = rettxt & "]}"
         Response.Write rettxt     
    else
    	rettxt = "{localite:""" & str & """, suggestions:["   
    	rettxt = rettxt & """" & undefined & ""","
    	rettxt = left(rettxt,len(rettxt)-1)
    	rettxt = rettxt & "]}"
        Response.Write rettxt
    end if
     
    %>

    je viens de tester la ligne de code qui provoque une erreur 500 dans autocompletePaysR est c'est celle ci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    ......
    myStr = pref1
    myStr = mid(myStr,5,11)
    myDate = datevalue(myStr)   ' C'est ici que cela plante .............................................................................................................

  4. #4
    Membre émérite Avatar de Zekraoui_Jakani
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    1 670
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2013
    Messages : 1 670
    Points : 2 489
    Points
    2 489
    Par défaut
    Après l'instruction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    myStr = mid(myStr,5,11)
    , mettez l'instruction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Debug.Print, "le contenu de myStr est : ", myStr
    Ainsi, vous verrez la source de l'erreur; l'erreur peut être due soit aux paramètres "5,11", soit au format de la date (USA vs Europe).

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2004
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mars 2004
    Messages : 178
    Points : 94
    Points
    94
    Par défaut
    Avec Firefox en regardant dans le débogueur, je me suis aperçu que je récupèrais ainsi les paramètres (autocompletePaysR.asp)

    Pref1: SatJan03198812:01:53GMT 0100
    Pref2: TueJan03193912:01:536MT 0100

    J'ai modifidié la function : autocompletePays(arg, genre, pref1, pref2)

    et ajouté ceci

    pref1 = encodeURIComponent(pref1)
    pref2 = encodeURIComponent(pref2)

    le problème et résolu ! :-)

    merci !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Javascript][SQL]Rafraîchissement d'une liste
    Par Aurore M dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 09/02/2005, 17h11
  2. [SQL/access] Doublon sur un champ
    Par kor dans le forum Langage SQL
    Réponses: 7
    Dernier message: 21/01/2005, 11h21
  3. [date][javascript][sql] récupération dans un formulaire
    Par Shaud7 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 16/12/2004, 15h45
  4. [SQL Access] Modifier la structure d'une table
    Par Le Lézard dans le forum Bases de données
    Réponses: 6
    Dernier message: 28/06/2004, 14h03
  5. [SQL][ACCESS]Compter le nombres d'enregistrement dans deux..
    Par pc152 dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 05/06/2004, 12h30

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo