Insertion de données
Le langage SQL fournit des instructions pour ajouter des nouveaux tuples à une relation. Il offre ainsi une interface standard pour ajouter des information dans une base de données.
Il existe deux moyens d'ajouter des données, soit par fourniture directe des valeurs des propriétés du tuple à ajouter, soit par sélection des tuples à ajouter dans une autre relation.
Syntaxe : Insertion directe de valeurs
INSERT INTO <Nom de la relation> (<Liste ordonnée des propriétés à valoriser>)
VALUES (<Liste ordonnée des valeurs à affecter aux propriétés spécifiées ci-dessus>)
Exemple : Insertion directe de valeurs
INSERT INTO Virement (Date, Montant, Objet)
VALUES (14-07-1975, 1000, 'Prime de naissance');
Syntaxe : Insertion de valeurs par l'intermédiaire d'une sélection
INSERT INTO <Nom de la relation> (<Liste ordonnée des propriétés à valoriser>)
SELECT ...
L'instruction SELECT projetant un nombre de propriétés identiques aux propriétés à valoriser.
Exemple : Insertion de valeurs par l'intermédiaire d'une sélection
INSERT INTO Credit (Date, Montant, Objet)
SELECT Date, Montant, 'Annulation de débit'
FROM Debit
WHERE Debit.Date = 25-12-2001;
Dans cet exemple tous les débits effectués le 25 décembre 2001, sont re-crédités pour le même montant (et à la même date), avec la mention annulation dans l'objet du crédit. Ceci pourrait typiquement réalisé en cas de débits erronés ce jour là.
Remarque :
Les propriétés non valorisées sont affectées à la valeur NULL.
Il est possible de ne pas spécifier les propriétés à valoriser, dans ce cas, toutes les propriétés de la relation seront considérées, dans leur ordre de définition dans la relation (à n'utiliser que dans les cas les plus simples).