Maison base de données tutoriel mysql 约束与数据库对象规则、默认值的探究

约束与数据库对象规则、默认值的探究

Jun 07, 2016 pm 03:35 PM
trois 对象 探究 数据库 约束 规则 默认 默认值

约束、规则、默认这三者在数据表中规定了数据进行操作时的限制条件。他们三者有关系也有区别,用了两天的时间研究了他们三者,总结如下。 首先让我们从关系角度来分析: ●浅谈约束、规则、默认 1、约束,约束顾名思义是限制条件的意思,其实它的作用也是如

    约束、规则、默认值这三者在数据表中规定了数据进行操作时的限制条件。他们三者有关系也有区别,用了两天的时间研究了他们三者,总结如下。

首先让我们从关系角度来分析:

约束与数据库对象规则、默认值的探究

●浅谈约束、规则、默认值

    1、约束,约束顾名思义是限制条件的意思,其实它的作用也是如此,它是对所要进行增删改查操作的数据进行一次检查,检查这些数据是否符合我们所要约束的条件。举个例子:我们都经历过高考,考试规定考生不许带与考试无关的物品这就是一种约束。报名考试的考生可能因为某些意外没有进入考场考试,但大部分考生还是进行了考试。那么在考场内就产生了两种情况空位和非空位,这就是我们约束条件的两种情况。我们继续分析,在考生进入考场的情况中,考生在答卷之前是必须要在试卷和答题卡上填写自己的信息的,这些信息都是必须要填的因为它们唯一确定了一个考生,这里考生必须填写考生信息也就是我们所说的主键约束(主关键字约束)。接下来我们用两个表来说明下外键约束:

        约束与数据库对象规则、默认值的探究

    那么如果我们在字段后面用Not Null规定了呢?也就是说在我们的考生信息表中的性别字段,该列是不允许为空的于是就用Not Null标识,但是如果我们不填的话呢,我们的系统就会用Default默认值约束来帮助我们天上一个值。接下来我们来看Check约束,该约束是要用条件表达式来限定所要填的数据的,如下:

         Create table 工资 (

                  name  char(10) primary key,

                  department  char(20) Not Null,

                  salary int not null check(salary>1000 and salary
<p><br>
    创建了一个表该表中有三个字段,name、department、salary,并在salary字段设置了约束条件。该表如下图:</p>
<p></p>
<p><span>     <img  src="/static/imghw/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397842_8207.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150" class="lazy" alt="约束与数据库对象规则、默认值的探究" ></span></p>
<p><span>    <span>
在表中填数据时后两个不符合条件是不正确的。</span></span></p>
<p><span>    在约束中还分为两种:<span>字段级约束和表级约束</span>。字段级约束是只约束其中的一列,表级约束是约束多列,它们两个的区别并不大,我们在理解时可以将表级理解为字段级,即:被约束的多列可以看做捆绑成一列,被捆绑后的字段中的两个记录是不能重复的,如:</span></p>
<p><span><img  src="/static/imghw/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397860_9111.png&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150" class="lazy" alt="约束与数据库对象规则、默认值的探究" ></span></p>
<p><span><br clear="all">
</span></p>
<p><span>    2、规则,规则顾名思义是规矩制度的意思,在进行表操作时它的作用和check约束条件是类似的,但是一个表中只有一个规则,可有多个check约束,如:</span></p>
<p><span>    </span></p>
<pre class="brush:php;toolbar:false">     Create table 薪水(

            name  char(10) primary key,

            position  char(20) Not Null,

            salary int not null

         )

     Create rule ru_salary

     As @salary>1000 and @salary
<p><br>
<span>     表说明如下:</span></p>
<p><img  src="/static/imghw/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397842_8207.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150" class="lazy" alt="约束与数据库对象规则、默认值的探究" ></p>
<p><span>    3、默认值,用法同规则,它的作用类似于Default约束,是说在表中插入数据时,如果没有指定值,默认值自动指定数据值。</span></p>
<p><span>接下来我们在语法上分析三者,看图:</span></p>
<p><img  src="/static/imghw/default1.png" data-src="/inc/test.jsp?url=http%3A%2F%2Fmy.csdn.net%2Fuploads%2F201208%2F08%2F1344397923_5880.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fzhang_xinxiu%2Farticle%2Fdetails%2F7842150" class="lazy" alt="约束与数据库对象规则、默认值的探究" ></p>
<p></p>
<p><span>       1、约束,创建方法大致有三种:</span></p>
<p><span>               </span></p>
<pre class="brush:php;toolbar:false"> 	——方法一:在创建表时用字句的方式创建约束

	CREATE TABLE 表名(

            列名数据类型,

            ……

           <span> CONSTRAINT 约束名 PRIMARY KEY (列名),                       ——主键约束

            CONSTRAINT 约束名 UNIQUE (列名),                            ——唯一约束

            CONSTRAINT 约束名 FOREIGN KEY (列名) REFERENCES 表名 (列名),  ——外键约束

            CONSTRAINT 约束名 CHECK (检查条件)                           ——Check约束

</span>	);

        ——方法二:在创建表时直接定义约束

	CREATE TABLE 表名(

 <span>           列名数据类型 NOT NULL,                                        ——非空约束

            列名数据类型 NOT NULL PRIMARY KEY,                            ——主键约束

            列名数据类型 NOT NULL UNIQUE,                                 ——唯一约束

            列名数据类型 [NOT NULL] REFERENCES 表名(列名),                ——外键约束

            列名数据类型 [NOT NULL] CHECK (检查条件)                         ——Check约束</span>

	)

       ——方法三:在创建表后,通过更改表来定义

<span>	ALTER TABLE 表名 ALTER COLUMN 列名 SET NOT NULL;

	ALTER TABLE 表名 ADD PRIMARY KEY (列名1,列名2…);

	ALTER TABLE 表名 ADD UNIQUE (列名1,列名2,……);

	ALTER TABLE 表名 ADD FOREIGN KEY(列名) REFERENCES 表名2 (列名2);

	ALTER TABLE 表名 ADD CHECK (检查条件);
</span>
Copier après la connexion

      删除约束的语法为:ALTER TABLE 表名 DROP CONSTRAINT 约束名

    2、规则。规则的应用操作,首先要创建但只创建是不能应用的要用sp_bindrule将规则绑定到字段或自定义的数据类型上才能起作用。

             

   ——创建

 <span>   Create rule 规则名 as 条件表达式
</span>
    ——绑定

   <span> Exec sp_bindrule ‘规则名’  , ‘表名.字段名’ | ‘数据类型’

</span>    ——解除绑定

  <span>  sp_unbindrule  ‘表名.字段名’ | ‘数据类型’
</span>
    ——删除规则

    <span>DROP RULE {rule_name} [,...n]
</span>
Copier après la connexion

      3、默认值的语法和规则是类似的,只需将规则中的rule改成关键字default即可。         

     

      三者间的关系很清楚了吧。约束与数据库对象规则、默认值的探究

                上面两个导图看不清怎么办,不用着急来这儿下载吧: http://163.fm/8S2n28H     提取码:0lUKbp0z

                                                                                                             http://163.fm/GktKqwV    提取码:Dc6THqqH

 

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)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

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)

Comment Hibernate implémente-t-il le mappage polymorphe ? Comment Hibernate implémente-t-il le mappage polymorphe ? Apr 17, 2024 pm 12:09 PM

Le mappage polymorphe Hibernate peut mapper les classes héritées à la base de données et fournit les types de mappage suivants : join-subclass : crée une table séparée pour la sous-classe, incluant toutes les colonnes de la classe parent. table par classe : créez une table distincte pour les sous-classes, contenant uniquement des colonnes spécifiques aux sous-classes. union-subclass : similaire à join-subclass, mais la table de classe parent réunit toutes les colonnes de la sous-classe.

Comment convertir le tableau de résultats d'une requête MySQL en objet ? Comment convertir le tableau de résultats d'une requête MySQL en objet ? Apr 29, 2024 pm 01:09 PM

Voici comment convertir un tableau de résultats de requête MySQL en objet : Créez un tableau d'objets vide. Parcourez le tableau résultant et créez un nouvel objet pour chaque ligne. Utilisez une boucle foreach pour attribuer les paires clé-valeur de chaque ligne aux propriétés correspondantes du nouvel objet. Ajoute un nouvel objet au tableau d'objets. Fermez la connexion à la base de données.

iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées Jul 18, 2024 am 05:48 AM

Les dernières versions d'Apple des systèmes iOS18, iPadOS18 et macOS Sequoia ont ajouté une fonctionnalité importante à l'application Photos, conçue pour aider les utilisateurs à récupérer facilement des photos et des vidéos perdues ou endommagées pour diverses raisons. La nouvelle fonctionnalité introduit un album appelé "Récupéré" dans la section Outils de l'application Photos qui apparaîtra automatiquement lorsqu'un utilisateur a des photos ou des vidéos sur son appareil qui ne font pas partie de sa photothèque. L'émergence de l'album « Récupéré » offre une solution aux photos et vidéos perdues en raison d'une corruption de la base de données, d'une application d'appareil photo qui n'enregistre pas correctement dans la photothèque ou d'une application tierce gérant la photothèque. Les utilisateurs n'ont besoin que de quelques étapes simples

Règles et exceptions pour les comparaisons de pointeurs ? Règles et exceptions pour les comparaisons de pointeurs ? Jun 04, 2024 pm 06:01 PM

En C/C++, les règles de comparaison des pointeurs sont les suivantes : les pointeurs pointant vers le même objet sont égaux. Les pointeurs vers différents objets ne sont pas égaux. Exception : les pointeurs vers des adresses nulles sont égaux.

Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP Jun 04, 2024 pm 01:42 PM

Comment utiliser MySQLi pour établir une connexion à une base de données en PHP : Inclure l'extension MySQLi (require_once) Créer une fonction de connexion (functionconnect_to_db) Appeler la fonction de connexion ($conn=connect_to_db()) Exécuter une requête ($result=$conn->query()) Fermer connexion ( $conn->close())

Une analyse approfondie de la façon dont HTML lit la base de données Une analyse approfondie de la façon dont HTML lit la base de données Apr 09, 2024 pm 12:36 PM

HTML ne peut pas lire directement la base de données, mais cela peut être réalisé via JavaScript et AJAX. Les étapes comprennent l'établissement d'une connexion à la base de données, l'envoi d'une requête, le traitement de la réponse et la mise à jour de la page. Cet article fournit un exemple pratique d'utilisation de JavaScript, AJAX et PHP pour lire les données d'une base de données MySQL, montrant comment afficher dynamiquement les résultats d'une requête dans une page HTML. Cet exemple utilise XMLHttpRequest pour établir une connexion à la base de données, envoyer une requête et traiter la réponse, remplissant ainsi les données dans les éléments de la page et réalisant la fonction de lecture HTML de la base de données.

Comment gérer les erreurs de connexion à la base de données en PHP Comment gérer les erreurs de connexion à la base de données en PHP Jun 05, 2024 pm 02:16 PM

Pour gérer les erreurs de connexion à la base de données en PHP, vous pouvez utiliser les étapes suivantes : Utilisez mysqli_connect_errno() pour obtenir le code d'erreur. Utilisez mysqli_connect_error() pour obtenir le message d'erreur. En capturant et en enregistrant ces messages d'erreur, les problèmes de connexion à la base de données peuvent être facilement identifiés et résolus, garantissant ainsi le bon fonctionnement de votre application.

Quelle est la différence entre les tableaux et les objets en PHP ? Quelle est la différence entre les tableaux et les objets en PHP ? Apr 29, 2024 pm 02:39 PM

En PHP, un tableau est une séquence ordonnée et les éléments sont accessibles par index ; un objet est une entité avec des propriétés et des méthodes, créée via le mot-clé new. L'accès au tableau se fait via l'index, l'accès aux objets se fait via les propriétés/méthodes. Les valeurs du tableau sont transmises et les références d'objet sont transmises.

See all articles