Designed by Maunakea !
80 en ligne   Boutique | Sites | Bar | Forum | PhpBB | Actu | Glossaire | Codes | Tips | Liens | Livres | Lettre  


 Recherche

 NewsLetter





   

Etude de l'objet Recordset

ASP et les ActiveX Data Objects






1 . INTRODUCTION

CestPasDur
Pour communiquer avec une base de donnée, nous devons utiliser en ASP les ActiveX Data Objects (ADO).
Le recordset (jeu d'enregistrement) est certainement l'objet ADO le plus utilisé, puiqu'il contient l'ensemble des données extraites de nos sources (base de données, XML,...), celui-ci contient une collection fields qui contient à son tour un objet field pour chaque champ ou colonne du jeu d'enregistrement.


Il permet de :

  • Lire les informations contenues dans une base de données
  • Insérer des informations dans celles-ci
  • Mettre à jour des informations
  • En supprimer.

2 . le schéma type d'un recordset :

 
colonne 1
colonne 2
colonne 3
colonne 4  
Rangée 1
Objet field
Objet field
B.O.F
•••••••
Objet field
Objet field
 
•••••••



•••••••
Objet field
Objet field
E.O.F
 
}collection fields1 ou instance
Rangée 2   }collection fields2
 
 
 
 
Rangée n   }collection fields n

Propriétés de l'objet field
Value Contient les données issues de notre source de données
Name Contient le nom de la colonne à laquelle est associée l'objet
Type Type de données contenues dans la cellule (chaîne de caractères, date, integer...)
Precision Correspond au nombre maximal pouvant être utilisé par des valeurs numériques
NumericScale Nombre de décimales des valeurs numériques
DefinedSize Taille maximale exprimée en octet, que peut contenir la cellule
Actualsize Taille verritable des données actuellement contenues dans la cellule


exemple : pour afficher la taille actuelle de l'objet field rangée 1 colonne 1 nous devons nous positionner sur la premiere instance

<%
RS_liste.MoveFirst
Response.write( RS_liste.fields("colonne 1").Actualsize)

%>

2 . Les paramètres du Recordset


Lors de l'ouverture d'un recordset, il est possible de passer des paramètres à celui-ci :

ObjetRecordset.Open source, ActiveConnection, CursorType, Locktype, Options

Paramètres à passer en ouvrant le recordset
Source Source de données, cela peut être le nom d'une table d'une base de données, une procédure stockée...
ActiveConnection Connexion à utiliser pour le recordset.
CursorType Type de curseur à utiliser. (cf CursorType ).
LockType Type de verrous (cf Locktype ).
Options Indique au fournisseur l'argument source : c.a.d s'il s'agit d'une table ou d'une chaîne de texte

 

2.1 Types de curseurs

Curseurs
Statique (static, adOpenStatic ) Les curseurs statiques contiennent une copie statique du jeu d'enregistrement. Toute modification sur la base de donnée ne sera pas visible sur le recordset
Le déplacement dans le recordset se fait alors en avant et en arrière
Forward-only (forwardonly, adOpenForwardOnly ). C'est le curseur par default, identique au curseur statique, à la différence que le déplacement dans le recordset ne se fait que vers l'avant.
Dynamique ( Dynamic, adOpenDynamic ). Il ne contient pas de nombre fixe d'enregistrement. Toute modification effectuée sur la base de donnée et répercutée sur le Recordset. Déplacement avant et arrière possible.
Jeu de clés (keyset, adOpenKeySet ). Identique au curseur dynamique à ceci près que le jeu d'enregistrement est figé : tout ajout sur la base de donnée ne sera pas repercuté sur le Recordset.
Les modifications seront prises en compte.
Pour toute suppression dans la base, les données correspondantes ne seront plus accessibles.

 

2.2 Types de verrous

Verrous
Lecture seule (adLockReadOnly). Verrou par defaut. Le jeu d'enregistrement ne peut être modifié.
Pessimiste (adLockPessimistic). Lors de la modification d'un enregistrement, le fournisseur tente de verrouiller celui-ci afin de garantir le succès de la modification. Le verrouillage intervient dès l'édition.
Optimiste ( adLockOptimistic). L'enregistrement n'est pas verrouillé tant que l'on n'a pas fait appel à la méthode update.
Optimiste par lots (adLockBatchOptimistic). Idem que pour le verrouillage optimiste à la différence que cette fois-ci le verrouillage concerne plusieurs enregistrements et que la méthode à utiliser est : UpdateBatch

2.3 ADOVBS.INC

Les constantes adOpenStatic, adLockReadOnly, adOpenDynamic et les autres utilisées pour définir les types de verrous et de curseur ne sont pas directement intégrées aux ASP.

Il existe deux façons de passer des paramètres à l'ouverture du recordset :

OBJ_RS.Open "table",OBJ_connexion,0,1

ou
OBJ_RS.Open "table",OBJ_connexion,adOpenForwardOnly,adLockReadOnly

La deuxième ligne de code est équivalente à la première, à la différence que en utilisant les constantes définies dans le fichier ADOVBS.INC la lecture est plus simple et pas besoin de chercher la valeur des constantes.

 

 


CestPasDur le 09/04/2007 (52 010 hits)
Didier Téléchargez 1200 Partitions Gratuites !!!
Au fil des news  
Amélioration du Search MOSS : Les scopes - Quelques possibilités d'amélioration du Search
Lorsqu'on installe le moteur de recherche de MOSS et qu'on le configure basiquement, on veut ...
SharePoint - Lister les templates utilisés - Identifier les définitions utilisées par vos sites
Un site SharePoint est créé à partir d'un modèle ou définition de site. Mais comment savoir après ...
PowerShell - Profile avec la participation de mon ami Tigrou :)
Adobe - Lancement de la CS4, tous à vos agendas !
[MAJ] PHP - Fonctions de redimensionnement d'images - BD : redimensionner image + picto après upload
Ajout de FONCTIONS de redimensionnement.
PHP - Tchat PHP V2.1 sans base de donnée
SharePoint et les statistiques d'utilisation - Comment obtenir des statistiques depuis SharePoint
La mise en place de ferme SharePoint doit s'accompagner d'une notion de gouvernance. Cette notion ...
Adobe - Nouvelles annonces Adobe sur le salon IBC 2008
PHP - PHP TV emission 2 (septembre 2008)
PHP - PDO ADMIN
[MAJ] Inscription contrôlée à une NewsLetter ou Service - Abonnement avec confirmation et désabonnement
Correction d'un point-virgule manquant (merci de m'avoir obligé à chercher JPierre) dans le module ...
PHP - Premier lundi d'une semaine et d'une année
JavaScript - Premier lundi d'une semaine et d'une année
ASP - Premier lundi d'une semaine et d'une année
Alphabet Radio et Code Morse - Alpha Zulu appelle Tango Charlie !
Encoder-Décoder en "Alphabet Radio" ... "Alpha Zulu appelle Tango Charlie !" ou en Code Morse ... ...
Filtrer les modèles de site SharePoint - Filtrer l'affichage des modèles de site SharePoint
Je vous propose de découvrir à l'aide de cet article quels mécanismes peuvent vous permettent de ...
ASP/PHP - Méthode de cryptage - par table de correspondance
(ASP/PHP) Une méthode de cryptage de données par l'utilisation d'une "table de correspondance ...
PHP - Listes liées (1 table) - version2
JavaScript - Rendre Visible ou Invisible des éléments d'un form
PHP - Listes liées (1 table) - version1
JavaScript - Intercepter le click sur vidéo WMP ou flash SWF
[MAJ] Une base de données sans base de données - Comment travailler avec des fichiers texte ?
Modification du paramétrage du dossier à scanner dans le popup qui permet de sélectionner l'image.
Jeux de l'été (et de 5) - Un jeu de Motus (mots de 8 lettres)
C'est reparti pour un tour... Comme je venais de proposer un jeu de Mastermind, je me suis dit que, ...
PowerShell - Extraire toutes les collections SharePoint en CSV
PowerShell - Lister les collections pour une WebApp SharePoint
PowerShell - Lister les utilisateurs d'un site SharePoint
PowerShell - Connaître le code version de votre SharePoint
Connaître la version de SharePoint installée - Comment savoir la version de SharePoint en cours
Dans le cadre de la maintenance de plusieurs fermes SharePoint, il est indispensable de connaître ...
PowerShell - Travailler avec une base de données SQL Server
.NET - Visual Studio 2008 sur Facebook : çà rock's
PowerShell - Ajouter des liens sur deux niveaux dans SharePoint
Un petit annuaire perso avec photo - en PHP et MySQL
Avoir des copains et des amis c'est bien que dis-je c'est même vital pour le bien être de chacun. ...
Une base de données sans base de données - Comment travailler avec des fichiers texte ?
Suite à une question sur le forum (les habitués me connaissent), je propose une mini-gestion de ...
ASP/PHP : Affichage de données en tableau html - Afficher des données (BD, Array) dans un tableau
Création d'un tableau "à la volée" pour afficher ses données. Affichage "en ligne" ou "en ...
PowerShell - Ajouter une liste dans un site SharePoint
Annuaire d'entreprise en PHP - Très pratique pour ne plus rien perdre
Mon petit annuaire d'entreprise, je m'en sers tous les jours alors autant vous en faire profiter. ...
PHP-MySQL : Formulaire - pour le script 'Bon anniversaire' de DB77
Formulaire et script d'enregistrement pour le script « Bon anniversaire » de DB77 en PHP/MySQL ...
.NET - Introducing Microsoft Silverlight 2.0, 2nd Edition
PHP5 - Upload de fichiers - Classe PHP
PHP - PHP 5 /MYSQL® 5
Tutorial : HTML | Scripting | ASP-PHP | ASP.net | SQL Server | XML
Sharepoint | XAML | Pocket | Dreamweaver | VML | Divers
  Scripts : Scripting | ASP-PHP | ASP.net | Divers
  Boutique | Annuaire | Bannières | Météo | Tribune | Partenariats
v3 © Didier 2003   
 

Corpo Sciences de Reims Partitions gratuites Carte, météo, annonces
 Groupes Utilisateurs Microsoft DotNet Project El Roubio MVP CodePPC TechNet ASP-magazine The Inquirer FR Wygwam Codes Sources