SQL Server由于主外键约束导致插入失败的记录方法
你打算从 SQL Server 2000 数据库的客户表和国别表中导入客户数据到 SQL Server 2005 数据库中。你要确保在导入过程中,客户表中国家代码列的每个值在 SQL Server 2005 数据库中国别表内都有其相应的纪录。你在两个表之间定义一外键,这样,参照完整性将保证
你打算从 SQL Server 2000 数据库的客户表和国别表中导入客户数据到 SQL Server 2005 数据库中。你要确保在导入过程中,客户表中国家代码列的每个值在 SQL Server 2005 数据库中国别表内都有其相应的纪录。你在两个表之间定义一外键,这样,参照完整性将保证若国家代码值在客户表中存在, 而在国别表中不存在时导入程序失败。 你要确保国别表无记录时导入过程不失败。--创建Department(deptID,deptName)和UserInfo(userID, userName, sex, loginDate,deptid) --其中deptID,userID是自动增长的,并且是主键。deptid是外键。并且插入测试数据 --创建序列 CREATE SEQUENCE seq_Dep START WITH 1 INCREMENT BY 1 NOMAXVALUE NOCYCLE CACHE 30; --建表Department CREATE TABLE Department ( deptID VARCHAR2(10) PRIMARY KEY, deptName VARCHAR2(20) ); --插入测试数据 INSERT INTO Department VALUES ('D'||seq_Dep.NEXTVAL,'人事部'); INSERT INTO Department VALUES ('D'||seq_Dep.NEXTVAL,'技术部'); INSERT INTO Department VALUES ('D'||seq_Dep.NEXTVAL,'后勤部'); INSERT INTO Department VALUES ('D'||seq_Dep.NEXTVAL,'经理部'); INSERT INTO Department VALUES ('D'||seq_Dep.NEXTVAL,'销售部'); INSERT INTO Department VALUES ('D'||seq_Dep.NEXTVAL,'服务部'); INSERT INTO Department VALUES ('D'||seq_Dep.NEXTVAL,'公关部'); COMMIT; --创建序列 CREATE SEQUENCE seq_User START WITH 1 INCREMENT BY 1 NOMAXVALUE NOCYCLE CACHE 30; --建表UserInfo CREATE TABLE UserInfo ( userID VARCHAR2(10) PRIMARY KEY, userName VARCHAR2(20), sex VARCHAR2(2), loginDate DATE, deptid VARCHAR2(10) REFERENCES Department (deptID) ); --插入测试数据 INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Eric Schmidt','男','12-9月-07','D1'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Larry Page','男','12-10月-07','D3'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Sergey Brin','男','12-11月-07','D5'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'W. M. Coughran, Jr.','男','1-12月-07','D4'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'David C. Drummond','女','12-12月-01','D2'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Alan Eustace','男','12-9月-07','D1'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Jeff Huber','男','12-10月-07','D3'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'George Reyes','男','12-11月-07','D5'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Elliot Schrage','男','1-12月-07','D4'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Tim Armstrong','女','12-12月-01','D2'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Nikesh Arora','女','12-12月-01','D2'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Sukhinder','男','12-9月-07','D1'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Vinton G. Cerf','男','12-10月-07','D3'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'George Reyes','男','12-11月-07','D5'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Dave Girouard','男','1-12月-07','D4'); INSERT INTO UserInfo VALUES ('U'||seq_User.NEXTVAL,'Singh Cassidy','女','12-12月-01','D2'); COMMIT; --3. 在deptid建立索引 CREATE INDEX deptid_index on UserInfo(deptid); --4. 给Department和UserInfo创建同义词,名称分别是dept, sy_user CREATE OR REPLACE SYNONYM dept FOR Department; CREATE OR REPLACE SYNONYM sy_user FOR UserInfo; /* 5. 通过同义词dept, user来创建视图, 视图要求能查询出“部门名称,部门编号,用户名,性别,注册时间” */ CREATE OR REPLACE VIEW view_dept_user ("部门名称","部门编号","用户名","性别","注册时间") AS SELECT d.deptName,d.deptID,u.userName,u.sex,u.loginDate FROM dept d ,sy_user u WHERE d.deptID=u.deptid; --14. 使用Instead Of触发器,往第5题创建的视图中插入数据。 SET SERVEROUTPUT ON; INSERT INTO view_dept_user ('部门名称','部门编号','用户名','性别','注册时间') VALUES('仓储部','D6','Dejan Perkovic','男','1-1月-08'); /* CREATE OR REPLACE VIEW view_dept_user ("部门名称","部门编号","用户名","性别","注册时间") AS SELECT d.deptName,d.deptID,u.userName,u.sex,u.loginDate FROM dept d ,sy_user u WHERE d.deptID=u.deptid; */ CREATE OR REPLACE TRIGGER dept_user_insert INSTEAD OF INSERT ON view_dept_user FOR EACH ROW DECLARE CURSOR cur_dept IS SELECT * FROM Department WHERE Department.deptID = :NEW.deptID; CURSOR cur_user IS SELECT * FROM sy_user WHERE sy_user.userName = :NEW.userName; d cur_dept%rowtype; u cur_user%rowtype; did dept.deptID%TYPE; uid sy_user.userID%TYPE; BEGIN OPEN cur_dept; OPEN cur_user; FETCH cur_user INTO u; FETCH cur_dept INTO d; /* 如果插入的数据中部门ID不存在,则将 seq_Dep.NEXTVAL 产生的序号赋值给变量did,执行插入语句新增加一个部门。 */ IF cur_dept%NOTFOUND THEN did := 'D'||seq_Dep.NEXTVAL; INSERT INTO Department(deptID,deptName) VALUES(did,:NEW.deptName); /* 如果插入数据中的员工不存在,则执行插入语句增加一个新员工 */ IF cur_user%NOTFOUND THEN uid := 'U'||seq_User.NEXTVAL; INSERT INTO UserInfo(userID,userName,sex,loginDate,deptid) VALUES(uid,:NEW.userName,:NEW.sex,:NEW.loginDate,did); END IF; IF cur_dept%FOUND THEN /* 如果插入的数据中部门ID是已经存在的部门ID,则更新部门名称 */ did:=:NEW.deptID; UPDATE Department SET Department.deptName WHERE Department.deptID = :NEW.deptID; /* 如果插入数据中的员工不存在,则将seq_User.NEXTVAL 产生的序号赋值给变量uid,执行插入语句增加一个新员工 */ IF cur_user%NOTFOUND THEN uid := 'U'||seq_User.NEXTVAL; INSERT INTO UserInfo VALUES(uid,:NEW.userName,:NEW.sex,:NEW.loginDate,:NEW.deptID); ELSE /* 如果插入数据中的员工已存在,则根据部门ID、员工姓名 来更新员工的其他字段的值,员工ID为主键,不用更新。 考虑到同名员工存在的可能,但员工的ID不可能相同的特点,需要根据插入数据中的部门ID、员工姓名来查询出 符合要求的员工的ID,用员工ID来进行后续的操作 */ SELECT userID INTO uid FROM UserInfo WHERE UserInfo.userName=:NEW.userName AND UserInfo.deptID=did; UPDATE UserInfo SET UserInfo.sex = :NEW.sex,UserInfo.loginDate = :NEW.loginDate,UserInfo.deptID = :NEW.sex WHERE UserInfo.userID=uid AND UserInfo.userName=:NEW.userName; END IF; END IF; CLOSE ecur; CLOSE dcur; END dept_user_insert; / show errors; 出现的错误提示: 警告: 创建的触发器带有编译错误。 SQL> show errors; TRIGGER DEPT_USER_INSERT 出现错误: LINE/COL ERROR -------- ----------------------------------------------------------------- 3/31 PLS-00049: 错误的赋值变量 'NEW.DEPTID' 5/30 PLS-00049: 错误的赋值变量 'NEW.USERNAME' 20/56 PLS-00049: 错误的赋值变量 'NEW.DEPTNAME' 26/75 PLS-00049: 错误的赋值变量 'NEW.USERNAME' 26/89 PLS-00049: 错误的赋值变量 'NEW.SEX' 26/98 PLS-00049: 错误的赋值变量 'NEW.LOGINDATE' 33/10 PLS-00049: 错误的赋值变量 'NEW.DEPTID' 34/4 PL/SQL: SQL Statement ignored 34/46 PL/SQL: ORA-00927: 缺少等号 34/72 PLS-00049: 错误的赋值变量 'NEW.DEPTID' 40/37 PLS-00049: 错误的赋值变量 'NEW.USERNAME' LINE/COL ERROR -------- ----------------------------------------------------------------- 40/51 PLS-00049: 错误的赋值变量 'NEW.SEX' 40/60 PLS-00049: 错误的赋值变量 'NEW.LOGINDATE' 40/75 PLS-00049: 错误的赋值变量 'NEW.DEPTID' 47/66 PLS-00049: 错误的赋值变量 'NEW.USERNAME' 49/40 PLS-00049: 错误的赋值变量 'NEW.SEX' 49/70 PLS-00049: 错误的赋值变量 'NEW.LOGINDATE' 49/103 PLS-00049: 错误的赋值变量 'NEW.SEX' 50/53 PLS-00049: 错误的赋值变量 'NEW.USERNAME' 55/5 PLS-00103: 出现符号 "DEPT_USER_INSERT"在需要下列之一时: if

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

HQL et SQL sont comparés dans le framework Hibernate : HQL (1. Syntaxe orientée objet, 2. Requêtes indépendantes de la base de données, 3. Sécurité des types), tandis que SQL exploite directement la base de données (1. Normes indépendantes de la base de données, 2. Exécutable complexe requêtes et manipulation de données).

"Utilisation de l'opération de division dans OracleSQL" Dans OracleSQL, l'opération de division est l'une des opérations mathématiques courantes. Lors de l'interrogation et du traitement des données, les opérations de division peuvent nous aider à calculer le rapport entre les champs ou à dériver la relation logique entre des valeurs spécifiques. Cet article présentera l'utilisation de l'opération de division dans OracleSQL et fournira des exemples de code spécifiques. 1. Deux méthodes d'opérations de division dans OracleSQL Dans OracleSQL, les opérations de division peuvent être effectuées de deux manières différentes.

Oracle et DB2 sont deux systèmes de gestion de bases de données relationnelles couramment utilisés, chacun possédant sa propre syntaxe et ses propres caractéristiques SQL. Cet article comparera et différera la syntaxe SQL d'Oracle et de DB2, et fournira des exemples de code spécifiques. Connexion à la base de données Dans Oracle, utilisez l'instruction suivante pour vous connecter à la base de données : CONNECTusername/password@database Dans DB2, l'instruction pour vous connecter à la base de données est la suivante : CONNECTTOdataba.

Qu'est-ce que l'identité en SQL ? Des exemples de code spécifiques sont nécessaires. En SQL, l'identité est un type de données spécial utilisé pour générer des nombres à incrémentation automatique. Il est souvent utilisé pour identifier de manière unique chaque ligne de données dans une table. La colonne Identité est souvent utilisée conjointement avec la colonne clé primaire pour garantir que chaque enregistrement possède un identifiant unique. Cet article détaillera comment utiliser Identity et quelques exemples de code pratiques. La manière de base d'utiliser Identity consiste à utiliser Identit lors de la création d'une table.

Utilisation de MINUS dans SQL et exemples de code spécifiques En SQL, MINUS est un opérateur utilisé pour effectuer une opération de différence entre deux jeux de résultats. Il est utilisé pour supprimer les mêmes lignes du premier ensemble de résultats que dans le deuxième ensemble de résultats. Le jeu de résultats renvoyé par l'opérateur MINUS contiendra des lignes qui existent uniquement dans le premier jeu de résultats. Voici un exemple de code spécifique pour démontrer l'utilisation de MINUS : Supposons qu'il existe deux tables : "table1" et "table2", leurs structures sont les suivantes : Nom de la table : champ table1

Interprétation des balises SQL dynamiques MyBatis : explication détaillée de l'utilisation des balises Set MyBatis est un excellent cadre de couche de persistance. Il fournit une multitude de balises SQL dynamiques et peut construire de manière flexible des instructions d'opération de base de données. Parmi elles, la balise Set est utilisée pour générer la clause SET dans l'instruction UPDATE, qui est très couramment utilisée dans les opérations de mise à jour. Cet article expliquera en détail l'utilisation de la balise Set dans MyBatis et démontrera ses fonctionnalités à travers des exemples de code spécifiques. Qu'est-ce que Set tag Set tag est utilisé dans MyBati

WindowsServerBackup est une fonction fournie avec le système d'exploitation WindowsServer, conçue pour aider les utilisateurs à protéger les données importantes et les configurations système, et à fournir des solutions complètes de sauvegarde et de récupération pour les petites, moyennes et grandes entreprises. Seuls les utilisateurs exécutant Server2022 et versions ultérieures peuvent utiliser cette fonctionnalité. Dans cet article, nous expliquerons comment installer, désinstaller ou réinitialiser WindowsServerBackup. Comment réinitialiser la sauvegarde de Windows Server Si vous rencontrez des problèmes avec la sauvegarde de votre serveur, si la sauvegarde prend trop de temps ou si vous ne parvenez pas à accéder aux fichiers stockés, vous pouvez envisager de réinitialiser vos paramètres de sauvegarde de Windows Server. Pour réinitialiser Windows

Solution : 1. Vérifiez si l'utilisateur connecté dispose des autorisations suffisantes pour accéder ou utiliser la base de données, et assurez-vous que l'utilisateur dispose des autorisations appropriées ; 2. Vérifiez si le compte du service SQL Server est autorisé à accéder au fichier spécifié ou ; dossier et assurez-vous que le compte dispose des autorisations suffisantes pour lire et écrire le fichier ou le dossier ; 3. Vérifiez si le fichier de base de données spécifié a été ouvert ou verrouillé par d'autres processus, essayez de fermer ou de libérer le fichier et réexécutez la requête ; . Essayez en tant qu'administrateur, exécutez Management Studio en tant que etc.
