Accueil > > > RÉCUPÉRER UN ID AU HASARD D'UNE BASE DE DONNÉE ACCESS
RÉCUPÉRER UN ID AU HASARD D'UNE BASE DE DONNÉE ACCESS
Information sur la source
Description
Source
- // mes objets de connexion à ma base de donnée
- <%
- dim mydb
- dim oConn
- dim oRs
- dim varsql
-
- mydb = "DBQ=c:\\\\inetpub\\\\database\\\\mydatabase.mdb;Driver={Microsoft Access Driver (*.mdb)};DriverId=25"
- set oConn = server.createobject("ADODB.Connection")
- oConn.Open mydb
- set oRs = server.createobject("adodb.recordset")
- %>
-
-
- // ma boucle qui lance la fonction jusqu'à ce que l'ID obtenu existe
- <%
- do while id_ok = 0 'tant que l'id_ok est égal à 0 on execute la fonction
- gen_id()
- loop
- response.write mygen_id & " est l'ID séléctionné au hasard de ma table"
- %>
-
- // ma fonction qui récupère l'id au hasard
- <%
- function gen_id()
- varsql = "SELECT max(image.id) as max_id, min(image.id) as min_id FROM image" 'la requête SQL qui selectionne l'id le plus bas et le plus haut
- oRs.open varsql, oConn 'j execute la requete
- max_id = oRs.fields("max_id") 'j attribue l'ID le plus haut à la variable
- min_id = oRs.fields("min_id") 'j attribue l'ID le plus bas à la variable
-
- oRs.close 'je ferme mon recordset
- Randomize ' je genère un nombre entre max_id et min_id MyValue = Int((max_id - min_id + 1) * Rnd + min_id)
-
- varsql = "SELECT id FROM image WHERE id = " & myvalue 'la requete SQL qui vérifie que le numero généré existe
- oRs.open varsql, oConn 'j execute la requete
- if oRs.eof then 'si le recordset est vide
- id_ok = 0
- else 's il n est pas vide, l'ID existe
- id_ok = 1
- mygen_id = myvalue 'mygen_id est maintenant la variable qui contient l'ID séléctionné au hasard!!
- end if
- oRs.close 'on ferme le recordset
- end function 'fin de la fonction
- %>
// mes objets de connexion à ma base de donnée
<%
dim mydb
dim oConn
dim oRs
dim varsql
mydb = "DBQ=c:\\\\inetpub\\\\database\\\\mydatabase.mdb;Driver={Microsoft Access Driver (*.mdb)};DriverId=25"
set oConn = server.createobject("ADODB.Connection")
oConn.Open mydb
set oRs = server.createobject("adodb.recordset")
%>
// ma boucle qui lance la fonction jusqu'à ce que l'ID obtenu existe
<%
do while id_ok = 0 'tant que l'id_ok est égal à 0 on execute la fonction
gen_id()
loop
response.write mygen_id & " est l'ID séléctionné au hasard de ma table"
%>
// ma fonction qui récupère l'id au hasard
<%
function gen_id()
varsql = "SELECT max(image.id) as max_id, min(image.id) as min_id FROM image" 'la requête SQL qui selectionne l'id le plus bas et le plus haut
oRs.open varsql, oConn 'j execute la requete
max_id = oRs.fields("max_id") 'j attribue l'ID le plus haut à la variable
min_id = oRs.fields("min_id") 'j attribue l'ID le plus bas à la variable
oRs.close 'je ferme mon recordset
Randomize ' je genère un nombre entre max_id et min_id MyValue = Int((max_id - min_id + 1) * Rnd + min_id)
varsql = "SELECT id FROM image WHERE id = " & myvalue 'la requete SQL qui vérifie que le numero généré existe
oRs.open varsql, oConn 'j execute la requete
if oRs.eof then 'si le recordset est vide
id_ok = 0
else 's il n est pas vide, l'ID existe
id_ok = 1
mygen_id = myvalue 'mygen_id est maintenant la variable qui contient l'ID séléctionné au hasard!!
end if
oRs.close 'on ferme le recordset
end function 'fin de la fonction
%>
Conclusion
J'ai pensé que ca pourrait etre utile pour certain vu comme j'ai galeré pour trouver une solution. Imaginons que vous avez un site avec un album photo (beaucoup de photo) et que vous décidez de faire une page qui afficherais une photo au hasard tout les jours. Toutes les infos de vos photos sont bien sur stockées dans une base de donnée access. Illustration de la table IMAGE: ID (n° auto; clé primaire) | image (texte)
pour info: lorsqu'une image est supprimée de la table son ID n'existe plus, il y a donc un trou (ex: 32, 34, 35). C'est à cause de cela que ce système est plus compliqué :)
Voilà maintenant pour séléctionner un ID au hasard parmis les 1000 présents dans la table je fonctionne de la manière suivante: - on selectionne dans la table IMAGE l'ID le plus bas et le plus haut (ex: 3 et 700) - on génère un n° au hasard compris entre l'ID le plus bas (3) et l'ID le plus haut (700) - on regarde si le n° génèré existe dans la table IMAGE - s'il existe, on affiche l'image, sinon on regenere un n° etc...
Bien entendu avec les explications données une image au hasard s'affichera à chaque visite sur la page et non chaque jour (pour 1 tout les jours il suffit de créer une 2eme table avec un seul enregistrement qui comprend l'ID de l'image et la date d'affichage puis faire une comparaison des date et executer le script ou non)
Si y a des questions posez les. A+
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
L'INTERFACE NATURELLE DE WINDOWS PHONE 7 SERIESL'INTERFACE NATURELLE DE WINDOWS PHONE 7 SERIES par odewit
La tendance est aux interfaces naturelles (NUI), et le keynote de Bill Buxton au MIX l'a bien souligné.
La charte graphique et ergonomique de Windows Phone 7 a donc été entièrement repensée en vue d'obtenir un maximum d'efficacité sur ce point. En re...
Cliquez pour lire la suite de l'article par odewit COMMENT MAPPER UNE VUE SQL SUR UNE COLLECTION DE COMPLEX TYPE?COMMENT MAPPER UNE VUE SQL SUR UNE COLLECTION DE COMPLEX TYPE? par Matthieu MEZIL
Avec EF, les vues doivent être mappées sur des entity types. Le problème c'est que les entity types doivent avoir une clé. Avec EF, nous avons les complex type qui n'ont pas de clé mais les vues ne peuvent pas être mappées dessus. Avec EF4, il est possibl...
Cliquez pour lire la suite de l'article par Matthieu MEZIL [WF4] UN BINDING ACTIVITY/ACTIVITYDESIGNER QUI PASSE MAL?[WF4] UN BINDING ACTIVITY/ACTIVITYDESIGNER QUI PASSE MAL? par JeremyJeanson
Certain d'entre vous on peut être vécu cette situation embarrassante après quelques temps passer avec WF4 : Au début avec mon " ActivityDesigner" , tout allait bien. Et puis un jour j'ai au des problèmes de " Binding" . Alors nous sommes allé sur le site ...
Cliquez pour lire la suite de l'article par JeremyJeanson
Forum
UTILISATEURUTILISATEUR par zaydounhlel
Cliquez pour lire la suite par zaydounhlel RE : VIRUSRE : VIRUS par ghuysmans99
Cliquez pour lire la suite par ghuysmans99
Logiciels
Academy System (10.9.4.0)ACADEMY SYSTEM (10.9.4.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods
|