Maison base de données tutoriel mysql Oracle primary key和unique key的区别与联系

Oracle primary key和unique key的区别与联系

Jun 07, 2016 pm 03:32 PM
key oracle unique 区别

primarykey与uniquekey都是唯一性约束,用来限制相同字段的插入 。但二者有很大的区别: 1.作为primarykey的1个或多个列必须为NOTNULL, 如果建表时此列设为NULL,在增加PRIMARYKEY时,列自动更改为NOTNULL。 而uniquekey约束的列可以为null,这是primarykey

primarykey与uniquekey都是唯一性约束,用来限制相同字段的值插入。但二者有很大的区别:

1.作为primarykey的1个或多个列必须为NOTNULL,
如果建表时此列设为NULL,在增加PRIMARYKEY时,列自动更改为NOTNULL。
而uniquekey约束的列可以为null,这是primarykey与uniquekey最大的区别。
2.一个表只能有一个primarykey(单列或多列,多列主键叫联合主键),但可以有多个uniquekey。
实例1:
createtablet(c1number(2),c2date,c3varchar2(5),c4int);
desct;
NameTypeNullableDefaultComments
————————————–
C1NUMBER(2)Y
C2DATEY
C3VARCHAR2(5)Y
C4INTEGERY
//
实例2:添加primarykey
altertabletaddconstraintt_pkprimarykey(c1,c2);
desct;
NameTypeNullableDefaultComments
————————————–
C1NUMBER(2)
C2DATE
C3VARCHAR2(5)Y
C4INTEGERY
我们看到,将c1,c2列设为联合主键后,他们变为notnull;
如果在建表时就指定了主键的话,主键列将会默认为notnull。
//
如果我们在添加一个primarykey,那么我们将会得到一个错误:
altertabletaddconstraintt_pk_2primarykey(c3,c4)
ORA-02260:tablecanhaveonlyoneprimarykey
//
实例3:添加uniquekey
altertabletaddconstraintunique_key_tunique(c3,c4);
实例4:添加数据
insertintot(c1,c2,c3,c4)
values(10,sysdate,’abc’,3);
1rowinserted
//
insertintot(c1,c2,c3,c4)
values(11,sysdate,’abc’,3);
ORA-00001:uniqueconstraint(SCOTT.UNIQUE_KEY_T)violated
我们看到,添加的第二条数据违反了刚刚创建的唯一键约束;
将unique_key_t删除,添加就能成功了。
实例5:删除uniquekey
altertabletdropconstraintunique_key_t;
insertintot(c1,c2,c3,c4)
values(11,sysdate,’abc’,3);
1rowinserted
//
实例6:删除primarykey
altertabletdropconstraintt_pk;
Tablealtered
//
desct;
NameTypeNullableDefaultComments
————————————–
C1NUMBER(2)Y
C2DATEY
C3VARCHAR2(5)Y
C4INTEGERY
删除主键约束后,c1,c2列由恢复了原来的默认值null。
//
3.其实primarykey也是uniquekey,被primarykey约束的列notnull,并且不允许重复
实例7:
truncatetablet;
Tabletruncated
//
altertabletaddconstraintt_pkprimarykey(c1,c2);
Tablealtered
//
insertintot(c1,c2,c3,c4)
values(1,to_date(’2011-01-01′,’yyyy-mm-dd’),’csdn’,10);
1rowinserted
//
insertintot(c3,c4)
values(‘china’,1);
ORA-01400:cannotinsertNULLinto(“SCOTT”.”T”.”C1″)
//
insertintot(c1,c2,c3,c4)
values(1,to_date(’2011-01-01′,’yyyy-mm-dd’),’csdn’,10);
ORA-00001:uniqueconstraint(SCOTT.T_PK)violated
这里,我们看到primarykeyt_pk变成了unique约束,证明了主键约束也是唯一约束。

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Quel échange est Nexo? Quel échange est Nexo? Mar 05, 2025 pm 07:39 PM

Nexo: Non seulement c'est un échange de crypto-monnaie, mais aussi votre directeur financier numérique. Il permet aux utilisateurs d'obtenir des prêts en crypto-monnaie en tant que garantie et fournit des services pour gagner des intérêts. Alors que Nexo propose également des capacités d'achat, de vente et de rédemption de crypto-monnaie, son principal activité est la cryptographie. Cet article explorera le modèle d'exploitation et la sécurité de Nexo en profondeur pour fournir aux investisseurs une compréhension plus complète. Le modèle d'exploitation de Nexo a été fondé en 2018 et a son siège à Zug, en Suisse, et est un pionnier dans le domaine de la finance numérique. Il est différent des autres échanges centralisés et se concentre davantage sur la fourniture de services financiers complets. Les utilisateurs peuvent acheter, vendre, échanger des crypto-monnaies sans vendre des actifs et

Y a-t-il une différence entre le bitcoin sud-coréen et le bitcoin domestique? Y a-t-il une différence entre le bitcoin sud-coréen et le bitcoin domestique? Mar 05, 2025 pm 06:51 PM

Le boom des investissements Bitcoin continue de se réchauffer. Bien que la Chine soit autrefois le plus grand marché du Bitcoin, les impacts politiques ont conduit à des restrictions de transaction. Aujourd'hui, la Corée du Sud est devenue l'un des principaux marchés du Bitcoin au monde, obligeant les investisseurs à remettre en question les différences entre elle et son bitcoin national. Cet article effectuera une analyse approfondie des différences entre les marchés du Bitcoin des deux pays. L'analyse des différences entre les marchés de la Corée du Sud et la Chine. Par exemple, fin octobre 2024, le prix du bitcoin en Corée du Sud était autrefois

La différence entre l'éther et le bitcoin quelle est la différence entre l'éther et le bitcoin La différence entre l'éther et le bitcoin quelle est la différence entre l'éther et le bitcoin Mar 19, 2025 pm 04:54 PM

La différence entre Ethereum et Bitcoin est significative. Techniquement, Bitcoin utilise POW et Ether est passé de Pow à Pos. La vitesse de trading est lente pour le bitcoin et Ethereum est rapide. Dans les scénarios d'application, Bitcoin se concentre sur le stockage des paiements, tandis que Ether prend en charge les contrats intelligents et les DAPP. En termes d'émission, le montant total du bitcoin est de 21 millions et il n'y a pas de montant total fixe de pièces d'éther. Chaque défi de sécurité est disponible. En termes de valeur marchande, le bitcoin se classe en premier et les fluctuations des prix des deux sont importantes, mais en raison de caractéristiques différentes, la tendance des prix d'Ethereum est unique.

La spéculation de Bitcoin est-elle une spéculation sur stock? Pourquoi? Quelles sont les différences entre les deux? La spéculation de Bitcoin est-elle une spéculation sur stock? Pourquoi? Quelles sont les différences entre les deux? Mar 05, 2025 pm 02:24 PM

Bitcoin: Digital Or ou Stock Trading Dérivés? Une analyse approfondie de la nature de son investissement. Cet article discutera en profondeur des aspects de la définition, de la nature, du mécanisme d'émission, etc., et dévoilera le mystère de l'investissement du bitcoin. Bitcoin and Stocks: La différence essentielle entre Bitcoin et les actions est: investir dans Bitcoin n'est pas la même chose que d'investir dans des actions. Bitcoin est une monnaie numérique décentralisée qui appartient à la catégorie des actifs numériques ou des actifs virtuels. Ce concept a été proposé par Satoshi Nakamoto en 2009. Contrairement aux devises traditionnelles,

La différence entre le multithreading et le C # asynchrone La différence entre le multithreading et le C # asynchrone Apr 03, 2025 pm 02:57 PM

La différence entre le multithreading et l'asynchrone est que le multithreading exécute plusieurs threads en même temps, tandis que les opérations effectuent de manière asynchrone sans bloquer le thread actuel. Le multithreading est utilisé pour les tâches à forte intensité de calcul, tandis que de manière asynchrone est utilisée pour l'interaction utilisateur. L'avantage du multi-threading est d'améliorer les performances informatiques, tandis que l'avantage des asynchrones est de ne pas bloquer les threads d'interface utilisateur. Le choix du multithreading ou asynchrone dépend de la nature de la tâche: les tâches à forte intensité de calcul utilisent le multithreading, les tâches qui interagissent avec les ressources externes et doivent maintenir la réactivité de l'interface utilisateur à utiliser asynchrone.

Quelle est la différence entre le pain aux haricots et la profondeur Quelle est la différence entre le pain aux haricots et la profondeur Mar 12, 2025 pm 01:24 PM

La différence de base entre le pain de haricot et Deepseek est la précision et la complexité de la récupération. 1. Doubao est basé sur la correspondance des mots clés, simple et directe, avec un faible coût, mais une faible précision, et ne convient que pour des données structurées; 2. Deepseek est basé sur l'apprentissage en profondeur, peut comprendre la sémantique, a une précision élevée, mais un coût élevé et convient aux données non structurées. Le choix final dépend du scénario d'application et des limitations de ressources.

La mentalité d'investissement en crypto est très importante! Comment éviter les inquiétudes inutiles et prendre les décisions correctes? La mentalité d'investissement en crypto est très importante! Comment éviter les inquiétudes inutiles et prendre les décisions correctes? Mar 05, 2025 pm 07:24 PM

Peur, incertitude et doute de l'investissement en crypto: comment prendre des décisions éclairées? De nombreux investisseurs de crypto sont confrontés à des craintes de «c'est le dernier cycle», ainsi que des préoccupations concernant la durée du marché haussier, associée à la pression des autres, ce qui conduit ensemble à de mauvaises décisions d'investissement. Cet article explorera comment surmonter ces défis et faire des choix d'investissement plus intelligents. Risque potentiel: distraction: chasser aveuglément les points chauds et ignorer la valeur des actifs centraux. Pessimisme et hésitation: L'incertitude conduit à un manque de confiance, à l'incapacité de tenir longtemps et même à la sortie du marché. Manque de croyance: manque de recherches approfondies sur les projets et ne peut pas faire face à la volatilité du marché. Manque de stratégies de bénéfice: nettoyer les positions tôt en raison de la peur des retraits, manquant des rendements potentiels. Stratégies d'adaptation: 1. Focus sur les zones centrales:

Comment faire des paramètres de sécurité Oracle sur Debian Comment faire des paramètres de sécurité Oracle sur Debian Apr 02, 2025 am 07:48 AM

Pour renforcer la sécurité de la base de données Oracle sur le système Debian, il faut de nombreux aspects pour commencer. Les étapes suivantes fournissent un cadre pour la configuration sécurisée: 1. Installation de la base de données Oracle et préparation du système de configuration initiale: Assurez-vous que le système Debian a été mis à jour vers la dernière version, la configuration du réseau est correcte et tous les packages logiciels requis sont installés. Il est recommandé de se référer à des documents officiels ou à des ressources tierces fiables pour l'installation. Utilisateurs et groupes: Créez un groupe d'utilisateurs Oracle dédié (tel que Oinstall, DBA, BackupDBA) et définissez-le pour lui. 2. Restrictions de sécurité Définir les restrictions de ressources: Edit /etc/security/limits.d/30-oracle.conf

See all articles