Designed by NoKi !
73 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 (58 818 hits)
Didier Téléchargez gratuitement et légalement des logiciels Microsoft ! Si, si ;)
  • Visual Studio 2010
  • Office 2010
  • Expression Studio 3
  • SQL Server 2008
  • et d'autres...
Au fil des news  
Adobe - Adobe lance des applications Photoshop Express....
PHP - Détermination de l'intersection entre 2 segments
Magazines - Le N°132 de Programmez est disponible
Les alertes dans SharePoint 2007 - Comment SharePoint 2007 gère les User Alerts
Une des fonctionnalités de base de SharePoint, aussi bien dans Windows SharePoint Services (WSS) ...
Adobe - Photoshop.com Mobile pour Android 1.2
Adobe - Adobe dévoile une technologie de lecture.......
PHP - Experts PHP : participez au Forum PHP 2010 !
PHP - Fobec.com - Code source PHP & javascript
Foliotage alphabétique - Lister sur la première lettre d'un champ
Pour faire suite à l'article de JPierre sur la pagination alphabétique, voici, en ASP et en PHP, ...
Dreamweaver CS4 + Php + Mysql - Pagination alphabétique
Je vous propose la création d'une barre de navigation ou pagination alphabétique pour filtrer les ...
Adobe - HTML5 dans Dreamweaver CS5
VBScript - Déterminer si un chemin est absolu ou relatif
VBScript - Lire/écrire un fichier texte
Magazines - Le N°130 de Programmez est disponible
Hebergement - Hébergement à prix libre
Adobe - Adobe Creative Suite 5
PHP - Calcul de la date de Pâques
Magazines - Le N°128 de Programmez est disponible
Magazines - Le N°127 de Programmez est disponible
Dreamweaver CS4 + Php + Mysql - Trucs et Astuces - Part 6
Pour continuer dans le même style, je vous propose une suite au précédent article. Rechercher tous ...
Adobe - Adobe Photoshop.com Mobile pour iPhone 1.1
JavaScript - Ajouter une page dans vos favorites
Dreamweaver CS4 + Php + Mysql - Trucs et Astuces - Part 5 -
Je vous propose cette fois deux astuces. Comment exporter une feuille de style avec l'aide de ...
SharePoint Personalization Site Links - Les liens personnalisés des MySite SharePoint
Nous avons vu dans les articles précédents comment agrémenter les pages de recherche afin de ...
Magazines - Le n°126 de Programmez est disponible
Outils - Traducteur en ligne automatique pour site web
Adobe - Adobe Photoshop.com Mobile pour Iphone
Magazines - Le n°125 de Programmez est disponible
Adobe - Adobe AIR 2 et Flash Player 10.1version bêta
Les conférences autour des technologies Microsoft - Liste non exhaustive des grands évènements
Nous allons essayer de regrouper un grand nombre des évènements autour des technologies Microsoft ...
Magazines - Le n°124 de Programmez est disponible
PHP - Forum PHP 2009
Composants - eFace - XAML en Java
WPF - Désactiver le bouton de réduction d'une fenêtre
Magazines - Le n°123 de Programmez est disponible
Magazines - Le n°122 de Programmez est disponible
Auditer une ferme SharePoint - Assurer le bon fonctionnement de SharePoint
Dans le cadre de la bonne gestion de son environnement SharePoint, il est utile de faire un ...
SQL Server 2008 Report Builder 2.0 - Installation et utilisation de Report Builder 2.0
Dans le cadre de la création de rapports pour SQL Server Reporting Services 2008, un outil est ...
Magazines - Le HS N° 1 de Web Design est disponible
Outils - EntityBuilder
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
 MVP TechNet ASP-magazine Groupes Utilisateurs Microsoft DotNet Project