MySQL 제약 조건 및 인덱스의 개념은 무엇입니까
1. 관계형 데이터베이스 설계 규칙
ER 모델과 세 가지 패러다임을 따르세요.
E 엔터티는 데이터베이스의 테이블에 해당하는 엔터티를 나타냅니다.
R 관계는 관계를 나타냅니다.
세 가지 패러다임:
1. 열을 분할할 수 없습니다
2. 고유 식별자
3. 관계 참조 기본 키
구체적인 구현
데이터를 테이블에 넣은 다음 테이블을 라이브러리에 넣습니다.
데이터베이스에는 여러 테이블이 있을 수 있으며 각 테이블에는 자신을 식별하는 이름이 있습니다. 테이블 이름은 고유합니다.
테이블에는 Java 및 Python의 "클래스" 디자인과 유사하게 데이터가 테이블에 저장되는 방식을 정의하는 몇 가지 특성이 있습니다.
테이블은 필드라고도 하는 열로 구성됩니다. 데이터 테이블의 디자인은 실제로 각 필드의 의미에 대한 디자인과 설명입니다. 데이터 테이블을 생성할 때 각 필드의 데이터 유형을 지정하고 데이터 길이와 이름을 정의해야 합니다. 각 필드는 Java 또는 Python의 "인스턴스 속성"과 유사합니다.
테이블의 데이터는 행으로 저장되며, 한 행은 레코드입니다. 각 행은 Java 또는 Python의 "객체"와 유사합니다.
2. 데이터 무결성, 제약 조건 및 인덱스의 개념
1. 데이터 무결성(Data Integrity)은 데이터의 정확성(Accuracy)과 신뢰성(Reliability)을 방지하기 위해 고안되었습니다. 의미론적 규정을 준수하지 않는 데이터가 있는 동시에 오류 정보의 입력 및 출력으로 인해 발생하는 잘못된 연산이나 오류 메시지를 방지합니다.
데이터의 무결성은 다음과 같이 고려해야 합니다. 네 가지 측면:
엔티티 무결성. 예를 들어 동일하고 구별할 수 없는 두 개의 레코드가 동일한 테이블에 존재할 수 없습니다.
도메인 무결성: 예: 연령 범위 0-120, 성별 범위 "남성/여성"
인용 무결성(참조 무결성): 예: 직원이 위치한 부서, 이 부서는 부서 테이블에서 찾아야 합니다.
사용자 정의 무결성(사용자 정의 무결성): 예: 사용자 이름 이 부서 관리자의 급여는 이 부서 직원 평균 급여의 5배를 초과할 수 없습니다.
2. 제약 조건(CONSTRAINTS)
데이터 비즈니스 규칙 및 데이터 무결성을 구현하고 유지하는 데 사용됩니다. 제약 조건은 데이터베이스 개체로 처리될 수 있으며 논리적 제약 조건이므로 제약 조건 설정으로 인해 추가 공간을 차지하지 않습니다.
3. 인덱스(INDEX)
인덱스는 데이터 페이지에 개별적으로 물리적으로 저장되는 A 데이터베이스 구조이며, 테이블에 있는 하나 이상의 열 값과 해당 논리 목록입니다. 테이블에 있는 데이터 값의 물리적 식별 데이터 페이지를 가리키는 포인터(신화사전의 디렉토리 색인 페이지와 유사) 색인이 있으면 데이터베이스의 저장 공간이 늘어나고 삽입하는 데 드는 시간 비용이 늘어납니다. (데이터를 삽입하고 수정하면 인덱스도 변경되기 때문에) 쿼리 속도를 크게 향상시킬 수 있으므로 자주 쿼리하고 정렬하는 컬럼에 인덱스를 생성하여 사용해야 합니다. 쿼리에서 거의 사용되지 않고 참조되는 컬럼, 자주 수정되는 컬럼, 값이 거의 없는 컬럼(예를 들어 성별은 남성만 있고 여성 등의 컬럼에는 Index를 생성하면 안 됨)을 범위별로 검색한다.
①Mysql은 기본 키, 고유 키 및 외래 키 열에 대해 자동으로 인덱스를 생성합니다.
②기본 키는 삭제되고 해당 열은 수동으로 생성되어야 합니다. 인덱스도 삭제됩니다
③고유키를 삭제하는 방법은 해당 인덱스를 삭제하는 것입니다
4외래키 삭제 외래키 열에 있는 인덱스가 아직 남아있으니 삭제하셔야 합니다. 인덱스 별도로
3. 제약 조건 적용
1. 테이블의 제약 조건 및 인덱스 보기
#查看某个表的约束 SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称'; 或 SHOW CREATE TABLE 表名; #查看某个表的索引 SHOW INDEX FROM 表名称;
2. 기본 키 제약 조건: 기본 키
(1) 기본 키는 단일 열 기본 키와 복합 기본 키로 구분됩니다. 키(복합 기본 키는 세 가지 패러다임을 위반하므로 권장되지 않습니다.):
#单个字段设置主键 create table t_user( id int primary key, username varchar(20), password varchar(20) ); create table t_user( id int, username varchar(20), password varchar(20), primary key(id) ); #多个字段设置联合主键 drop table t_user; create table t_user( id int, username varchar(20), password varchar(20), primary key(id,username) ); #了解 #在建表后指定主键约束 alter table 表名称 add primary key (主键字段列表); #删除主键约束 alter table 表名称 drop primary key;
기본 키의 특성:
1 테이블에는 기본 키가 하나만 있을 수 있습니다
2. 기본 키로 설정된 필드의 값은 고유하고 비어 있지 않습니다
3. 기본 키가 여러 개 있는 경우 필드로 구성되어 있으므로 해당 필드 뒤에는 기본 키를 설정할 수 없습니다. 4. 공동 기본 키에서 기본 키를 구성하는 각 필드는 비어 있지 않으며 별도로 사용할 수 있습니다. 반복하지만 동시에 사용할 수는 없습니다
5. 기본 키를 생성하면 해당 인덱스가 자동으로 생성되며, 기본 키를 삭제하면 해당 인덱스도 함께 삭제됩니다.
3. Auto_increment 제약 조건: auto_increment
create table t_user( id int primary key auto_increment, username varchar(20), password varchar(20) ); #建表后指定自增长列 alter table [数据库.]表名 modify 自增字段名 数据类型 auto_increment; #删除自增约束 alter table 表名 modify 自增字段名 数据类型;
로그인 후 복사자동 증분 제약 조건의 특징:
테이블에는 자동 증분 유형의 기본 키 필드가 하나만 있어야 하며, 이 필드는 정수여야 하며 비어 있을 수 없습니다. 일반적으로 키 제약 조건은 기본 키 제약 조건, 고유 키 제약 조건, 외래 키 제약 조건과 같이 기본 키에만 설정됩니다
2、设置为自增的字段,从1开始自增;每次添加数据,都会在该字段最大值的基础上+1
3、使字段自增的方式:
如果是空或者0,则实际插入的将是自动增长后的值。
a> insert into t_user(username,password) values(‘admin’,‘123456’);
b> insert into t_user values(null,‘root’,‘123456’); (推荐使用)
c> insert into t_user values(0,‘root’,‘123456’);
4、唯一键约束:unique key
create table t_user( id int primary key auto_increment, username varchar(20) unique key, password varchar(20) unique key ); create table t_user( id int primary key auto_increment, username varchar(20), password varchar(20), unique key(username,password) ); #在建表后增加唯一键约束 alter table 表名称 add 【constraint 约束名】 unique key (字段名列表); #如果没有指定约束名,(字段名列表)中只有一个字段的,默认是该字段名,如果是多个字段的默认是字段名列表的第1个字段名。也可以通过show index from 表名;来查看 #删除唯一键约束 ALTER TABLE 表名称 DROP INDEX 唯一性约束名; #注意:如果忘记名称,可以通过“show index from 表名称;”查看
唯一键约束的特点:
1、设置唯一键约束的字段值唯一,但是可以为null
2、一张表可以设置多个唯一键约束,也可以设置联合唯一键,即多个字段设置一个唯一约束,但是不能使用"unique key"写在字段后设置,必须写在所有字段后,使用"unique key(字段,字段)"
3、联合唯一键要求组成唯一约束的字段可以单独重复,不能同时重复
4、 MySQL会给唯一约束的列上默认创建一个唯一索引。
5、删除唯一键只能通过删除对应索引的方式删除,删除时需要指定唯一键索引名
5、非空约束:not null
create table t_user( id int primary key auto_increment, username varchar(20) unique key not null, password varchar(20) ); #在建表后指定某个字段非空 ALTER TABLE 表名称 MODIFY 字段名 数据类型 NOT NULL 【default 默认值】; #如果该字段原来设置了默认值约束,要跟着一起再写一遍,否则默认值约束会丢失 #取消某个字段非空 ALTER TABLE 表名称 MODIFY 字段名 数据类型 【default 默认值】; #如果该字段原来设置了默认值约束,要跟着一起再写一遍,否则默认值约束会丢失
非空约束的特点:
设置为非空约束的字段的值不能为null
6、默认值约束:default
create table t_user( id int primary key auto_increment, username varchar(20) unique key not null, password varchar(20), gender char not null default '男' );
添加数据时使用默认值的方式:
不为该字段赋值或使用关键字default
insert into t_user(username,password) values(‘root’,‘123’);
insert into t_user values(null,‘admin123’,‘123’,default);
insert into t_user values(null,‘admin’,‘123’,null); //此方式不可以,会为该字段赋值为null
7、外键约束:foreign key
表关系:
1、一对一
2、多对一,在多的一方引用一的主键
student(sid,sname,age,sex,cid)–clazz(cid,cname,location)
3、一对多,在多的一方引用一的主键
clazz(cid,cname,location)–student(sid,sname,age,sex,cid)
4、多对多
user(uid,username,password)
order(oid,create_time,total_count,total_amount,status,user_id)
order_goods(id,oid,gid)
goods(gid,gname,price,sales,stock)
create table t_dept( id int primary key auto_increment, name varchar(20) ); create table t_emp( id int primary key auto_increment, name varchar(20), age int, gender char, dept_id int, foreign key(dept_id) references t_dept(id) #外键只能在所有字段列表后面单独指定 ); #在建表后指定外键约束 alter table 从表名称 add 【constraint 外键约束名】 foreign key (从表字段名) references 主表名(主表被参照字段名) 【on update xx】[on delete xx]; #删除外键约束 ALTER TABLE 表名称 DROP FOREIGN KEY 外键约束名; #查看某个表的约束名 SELECT * FROM information_schema.table_constraints WHERE table_name = '表名称'; 或 SHOW CREATE TABLE 表名; #删除外键约束不会删除对应的索引,如果需要删除索引,需要用ALTER TABLE 表名称 DROP INDEX 索引名; #查看索引名 show index from 表名称;
(1)外键特点
外键约束是保证一个或两个表之间的参照完整性,外键是构建于一个表的两个字段或是两个表的两个字段之间的参照关系。
在创建外键约束时,如果不给外键约束名称,默认名不是列名,而是自动产生一个外键名(例如 student_ibfk_1;),也可以指定外键约束名。
当创建外键约束时,系统默认会在所在的列上建立对应的普通索引。但是索引名是列名,不是外键的约束名。
删除外键时,关于外键列上的普通索引需要单独删除。
(2)要求
在从表上建立外键,而且主表要先存在。
一个表可以建立多个外键约束
从表的外键列,在主表中引用的只能是键列(主键,唯一键,外键),推荐引用主表的主键。
从表的外键列与主表被参照的列名字可以不相同,但是数据类型必须一样
(3)约束关系:约束是针对双方的
添加了外键约束后,主表的修改和删除数据受约束
添加了外键约束后,从表的添加和修改数据受约束
在从表上建立外键,要求主表必须存在
删除主表时,要求从表先删除,或将从表中外键引用该主表的关系先删除
(4)5个约束等级
Cascade方式:在父表上update/delete记录时,同步update/delete掉子表的匹配记录
Set null方式:在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子表的外键列不能为not null
No action方式:如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作
Restrict方式:同no action, 都是立即检查外键约束
Set default方式(在可视化工具SQLyog中可能显示空白):父表有变更时,子表将外键列设置成一个默认的值,但Innodb不能识别
如果没有指定等级,就相当于Restrict方式
8、检查约束:check
检查约束,mysql暂不支持
create table stu( sid int primary key, sname varchar(20), gender char check ('男'or'女') ); insert into stu values(1,'张三','男'); insert into stu values(2,'李四','妖'); 使用枚举类型解决如上问题: create table stu( sid int primary key, sname varchar(20), gender enum ('男','女') );
위 내용은 MySQL 제약 조건 및 인덱스의 개념은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

웹 응용 프로그램에서 MySQL의 주요 역할은 데이터를 저장하고 관리하는 것입니다. 1. MySQL은 사용자 정보, 제품 카탈로그, 트랜잭션 레코드 및 기타 데이터를 효율적으로 처리합니다. 2. SQL 쿼리를 통해 개발자는 데이터베이스에서 정보를 추출하여 동적 컨텐츠를 생성 할 수 있습니다. 3.mysql은 클라이언트-서버 모델을 기반으로 작동하여 허용 가능한 쿼리 속도를 보장합니다.

Laravel은 웹 응용 프로그램을 쉽게 구축하기위한 PHP 프레임 워크입니다. 설치 : Composer를 사용하여 전 세계적으로 Laravel CLI를 설치하고 프로젝트 디렉토리에서 응용 프로그램을 작성하는 등 다양한 기능을 제공합니다. 라우팅 : Routes/Web.php에서 URL과 핸들러 간의 관계를 정의하십시오. 보기 : 리소스/뷰에서보기를 작성하여 응용 프로그램의 인터페이스를 렌더링합니다. 데이터베이스 통합 : MySQL과 같은 데이터베이스와 상자 외 통합을 제공하고 마이그레이션을 사용하여 테이블을 작성하고 수정합니다. 모델 및 컨트롤러 : 모델은 데이터베이스 엔티티를 나타내고 컨트롤러는 HTTP 요청을 처리합니다.

Docker에서 MySQL을 시작하는 프로세스는 다음 단계로 구성됩니다. MySQL 이미지를 가져와 컨테이너를 작성하고 시작하고 루트 사용자 암호를 설정하고 포트 확인 연결을 매핑하고 데이터베이스를 작성하고 사용자는 데이터베이스에 모든 권한을 부여합니다.

작은 응용 프로그램을 개발할 때 까다로운 문제가 발생했습니다. 가벼운 데이터베이스 운영 라이브러리를 신속하게 통합해야합니다. 여러 라이브러리를 시도한 후에는 기능이 너무 많거나 호환되지 않는다는 것을 알았습니다. 결국, 나는 내 문제를 완벽하게 해결하는 YII2를 기반으로 단순화 된 버전 인 Minii/DB를 발견했습니다.

MySQL 및 Phpmyadmin은 강력한 데이터베이스 관리 도구입니다. 1) MySQL은 데이터베이스 및 테이블을 작성하고 DML 및 SQL 쿼리를 실행하는 데 사용됩니다. 2) PHPMYADMIN은 데이터베이스 관리, 테이블 구조 관리, 데이터 운영 및 사용자 권한 관리에 직관적 인 인터페이스를 제공합니다.

다른 프로그래밍 언어와 비교할 때 MySQL은 주로 데이터를 저장하고 관리하는 데 사용되는 반면 Python, Java 및 C와 같은 다른 언어는 논리적 처리 및 응용 프로그램 개발에 사용됩니다. MySQL은 데이터 관리 요구에 적합한 고성능, 확장 성 및 크로스 플랫폼 지원으로 유명하며 다른 언어는 데이터 분석, 엔터프라이즈 애플리케이션 및 시스템 프로그래밍과 같은 해당 분야에서 이점이 있습니다.

기사 요약 :이 기사는 Laravel 프레임 워크를 쉽게 설치하는 방법에 대한 독자들을 안내하기위한 자세한 단계별 지침을 제공합니다. Laravel은 웹 애플리케이션의 개발 프로세스를 가속화하는 강력한 PHP 프레임 워크입니다. 이 자습서는 시스템 요구 사항에서 데이터베이스 구성 및 라우팅 설정에 이르기까지 설치 프로세스를 다룹니다. 이러한 단계를 수행함으로써 독자들은 라벨 프로젝트를위한 탄탄한 토대를 빠르고 효율적으로 놓을 수 있습니다.

MySQL은 웹 응용 프로그램 및 컨텐츠 관리 시스템에 적합하며 오픈 소스, 고성능 및 사용 편의성에 인기가 있습니다. 1) PostgreSQL과 비교하여 MySQL은 간단한 쿼리 및 높은 동시 읽기 작업에서 더 잘 수행합니다. 2) Oracle과 비교할 때 MySQL은 오픈 소스와 저렴한 비용으로 인해 중소 기업에서 더 인기가 있습니다. 3) Microsoft SQL Server와 비교하여 MySQL은 크로스 플랫폼 응용 프로그램에 더 적합합니다. 4) MongoDB와 달리 MySQL은 구조화 된 데이터 및 트랜잭션 처리에 더 적합합니다.
