>주제 >PHP MySQL >MySQL 기본 사용법 (2) DCL 문 및 집계 함수

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

coldplay.xixi
coldplay.xixi앞으로
2020-09-05 17:14:162477검색

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

【관련 학습 권장 사항: mysql tutorial(동영상)】

DCL

DCL은 비교적 간단하며 주로 데이터베이스에 액세스하고 데이터베이스를 제출할 수 있는 권한을 부여하거나 취소하는 데 사용됩니다. 트랜잭션 및 롤백.

권한 부여/취소

권한 부여를 예로 들어보겠습니다. 새 데이터베이스를 생성한 후 특정 사용자에게 데이터베이스에 대한 액세스 및 작업 권한을 부여하려고 합니다(일반적으로 프로덕션 환경에서는 보안상의 이유로 루트 사용자). 데이터베이스를 운영하지 않습니다.) 이를 위해서는 먼저 test와 같은 특정 사용자를 생성해야 합니다. DCL과 같은 제어 수준 SQL 문은 일반적으로 명령줄에서 실행됩니다. MySQL Docker 컨테이너를 데이터베이스에 연결하고 CREATE USER 문을 전달하여 새 test 사용자를 생성하고 비밀번호를 test로 설정합니다. test,DCL 这种控制级的 SQL 语句一般在命令行执行,我们进入 MySQL Docker 容器,连接到数据库,通过 CREATE USER 语句新建一个 test 用户,同时将密码设置为 test

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

创建完成后,就可以在 mysql.user 数据表中看到这个用户了:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

Host 字段为 % 表示 test 用户可以从任何主机连接到 MySQL 服务器。

或者通过命令行查看(这里用到了 SQL 查询语句):

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

然后我们就可以运行 GRANT 语句授予 test 用户对 test 数据库的所有操作权限了:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

授权后,需要运行 flush privileges; 刷新权限,这样就可以在 test 数据库的权限列表中看到这个用户了:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수权限

如果我们退出当前登录状态,以 test 用户登录,就只能看到 test 数据库,因为它对其他数据库没有操作权限:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

要撤回权限,需要以 root 身份进行,在权限列表删除这个用户,或者在命令行通过 REVOKE 语句完成:

revoke all privideges on test.* from 'test'@'%';
flush privileges;

这里操作的都是所有权限,也可以指定特定的权限:

// 授予权限
grant select on test.* to 'user1'@'localhost';  /*给予查询权限*/
grant insert on test.* to 'user1'@'localhost'; /*添加插入权限*/
grant delete on test.* to 'user1'@'localhost'; /*添加删除权限*/
grant update on test.* to 'user1'@'localhost'; /*添加权限*/

// 收回权限
revoke select on test.* from 'jack'@'localhost';
revoke insert on test.* from 'jack'@'localhost';
revoke delete on test.* from 'jack'@'localhost';
revoke update on test.* from 'jack'@'localhost';

事务提交/回滚

数据库事务(Database Transaction)是指作为单个逻辑工作单元执行的一系列操作(对数据库的相关增删改查的操作,包含一条或多条 SQL 语句),要么完全地执行,要么完全地不执行。

对于单条 SQL 语句,数据库系统自动将其作为一个事务执行,这种事务被称为隐式事务

要手动把多条 SQL 语句作为一个事务执行,可以使用 BEGIN 开启一个事务,使用 COMMIT 提交一个事务,这种事务被称为显式事务,如果事务执行过程中出现错误或异常,可以通过 ROLLBACK 语句回滚事务。

我们在命令行中简单演示下数据库事务的操作:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

我们通过 BEGIN 语句开启事务,但是在执行多条语句后,没有通过 COMMIT 提交事务,测试执行这几条 SQL 语句,进入「浏览」面板查看,发现并没有插入新的记录:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

如果在上述 SQL 序列后加上 ROLLBACK 回滚事务,效果也是一样的:

BEGIN;

INSERT INTO post (`title`, `content, `created_at`) VALUES ('这是一篇测试文章2', '测试内容哈哈哈', '2020-05-26 13:00:00');
INSERT INTO post (`title`, `content, `created_at`) VALUES ('这是一篇测试文章3', '测试内容哈哈哈', '2020-05-26 13:30:00');

ROLLBACK;

而如果在最后加上 COMMIT

새 사용자 만들기

MySQL 기본 사용법 (2) DCL 문 및 집계 함수생성이 완료되면 다음을 수행할 수 있습니다. mysql.user 데이터 테이블에서 이 사용자를 확인하세요. :

새 사용자 보기MySQL 기본 사용법 (2) DCL 문 및 집계 함수

Host 필드는 <code>%입니다. 이는 test 사용자가 어디서든 MySQL 서버에 연결할 수 있음을 의미합니다. 주인.

또는 명령줄을 통해 확인하세요(여기서는 SQL 쿼리 문이 사용됨): 🎜

새 사용자 보기🎜🎜그런 다음 GRANT 문을 실행하여 test 사용자에게 test 이제 데이터베이스의 모든 작업 권한을 사용할 수 있습니다: 🎜🎜새 사용자 권한 부여🎜🎜인증 후 flush 특권;을 실행하여 권한을 새로 고쳐야 의 권한 목록에서 이 사용자를 볼 수 있습니다. 테스트 데이터베이스: 🎜🎜새 사용자 권한 보기 🎜🎜현재 로그인 상태를 종료하면 test 사용자가 로그인하면 다른 데이터베이스에 대한 운영 권한이 없기 때문에 test 데이터베이스만 볼 수 있습니다. 🎜🎜🎜🎜권한을 취소하려면 루트로 수행하거나, 권한 목록에서 이 사용자를 삭제하거나, 다음 명령을 실행해야 합니다. REVOKE 문을 통해 줄이 완성됩니다: 🎜rrreee🎜모든 권한은 여기서 작동되며 특정 권한도 가능합니다. 지정: 🎜rrreee🎜트랜잭션 제출/롤백🎜🎜데이터베이스 트랜잭션은 단일 논리적 작업 단위에서 수행되는 일련의 작업(하나 이상의 SQL 문을 포함하여 데이터베이스 추가, 삭제, 수정 및 쿼리와 관련된 작업)을 의미합니다. , 완전히 실행되거나 전혀 실행되지 않습니다. 🎜🎜단일 SQL 문에 대해 데이터베이스 시스템은 자동으로 이를 트랜잭션으로 실행합니다. 이 트랜잭션을 🎜암시적 트랜잭션🎜이라고 합니다. 🎜🎜여러 SQL 문을 하나의 트랜잭션으로 수동으로 실행하려면 BEGIN을 사용하여 트랜잭션을 열고 COMMIT을 사용하여 트랜잭션을 제출할 수 있습니다. 트랜잭션 실행 중 오류나 예외가 발생하면 ROLLBACK 문을 통해 트랜잭션을 롤백할 수 있습니다. 🎜🎜명령줄에서 데이터베이스 트랜잭션의 작동을 간략하게 보여줍니다: 🎜

데이터베이스 트랜잭션 데모🎜🎜BEGIN 문을 통해 트랜잭션을 시작했지만 여러 문을 실행한 후 COMMIT 거래를 제출하고, 다음 SQL 문을 테스트 및 실행하고, "찾아보기" 패널에 들어가 새 레코드가 삽입되지 않았는지 확인하세요. 🎜🎜데이터베이스 트랜잭션 데모🎜🎜트랜잭션을 롤백하기 위해 위의 SQL 시퀀스 뒤에 ROLLBACK을 추가하면 그 효과는 다음과 같습니다. 동일: 🎜rrreee🎜그리고 마지막에 COMMIT 문을 추가하면 수정 사항을 원활하게 제출할 수 있습니다. 🎜🎜🎜🎜🎜🎜🎜🎜 phpMyAdmin의 일반적인 SQL 문 및 시각적 데모에 대해서는 다음과 같습니다. 간략한 소개와 자세한 내용은 온라인 SQL 자습서와 함께 직접 살펴보아야 합니다. 이는 이 자습서 시리즈의 초점이 아니므로 여기서는 자세히 설명하지 않겠습니다. 🎜

집계 함수

일반적인 SQL 쿼리 및 연산 명령문 외에도 SQL에는 데이터 쿼리 중 결과를 간단하고 편리하게 통계할 수 있는 집계 함수가 내장되어 있습니다. 여기서는 count, sum, avg, maxmin. <code>countsumavgmaxmin

COUNT

count 函数可用于统计查询结果总共有多少条,通常在进行分页查询时需要用到这个函数。为了方便直接看到结果,我们在命令行中进行演示:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

在查询字段时为了提高可读性,可以通过 as 指定字段别名,这里 post 表总共有三条记录,所以查询结果是 3

SUM

sum 可用于统计查询结果中某个字段的求和,因此只能用于数字类型字段,这里我们为 post 表新增一个字段 views,用于存储对应文章记录的浏览次数。在 post 表结构中,选择在 content 字段后新增一个字段并点击「执行」:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

将字段名设置为 views,并将其类型设置为 UNSIGNED INT,表示非负整数,同时设置默认值为 0,对应的 SQL 语句可以通过预览功能查看:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

点击「保存」创建这个字段,就可以在表结构中看到它了:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

由于 views 有默认值,所以目前所有记录的 views 值都是 0:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수默认值

可以通过「编辑」功能将其设置为对应的模拟值:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

接下来,我们就可以通过 sum 函数对结果进行求和统计了:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

AVG

avg 可用于统计查询结果中某个字段的平均值,和 sum 一样,也是作用于数字类型字段,比如我们可以通过它来统计所有文章的平均浏览数:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

如果是一个不能被整除的数字,平均数会精确到小数点后四位。

MAX

max 可用于获取查询结果中某个数字类型字段的最大值,比如要获取浏览数最高的文章信息可以这么做:

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

MySQL 命令行默认中文乱码,我们可以通过 set names utf8mb4; 将编码类型设置为 utf8mb4,这样就可以正常显示中文和 Emoji 表情符号了。

另外,这里还用到了子查询的概念,就是将一个查询的结果作为另一个查询的条件,这里我们将最大浏览数作为子查询的结果传递给父查询作为查询条件,获取对应的文章信息。

MIN

max 相对,min

COUNT

count 함수는 쿼리 결과의 총 개수를 계산하는 데 사용할 수 있습니다. 이 함수는 일반적으로 페이징 쿼리를 수행할 때 사용됩니다. 결과를 직접 확인하기 위해 명령줄에서 시연합니다.

MySQL 기본 사용법 (2) DCL 문 및 집계 함수

필드를 쿼리할 때 가독성을 높이기 위해 as를 통해 필드 별칭을 지정할 수 있습니다. 여기서 post 테이블에는 총 3개의 레코드가 있습니다. 이므로 쿼리 결과는 3입니다.

SUM

sum은 통계 쿼리 결과의 특정 필드를 합산하는 데 사용할 수 있으므로 숫자 유형 필드에만 사용할 수 있습니다. 여기서는 게시물입니다. 해당 기사 레코드의 조회수를 저장하는 데 사용되는 새 필드 views가 테이블에 추가됩니다. post 테이블 구조에서 content 필드 뒤에 새 필드를 추가하도록 선택하고 "실행"을 클릭합니다:

새 데이터 테이블 필드

필드 이름을 views로 설정하고 해당 유형을 UNSIGNED INT
는 음수가 아닌 정수를 나타내며 기본값은 0으로 설정됩니다. 해당 SQL 문은 미리보기 기능을 통해 볼 수 있습니다:
새 데이터 테이블 필드

이 필드를 생성하려면 "저장"을 클릭하고 테이블 구조에 추가할 수 있습니다. 보았습니다:

새 데이터 테이블 필드

views에는 기본값이 있으므로 현재 모든 레코드의 views 값은 0입니다:
🎜🎜🎜을 통해 설정할 수 있습니다. "편집" 기능 해당 시뮬레이션 값: 🎜🎜데이터 테이블 필드 값 수정 🎜 🎜다음으로 sum 함수를 통해 결과를 요약할 수 있습니다. 🎜🎜sum Statistics🎜

AVG

🎜avg는 쿼리 결과에서 필드의 평균 값을 계산하는 데 사용할 수 있습니다. sum은 동일하며 숫자 필드에서도 작동합니다. 예를 들어 모든 기사의 평균 조회수를 계산하는 데 사용할 수 있습니다. 🎜🎜MySQL 기본 사용법 (2) DCL 문 및 집계 함수🎜🎜나누기가 어려운 숫자라면 평균은 소수점 4자리까지 정확합니다 . 🎜

MAX

🎜max는 쿼리 결과에서 특정 숫자 필드의 최대값을 가져오는 데 사용할 수 있습니다. 예를 들어 조회수가 가장 높은 기사 정보를 가져오는 데 사용할 수 있습니다. , 다음과 같이 할 수 있습니다: 🎜🎜max query🎜🎜MySQL 명령줄의 기본값은 중국어 왜곡 문자로 설정되어 있으므로 set names utf8mb4;를 전달할 수 있습니다. 인코딩 유형을 utf8mb4로 설정하면 중국어 및 이모티콘 이모티콘이 정상적으로 표시될 수 있습니다. 🎜🎜또한 여기서는 한 쿼리의 결과를 다른 쿼리의 조건으로 사용하는 하위 쿼리 개념도 사용됩니다. 해당 기사 정보를 얻기 위해 상위 쿼리에 대한 하위 쿼리를 쿼리 조건으로 사용합니다. 🎜

MIN

🎜max와 관련하여 min 함수는 쿼리 결과에서 숫자 필드의 최소값을 얻는 데 사용됩니다. 최소 기사 정보는 다음과 같습니다. 🎜🎜🎜🎜🎜Summary🎜🎜 좋습니다. MySQL 데이터베이스의 기본 쿼리, 작업 및 통계에 대해서는 여기서 간단히 소개하겠습니다. MySQL과 그 운영에 대한 이해. 다음 튜토리얼에서는 PHP에서 MySQL 데이터베이스에 연결하고 추가, 삭제, 수정 및 쿼리 작업을 수행하는 방법을 소개합니다. 페이징, 그룹화, 연결 쿼리, 연관 관계, 인덱스 설정과 같은 좀 더 복잡한 작업에 대해 설명합니다. 및 응용 프로그램에 대해서는 후속 자습서에서 구체적인 예를 통해 설명하겠습니다. 🎜🎜이 기사는 https://xueyuanjun.com/post/21656🎜🎜🎜🎜🎜에서 따왔습니다. 더 많은 관련 기사를 알고 싶다면 🎜php mysql🎜 칼럼을 주목해주세요! 🎜🎜🎜

위 내용은 MySQL 기본 사용법 (2) DCL 문 및 집계 함수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 xueyuanjun.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제

관련 기사

더보기