Précédent   Forum des professionnels en informatique > Bases de données > Oracle > SQL
SQL Forum d'entraide sur le SQL pour Oracle
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 13/07/2011, 13h51   #1
Invité régulier
 
Inscription : avril 2008
Messages : 17
Détails du profil
Informations forums :
Inscription : avril 2008
Messages : 17
Points : 8
Points : 8
Par défaut Formulaires access tables Oracle

Bonjour,
voici mon problème.
J'ai une base Access avec des formulaires et des requêtes. Je dois transférer cette base sous Oracle au plus vite. J'ai donc transférer mes tables sous Oracle et les ai liées dans Access. J'ai ensuite vérifié mes formulaires. Jusqu'ici tout va bien, sauf que quand je veux ajouter un nouvel enregistrement les clés primaires de mes tables (ID automatiques sous Access) ne se remplissent pas automatiquement. Comment faire?
Merci
baly5 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/07/2011, 13h56   #2
Expert Confirmé
 
Homme
Inscription : mai 2002
Messages : 1 638
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 29
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : mai 2002
Messages : 1 638
Points : 2 630
Points : 2 630
Bonjour,


Il n'y a pas de de clef à incrémentation automatique sous Oracle.

Il va falloir passer par des trigger + sequence.

un exemple :

la table
Code :
1
2
 
CREATE TABLE test (id number, testdata varchar2(255));
la sequence :
Code :
1
2
3
4
5
 
CREATE sequence test_seq 
start WITH 1 
increment BY 1 
nomaxvalue;
le trigger :
Code :
1
2
3
4
5
6
7
 
CREATE TRIGGER test_trigger
before INSERT ON test
FOR each row
begin
SELECT test_seq.NEXTVAL INTO :new.id FROM dual;
end;
il y a plein d'autre exemple sur google, recherchez avec : oracle pk autoincrement
punkoff est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/07/2011, 14h27   #3
Invité régulier
 
Inscription : avril 2008
Messages : 17
Détails du profil
Informations forums :
Inscription : avril 2008
Messages : 17
Points : 8
Points : 8
Merci pour votre réponse.
Ça fonctionne bien apparemment mais suis-je sûre qu'il n'y aura pas de problèmes de conflits avec les valeurs déjà définie par Access?
Est-ce que la fait d'avoir déclarer l'id en clé primaire fera en sorte que la sequence attribuera des valeurs différentes à celles déjà présentes (venant d'Access)?
baly5 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/07/2011, 14h39   #4
Expert Confirmé
 
Homme
Inscription : mai 2002
Messages : 1 638
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 29
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : mai 2002
Messages : 1 638
Points : 2 630
Points : 2 630
hmm,

il faudrait que vous initialisiez votre séquence au max actuel de l'id de votre table.


Je vous laisse cherchez pour la manip.
punkoff est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/07/2011, 14h54   #5
Membre Expert
 
Avatar de Garuda
 
Homme Philippe CHIRCOP
Chef de projet
Inscription : juin 2007
Messages : 1 109
Détails du profil
Informations personnelles :
Nom : Homme Philippe CHIRCOP
Localisation : France

Informations professionnelles :
Activité : Chef de projet
Secteur : Bâtiment

Informations forums :
Inscription : juin 2007
Messages : 1 109
Points : 1 559
Points : 1 559
Une sequence + un trigger "for update on each row"
__________________
Garuda गरूड
Brahmâ la Guerre et Vishnu la Paix

Oracle 10.2.0.4 - Forms6i patch 17 - Toad 11.1 - sharePoint 2010
Garuda est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 13/07/2011, 15h03   #6
Invité régulier
 
Inscription : avril 2008
Messages : 17
Détails du profil
Informations forums :
Inscription : avril 2008
Messages : 17
Points : 8
Points : 8
Oui évidemment!!
Merci beaucoup je n'ai plus qu'à faire cela pour chacune de mes tables et je devrais pouvoir entrer les données dans Oracle via mes formulaires Access!
baly5 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 00h05.


 
 
 
 
Partenaires

Hébergement Web