목차
1. MySQL 소개
1. 데이터베이스 관리 소프트웨어의 분류
2, MySQL
2. 스토리지 엔진(테이블 유형이라고도 함)
1. 일반적인 스토리지 엔진 및 적용 가능한 시나리오
2. mysql
1. 테이블 생성 시 스토리지 엔진을 지정합니다
2. MySQL 테이블 작업
1. 테이블 구조
테이블 구조를 보는 방법에는 두 가지가 있습니다:
제한된 필드는 자동으로 증가하며 동시에 제한되는 필드는 키 기본 키로 제한되어야 합니다
1. ENUM 및 SET
2、set/enum示例
五、MySQL表查询
1、限制查询的记录数(limit)
2、使用正则表达式查询
六、数据备份(命令行)
1、 数据库的逻辑备份
2、 数据恢复
七、事务和锁(SQL)
八、执行计划Explain
데이터 베이스 MySQL 튜토리얼 MySQL 데이터베이스의 기본 동작 사례 분석

MySQL 데이터베이스의 기본 동작 사례 분석

May 26, 2023 pm 11:27 PM
mysql

1. MySQL 소개

1. 데이터베이스 관리 소프트웨어의 분류

크게 관계형과 비관계형으로 나뉜다.

관계형 데이터베이스는 테이블 구조가 있어야 하고, 비관계형 데이터베이스는 키-값 데이터를 저장하고 테이블 구조가 없다고 간단히 이해하면 됩니다.

관계 유형: sqllite, db2, oracle, access, sql server, MySQL 등 참고: sql 문은 보편적입니다.

비관계형: mongodb, redis, memcache

2, MySQL

MySQL은 스웨덴 MySQL AB 회사에서 개발한 관계형 데이터베이스 관리 시스템으로 현재 Oracle의 제품입니다.

MySQL은 가장 널리 사용되는 관계형 데이터베이스 관리 시스템 중 하나입니다. 웹 애플리케이션 측면에서 MySQL은 최고의 RDBMS(관계형 데이터베이스 관리 시스템) 애플리케이션 소프트웨어입니다.

SQL 언어는 가장 일반적으로 사용되는 표준화된 언어이며 MySQL 데이터베이스에 액세스하는 데 사용됩니다. MySQL 소프트웨어는 이중 라이센스 정책을 채택하고 있으며 작은 크기, 빠른 속도, 낮은 총 소유 비용, 특히 오픈 소스의 특성으로 인해 커뮤니티 버전과 상용 버전으로 구분됩니다. 중소규모 웹사이트 개발.

MySQL은 Mac, Linux, Windows를 포함한 다양한 운영 체제용 오픈 소스 설치 패키지를 제공합니다.

2. 스토리지 엔진(테이블 유형이라고도 함)

MySQL의 데이터는 다양한 기술을 사용하여 파일(또는 메모리)에 저장됩니다. 다양한 기술은 고유한 저장 메커니즘, 인덱싱 기술 및 잠금 수준을 사용하여 다양한 기능과 기능을 제공합니다. MySQL은 이러한 다양한 기술과 관련 기능을 스토리지 엔진이라고 하며, 이를 테이블 유형이라고도 합니다.

MySQL은 기본적으로 다양한 스토리지 엔진으로 구성되며, 이는 MySQL 서버에서 미리 설정하거나 활성화할 수 있습니다.

1. 일반적인 스토리지 엔진 및 적용 가능한 시나리오

  • InnoDB: 외래 키 및 행 수준 잠금을 지원하는 트랜잭션 처리 애플리케이션에 사용됩니다. 애플리케이션이 사물의 무결성에 대한 요구 사항이 상대적으로 높고 동시 조건에서 데이터 일관성이 필요하며 데이터 작업에 삽입 및 쿼리 외에도 많은 업데이트 및 삭제 작업이 포함되는 경우 InnoDB 스토리지 엔진이 더 적합합니다.
    InnoDB는 삭제 및 업데이트로 인한 잠금을 효과적으로 줄이는 것 외에도 트랜잭션의 완전한 제출 및 롤백을 보장할 수 있습니다. 이는 데이터 정확성에 대한 요구 사항이 높은 청구 시스템 또는 금융 시스템과 같은 시스템에 적합한 선택입니다.

  • MyISAM: 애플리케이션이 주로 읽기 작업 및 삽입 작업을 기반으로 하고 몇 가지 업데이트 및 삭제 작업만 사용하며 트랜잭션 무결성 및 동시성에 대한 높은 요구 사항이 없는 경우 이 스토리지 엔진을 선택할 수 있습니다.

  • 메모리: 모든 데이터를 메모리에 저장하여 기록 및 기타 유사한 데이터를 빠르게 찾아야 하는 환경에서 매우 빠른 액세스를 제공합니다.
    메모리의 단점은 테이블 크기에 제한이 있다는 점입니다. 데이터베이스가 비정상적으로 종료되면 정상적으로 데이터를 복구할 수 있지만, 데이터베이스가 닫히면 메모리에 저장된 데이터가 손실됩니다.

mysql이 지원하는 스토리지 엔진에는 InnoDB, MyISAM, MEMORY, CSV, BLACKHOLE, NDB, FEDERATED, MRG_MYISAM, ARCHIVE, PERFORMANCE_SCHEMA가 포함됩니다.
그 중 NDB와 InnoDB는 트랜잭션에 안전한 테이블을 제공하고, 다른 스토리지 엔진은 트랜잭션에 안전한 테이블을 제공하지 않습니다.

2. mysql

# 查看当前的默认存储引擎:
mysql> show variables like "default_storage_engine";

# 查询当前数据库支持的存储引擎
mysql> show engines \G;
로그인 후 복사
1. 테이블 생성 시 스토리지 엔진을 지정합니다
mysql> create table ai(id bigint(12),name varchar(200)) ENGINE=MyISAM; 
mysql> create table country(id int(4),cname varchar(50)) ENGINE=InnoDB;

# 也可以使用alter table语句,修改一个已经存在的表的存储引擎。
mysql> alter table ai engine = innodb;
로그인 후 복사
2. MySQL 테이블 작업

1. 테이블 구조

테이블 구조를 보는 방법에는 두 가지가 있습니다:

    desc[테이블 이름] 및 설명[테이블 이름]: 이 두 가지 방법은 동일한 효과를 가지며 현재 테이블 구조를 볼 수 있습니다.
  • show create table [tablename]: 테이블 정의 외에도 엔진(스토리지 엔진), charset(문자 집합) 등의 정보도 볼 수 있습니다. G 옵션을 사용하면 레코드를 세로로 정렬하여 긴 레코드를 더 쉽게 표시할 수 있습니다. )
  • 예:
# my.ini文件
[mysqld]
default-storage-engine=INNODB
로그인 후 복사

2. 자동 증가 열

제한된 필드는 자동으로 증가하며 동시에 제한되는 필드는 키 기본 키로 제한되어야 합니다

mysql> desc staff_info;
+-------+-----------------------+------+-----+---------+-------+
| Field | Type                  | Null | Key | Default | Extra |
+-------+-----------------------+------+-----+---------+-------+
| id    | int(11)               | YES  |     | NULL    |       |
| name  | varchar(50)           | YES  |     | NULL    |       |
| age   | int(3)                | YES  |     | NULL    |       |
| sex   | enum('male','female') | YES  |     | NULL    |       |
| phone | bigint(11)            | YES  |     | NULL    |       |
| job   | varchar(11)           | YES  |     | NULL    |       |
+-------+-----------------------+------+-----+---------+-------+
rows in set (0.00 sec)

mysql> show create table staff_info\G;
*************************** 1. row ***************************
       Table: staff_info
Create Table: CREATE TABLE `staff_info` (
  `id` int(11) DEFAULT NULL,
  `name` varchar(50) DEFAULT NULL,
  `age` int(3) DEFAULT NULL,
  `sex` enum('male','female') DEFAULT NULL,
  `phone` bigint(11) DEFAULT NULL,
  `job` varchar(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
row in set (0.01 sec)

ERROR: 
No query specified
로그인 후 복사

4.

1. ENUM 및 SET

    ENUM 타입의 중국어 이름을 열거형(enumeration type)이라고 하며, 테이블 생성 시 해당 값의 범위를 열거형으로 표시해야 합니다.
  • ENUM을 사용하면 한 번에 여러 값이 아닌 값 컬렉션에서 단일 값만 선택할 수 있습니다. 목적: 단일 선택: 성별 선택


  • ENUM:
1~255명의 구성원을 열거하려면 1바이트의 저장 공간이 필요합니다.

255~65535명의 구성원의 경우 2바이트의 저장 공간이 필요합니다.
최대 허용 인원은 65535명입니다.

    SET은 ENUM과 매우 유사하며 문자열 객체이며 0-64개의 ​​멤버를 포함할 수 있습니다. 회원에 따라 저장공간이 다릅니다.
  • 세트 유형을 사용하면 조합할 값 세트에서 1개 이상의 요소를 임의로 선택할 수 있습니다. 범위를 벗어난 내용에 대해서는 주입이 허용되지 않으며, 중복된 값은 자동으로 중복제거됩니다. 사용법: 객관식: 취미 및 성별

SET:
1-8个成员的集合,占1个字节
9-16个成员的集合,占2个字节
17-24个成员的集合,占3个字节
25-32个成员的集合,占4个字节
33-64个成员的集合,占8个字节

2、set/enum示例

mysql> create table t10 (name char(20),gender enum('female','male') );
Query OK, 0 rows affected (0.01 sec)

-- 选择enum('female','male')中的一项作为gender的值,可以正常插入
mysql> insert into t10 values ('nick','male');
Query OK, 1 row affected (0.00 sec)

-- 不能同时插入'male,female'两个值,也不能插入不属于'male,female'的值
mysql> insert into t10 values ('nick','male,female');
ERROR 1265 (01000): Data truncated for column 'gender' at row 1

mysql> create table t11 (name char(20),hobby set('抽烟','喝酒','烫头','翻车') );
Query OK, 0 rows affected (0.01 sec)

-- 可以任意选择set('抽烟','喝酒','烫头','翻车')中的项,并自带去重功能
mysql> insert into t11 values ('tank','烫头,喝酒,烫头');
Query OK, 1 row affected (0.01 sec)

mysql> select * from t11;
+------+---------------+
| name | hobby        |
+------+---------------+
| tank | 喝酒,烫头     |
+------+---------------+
row in set (0.00 sec)

-- 不能选择不属于set('抽烟','喝酒','烫头','翻车')中的项,
mysql> insert into t11 values ('jason','烫头,翻车,看妹子');
ERROR 1265 (01000): Data truncated for column 'hobby' at row 1
로그인 후 복사

五、MySQL表查询

1、限制查询的记录数(limit)

示例:

SELECT * FROM employee ORDER BY salary DESC 
    LIMIT 3;    --默认初始位置为0 

SELECT * FROM employee ORDER BY salary DESC
    LIMIT 0 , 5 ; --从第0开始,即先出第一条,然后包含这一条在内往后查5条

SELECT * FROM employee ORDER BY salary DESC
    LIMIT 5 , 5 ; --从第5开始,即先出第6条,然后包含这一条在内往后查5条
로그인 후 복사

2、使用正则表达式查询

小结:对字符串匹配的方式

  • WHERE emp_name = 'nick';

  • WHERE emp_name LIKE 'sea%';

  • WHERE emp_name REGEXP 'on$';

SELECT * FROM employee WHERE emp_name REGEXP '^jas';
SELECT * FROM employee WHERE emp_name REGEXP 'on$';
SELECT * FROM employee WHERE emp_name REGEXP 'm{2}';
로그인 후 복사

六、数据备份(命令行)

1、 数据库的逻辑备份

--语法:
mysqldump -h 服务器 -u用户名 -p密码 数据库名 > 备份文件.sql

--示例:
--单库备份
mysqldump -uroot –p123  mysql > c:\db1.sql
mysqldump -uroot -p123 db1 table1 table2 > db1-table1-table2.sql

--多库备份
mysqldump -uroot -p123 --databases db1 db2 mysql db3 > db1_db2_mysql_db3.sql

--备份所有库
mysqldump -uroot -p123 --all-databases > all.sql
로그인 후 복사

2、 数据恢复

--方法一:
[root@nick backup]-- mysql -uroot -p123 < /backup/all.sql

--方法二:
mysql> use db1;
mysql> SET SQL_LOG_BIN=0;   --关闭二进制日志,只对当前session生效
mysql> source /root/db1.sql
로그인 후 복사

七、事务和锁(SQL)

begin;  -- 开启事务
   select * from emp where id = 1 for update;  -- 查询id值,for update添加行锁;
    update emp set salary=10000 where id = 1; -- 完成更新
commit; -- 提交事务
로그인 후 복사

八、执行计划Explain

执行计划:让mysql预估执行操作(一般正确)

Explain语法:

explain select &hellip; from &hellip; [where &hellip;]

Explain命令在解决数据库性能上是第一推荐使用命令,大部分的性能问题可以通过此命令来简单的解决,Explain可以用来查看SQL语句的执行效果,可以帮助选择更好的索引和优化查询语句,写出更好的优化语句。

具体用法和字段含义可以参考官网explain-output ,这里需要强调rows是核心指标,绝大部分rows小的语句执行一定很快(rows:显示MySQL认为它执行查询时必须检查的行数。)。所以优化语句基本上都是在优化rows。

例如:

explain select * from news;
로그인 후 복사

输出:

+--+-----------+-----+----+-------------+---+-------+---+----+-----+ 
|id|select_type|table|type|possible_keys|key|key_len|ref|rows|Extra| 
+--+-----------+-----+----+-------------+---+-------+---+----+----—+
로그인 후 복사

위 내용은 MySQL 데이터베이스의 기본 동작 사례 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

phpmyadmin을 여는 방법 phpmyadmin을 여는 방법 Apr 10, 2025 pm 10:51 PM

다음 단계를 통해 phpmyadmin을 열 수 있습니다. 1. 웹 사이트 제어판에 로그인; 2. phpmyadmin 아이콘을 찾고 클릭하십시오. 3. MySQL 자격 증명을 입력하십시오. 4. "로그인"을 클릭하십시오.

MySQL : 세계에서 가장 인기있는 데이터베이스 소개 MySQL : 세계에서 가장 인기있는 데이터베이스 소개 Apr 12, 2025 am 12:18 AM

MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

단일 스레드 레 디스를 사용하는 방법 단일 스레드 레 디스를 사용하는 방법 Apr 10, 2025 pm 07:12 PM

Redis는 단일 스레드 아키텍처를 사용하여 고성능, 단순성 및 일관성을 제공합니다. 동시성을 향상시키기 위해 I/O 멀티플렉싱, 이벤트 루프, 비 블로킹 I/O 및 공유 메모리를 사용하지만 동시성 제한 제한, 단일 고장 지점 및 쓰기 집약적 인 워크로드에 부적합한 제한이 있습니다.

MySQL의 장소 : 데이터베이스 및 프로그래밍 MySQL의 장소 : 데이터베이스 및 프로그래밍 Apr 13, 2025 am 12:18 AM

데이터베이스 및 프로그래밍에서 MySQL의 위치는 매우 중요합니다. 다양한 응용 프로그램 시나리오에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) MySQL은 웹, 모바일 및 엔터프라이즈 레벨 시스템을 지원하는 효율적인 데이터 저장, 조직 및 검색 기능을 제공합니다. 2) 클라이언트 서버 아키텍처를 사용하고 여러 스토리지 엔진 및 인덱스 최적화를 지원합니다. 3) 기본 사용에는 테이블 작성 및 데이터 삽입이 포함되며 고급 사용에는 다중 테이블 조인 및 복잡한 쿼리가 포함됩니다. 4) SQL 구문 오류 및 성능 문제와 같은 자주 묻는 질문은 설명 명령 및 느린 쿼리 로그를 통해 디버깅 할 수 있습니다. 5) 성능 최적화 방법에는 인덱스의 합리적인 사용, 최적화 된 쿼리 및 캐시 사용이 포함됩니다. 모범 사례에는 거래 사용 및 준비된 체계가 포함됩니다

MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점 MySQL을 사용하는 이유는 무엇입니까? 혜택과 장점 Apr 12, 2025 am 12:17 AM

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

Apache의 데이터베이스에 연결하는 방법 Apache의 데이터베이스에 연결하는 방법 Apr 13, 2025 pm 01:03 PM

Apache는 데이터베이스에 연결하여 다음 단계가 필요합니다. 데이터베이스 드라이버 설치. 연결 풀을 만들려면 Web.xml 파일을 구성하십시오. JDBC 데이터 소스를 작성하고 연결 설정을 지정하십시오. JDBC API를 사용하여 Connections, 명세서 작성, 매개 변수 바인딩, 쿼리 또는 업데이트 실행 및 처리를 포함하여 Java 코드의 데이터베이스에 액세스하십시오.

Docker의 MySQL을 시작하는 방법 Docker의 MySQL을 시작하는 방법 Apr 15, 2025 pm 12:09 PM

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

Centos 설치 MySQL Centos 설치 MySQL Apr 14, 2025 pm 08:09 PM

Centos에 MySQL을 설치하려면 다음 단계가 필요합니다. 적절한 MySQL Yum 소스 추가. mysql 서버를 설치하려면 yum install mysql-server 명령을 실행하십시오. mysql_secure_installation 명령을 사용하여 루트 사용자 비밀번호 설정과 같은 보안 설정을 작성하십시오. 필요에 따라 MySQL 구성 파일을 사용자 정의하십시오. MySQL 매개 변수를 조정하고 성능을 위해 데이터베이스를 최적화하십시오.

See all articles