Page 1
Ouverture de la Connexion
Sélection d'une
base de données
Affichage de
la liste des
tables de la
base de
données
choisie
Requête pour afficher,
ajouter, supprimer,
modifier le contenu
d'une ou plusieurs
tables de la base de
données choisie
Requête de
Création d'une
nouvelle table
dans la base de
données choisie
Requête de
Suppression d'une
table de la base de
données choisie
Requête de
modification de la
structure d'une table
de la base de
données choisie
Exécution de la requête
Affichage de la valeur
de la rubriques
(champs) concernée
par la requête
Affichage du type
d'une rubrique en
particulier
Type=caractère,
numérique, date etc…
1
2
3
4
5
6
7
8
9
10
11
13
12
Fermeture de la
connexion
14
Page 2
ASP
Gestion de base de données
num
Code ASP
Commentaires
1
Set objc=Server.CreateObject("ADODB.Connection")
objc est la variable ne votre choix
Connexion
2
Base="DRIVER={Microsoft Access Driver (*.mdb)};"
& "DBQ=" &
Server.MapPath("repertoire/bd.mdb")&";PWD=;"
objc.open base
Sélection de la base de données
Ouverture d'une base de données nommée
bd.mdb dans le sous-dossier : repertoire
3.1
r1="select rubrique,rubrique2 from table where
condition"
condition = rubrique signe(=, <>, <, >) contenu
r1 est la variable ne votre choix
Requête de sélection
Exemple
Select nom from client where ville='nice'
Pour sélectionner les clients niçois
3.2
r1="delete from table where condition"
Exemple de condition
Prix<=200 ou DateInscription>#01/01/2000#
Requête de suppression
Exemple
delete from client where achat<>'télé'
pour supprimer les clients n'ayant pas acheté une télé
3.3
r1="insert into table (rubrique1,rubrique2) values
(contenu rubrique1,contenu rubrique2) where condition"
si rubrique1 est de type texte alors
mettre entre apostrophes: 'contenu rubrique1'
Requête d'ajout
Exemple
Insert into client (nom,age) values
('Dupond',40)
Pour ajouter monsieur Dupond de 40 ans
3.4
r1="update table set rubrique1=contenu1,
rubrique2=contenu2 where condition"
si contenu rubrique1 est de type texte alors
mettre entre apostrophes: 'contenu1'
Requête de mise à jour
Exemple
Update client set age=age+1 where
nom='dupond'
Pour ajouter 1à l'age de Dupond
4
r1="create table nom de la table (rubrique1 type (taille)
option, rubrique2 type (taille) option…)"
type: char pour caractère, int pour entier
float pour décimal, datetime pour date et heure
Option : null ou not null ou primary key
(rubrique1,rubrique2)
Requête création d'une nouvelle table
Exemple
Create table client (nom char(15) not null,
age int)
Pour ajouter la table client contenant les
rubriques nom de type chaîne et age entier
5
r1="drop table nom de la table à supprimer"
Requête suppression d'une table
Exemple
drop table client
Pour supprimer la totalité de la table client
6
r1="alter table nom de la table caractéristique";
caractéristique=add rubrique type (taille) pour ajouter
une rubrique à la table
ou drop rubrique pour supprimer une rubrique de la
table
Requête modification structure de la table
Exemple
Alter table client add datenais date
Pour ajouter la rubrique datenais de type
Date à la table client , la taille n'est pas
indiquée pour les rubriques de type Date
7
set ListeTable =objc.OpenSchema(20)
Do while not ListeTable.eof
If ListeTable("table_type")="TABLE" then
rem utilisez ListeTable("table_name")
rem pour exploiter le nom des tables
End If
ListeTable.MoveNext
Loop
ListeTable est la variable de votre choix
Boucle de récupération de la liste des
tables d'une base de données
ListeTable("table_name") contient le nom de la
table
ListeTable("table_type") peut contenir le mot
TABLE ou le mot
VIEW pour une requête
MoveNext indique le passage à la fiche suivante
8
set rs=objc.execute(requete,,Num)
rs est la variable de votre choix
objc est la variable de connexion
requete contient le texte de la requête SQL
num=1 si commande SQL
num=2 si table dans la base de données
num=4 si requête dans la base de données
Permet d'exécuter la requête
Exemple:
r1="delete from client where nom like 'A*'"
set rs=objc.execute(r1,,1)
supprime les clients dont le nom commence par
un A
Page 3
ASP
Gestion de base de données
num
Code ASP
Commentaires
9
r1="select count(*) as nombre from table where condition(s)"
set rs=objc.execute(r1,,1)
rs("nombre") contient le résultat
Requête statistique
Affichage du nombre d'enregistrements
concerné par la requête
10.1
NbRubrique=rs.fields.count
NbRubrique est la variable de votre choix
Affichage du nombre de rubriques
(champs) concerné par la requête
10.2
rs.fields.item(0).name--nom de la 1ere rubrique
rs.fields.item(1).name- nom de la 2ème rubrique
etc…
Affichage du nom des rubriques (champs)
concerné par la requête
10.3
r1="select * from achats"
set rs=objc.execute(r1,,1)
nb=rs.fields.count
for i=0 to nb-1
rem exploitation des rubriques avec rs.fields.item(i).name
next
Boucle d'affichage du nom de l'ensemble
des rubriques de la table Achats
11
rs.fields.item(0).value-contenu de la 1ère rubrique
rs.fields.item(1).value-contenu de la 2ème rubrique
on peut aussi utiliser rs("nom") ou rs("prix") etc…
si ce sont des rubriques de la table
Affichage du contenu des rubriques
Do while not rs.eof
Rem affichage des noms avec rs("nom")
rs.movenext
Loop
12
rs.fields.item(0).actualsizetaille 1ère rubrique
rs.fields.item(1).actualsizetaille 2ème rubrique
on peut aussi utiliser rs("nom").actualsize
Affichage de la taille de la rubrique
13
rs.fields.item(0).type-type de la 1ère rubrique
on peut aussi utiliser rs("nom").type
Type de donnée possible
3= entier long, 6= monétaire , 135=date ,
200 =texte
14
objc.close:set objc=nothing
Fermeture de la connexion
E
X
E
M
P
L
E
<html><body bgcolor=pink>
<%set db= Server.CreateObject("ADODB.Connection")
Base="DRIVER={Microsoft Access Driver (*.mdb)};" & "DBQ=" &
Server.MapPath("base/bd.mdb")&";PWD=;"
db.open base
r1="select * from achats";
set rs=db.execute(r1,,1)
r1="select count(*) as nb from achats";
set rs=db.execute(r1,,1)
%>
nombre : <b><%=rs("nb")%></b>
<%r1="select * from achats";
set rs=db.execute(r1,,1)%>
nombre de rubriques<%=rs.fields.count%><br>
<table border=1><tr bgcolor=white>
<%for k=0 to rs.fields.count-1%>
<td><b><%=rs.fields.item(k).name%></b></td>
<%next%>
</tr>
<%do while not rs.eof%>
<tr>
<%for k=0 to rs.fields.count-1%>
<%if isNull(rs.fields.item(k).value) then%>
<td>&nbsp;</td>
<%else%>
<td><%=rs.fields.item(k).value%></td>
<%end if%>
<%next%>
</tr>
<%rs.movenext
loop%>
</table><%db.close:set db=nothing%><body></html>
//connexion
//selection de la base de données
//selection de tous les champs
et exécution de la requête
//affichage du nombre d'enregistrement
//affichage du nombre de rubriques concerné
// affichage du contenu dans un tableau
Boucle d'affichage du nom des rubriques
Boucle d'affichage du contenu
Test de la longueur du champ, si égale à 0
Alors on affiche &nbsp; c'est à dire un espace
Fermeture de la connexion
1 / 3 100%
La catégorie de ce document est-elle correcte?
Merci pour votre participation!

Faire une suggestion

Avez-vous trouvé des erreurs dans linterface ou les textes ? Ou savez-vous comment améliorer linterface utilisateur de StudyLib ? Nhésitez pas à envoyer vos suggestions. Cest très important pour nous !