Designed by Maunakea !
53 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 (54 747 hits)
Didier Testez gratuitement la plateforme web de Windows Server 2008 !
Gagnez un voyage aux Etats-Unis pour la MS Project Conference !
Au fil des news  
Adobe - Adobe annonce MAX 2009 !
[MAJ] Dreamweaver MX + Php + MySql - Les formulaires - partie 3
Mise à jour du code, par DB 77, affichage du code erreur, dans la page erreur.php, traduction des ...
PHP - News avec photo - Système de gestion - affichage
Gestion - Administration - Affichage d'une "News", "Actualité", "Info", ... avec : - mise en forme ...
Dreamweaver Php Mysql - Région répétée imbriquée
Je rebondis, sur un post du forum, pour vous montrer comment obtenir grâce à l'extension Simulated ...
Gérer les bases de contenu SharePoint - Gérer la croissance du volume des données
Dans le cadre de la gestion quotidienne de ferme SharePoint, il existe une partie qu'il faut ...
PHP - Le Coach PHP sur Visual Studio
.NET - Ecrire une application .NET utilisant MySQL
PHP - Utilisation de PHP dans le monde Microsoft
Magazines - Le n° 119 de Programmez est disponible
Adobe - Adobe annonce Photoshop Marketplace
[MAJ] Tutoriel AJAX simple - En avant vers le WEB2.0
Mis à jour le 20/04/2009
Captcha «maison» sans extension - Et en plus, c'est gratuit ;)
Un ami m'a demandé de l'aide ce matin pour insérer un captcha dans un formulaire pour son site ...
Dreamweaver CS4 - Photoshop CS4 - Alliance parfaite pour la gestion des images
Pour changer un peu des pages de code, je vous propose de voir ensemble, la fonctionnalité très ...
JavaScript - Calcul automatique d'une facture
Amélioration du Search MOSS: Manipulation XSL - Utilisation du XSL dans l'affichage des résultats
Parmi tous les articles sur l'amélioration du moteur de recherche de Microsoft Office SharePoint ...
Outils - Editeur d'icônes IcoFX
Magazines - Le n°118 de Programmez est disponible
JavaScript - Imprimer une autre page que celle en cours
CSS - div pour imiter frame (Bandeau/Menu FIXES)
[MAJ] [PHP] Un calendrier très complet -
ajout des événements au calendrier
PowerShell - Winforms pour l'aide des commandes GET PowerShell
Adobe - Adobe Photoshop Lightroom 2 est offert ....
Amélioration du Search MOSS: synonyme et Best Bet - La gestion des synonymes dans MOSS Search
Le moteur de recherche de MOSS permet la configuration d'une liste de synonymes. Nous verrons donc ...
AJAX - récup champs formulaires pour POST en AJAX
PowerShell - Un windows Forms pour SharePoint en PowerShell
Sondage associatif (compatibilité) - Qui va bien avec qui ?
Cette fois, c'est un petit sondage que je vous propose. Il pourra bien sûr être adaptée à vos ...
ASP - Hashage MD5 (cryptage irréversible)
Adobe - 80% de réduction sur les versions Adobe Creative
CSharp - Interroger un serveur Whois
CSharp - Equivalent de la fonction PHP htmlentities()
CSharp - Somme de contrôle CRC32
Magazines - Le n°117 de Programmez est disponible
Hebergement - Hébergement ASP et ASP.Net
MOSS - Mon Profil - Personnalisation des profils utilisateurs de MOSS
La gestion des profils utilisateurs de SharePoint fait partie des fonctionnalités de base de ...
Dreamweaver CS3 + Php + Mysql - Le Jeu d'Enregistrements - Les fondamentaux Part-3
La 3ème partie des fondamentaux, traitera essentiellement du jeu d'enregistrements ou Recordset. ...
Mon mini-site @ Home - avec Windows, Free, Wamp & DynDNS
Envie d'héberger votre petit site chez vous, sur votre ordinateur ? de partager des fichiers avec ...
Magazines - Le n°116 de Programmez est disponible
Recevoir ses identifiants par mél - Bien pratique pour les petites têtes
Encore une question posée sur le forum et zou... Le problème est simple : On a oublié ses ...
ASP.NET - code pour le bouton enregistrer
Microsoft - Grand jeu-concours MSDN : l'indice d'ASP-PHP.net !
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
v3b © Didier 2003   
 

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