【관련 학습 권장 사항: mysql tutorial(동영상)】
DCL은 비교적 간단하며 주로 데이터베이스에 액세스하고 데이터베이스를 제출할 수 있는 권한을 부여하거나 취소하는 데 사용됩니다. 트랜잭션 및 롤백.
권한 부여를 예로 들어보겠습니다. 새 데이터베이스를 생성한 후 특정 사용자에게 데이터베이스에 대한 액세스 및 작업 권한을 부여하려고 합니다(일반적으로 프로덕션 환경에서는 보안상의 이유로 루트 사용자). 데이터베이스를 운영하지 않습니다.) 이를 위해서는 먼저 test
와 같은 특정 사용자를 생성해야 합니다. DCL과 같은 제어 수준 SQL 문은 일반적으로 명령줄에서 실행됩니다. MySQL Docker 컨테이너를 데이터베이스에 연결하고 CREATE USER
문을 전달하여 새 test
사용자를 생성하고 비밀번호를 test
로 설정합니다. test
,DCL 这种控制级的 SQL 语句一般在命令行执行,我们进入 MySQL Docker 容器,连接到数据库,通过 CREATE USER
语句新建一个 test
用户,同时将密码设置为 test
:
创建完成后,就可以在 mysql.user
数据表中看到这个用户了:
Host
字段为 %
表示 test
用户可以从任何主机连接到 MySQL 服务器。
或者通过命令行查看(这里用到了 SQL 查询语句):
然后我们就可以运行 GRANT
语句授予 test
用户对 test
数据库的所有操作权限了:
授权后,需要运行 flush privileges;
刷新权限,这样就可以在 test
数据库的权限列表中看到这个用户了:
如果我们退出当前登录状态,以 test
用户登录,就只能看到 test
数据库,因为它对其他数据库没有操作权限:
要撤回权限,需要以 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
语句回滚事务。
我们在命令行中简单演示下数据库事务的操作:
我们通过 BEGIN
语句开启事务,但是在执行多条语句后,没有通过 COMMIT
提交事务,测试执行这几条 SQL 语句,进入「浏览」面板查看,发现并没有插入新的记录:
如果在上述 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.user
데이터 테이블에서 이 사용자를 확인하세요. :
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
, max
및 min. <code>count
、sum
、avg
、max
和 min
。
count
函数可用于统计查询结果总共有多少条,通常在进行分页查询时需要用到这个函数。为了方便直接看到结果,我们在命令行中进行演示:
在查询字段时为了提高可读性,可以通过 as
指定字段别名,这里 post
表总共有三条记录,所以查询结果是 3
。
sum
可用于统计查询结果中某个字段的求和,因此只能用于数字类型字段,这里我们为 post
表新增一个字段 views
,用于存储对应文章记录的浏览次数。在 post
表结构中,选择在 content
字段后新增一个字段并点击「执行」:
将字段名设置为 views
,并将其类型设置为 UNSIGNED INT
,表示非负整数,同时设置默认值为 0
,对应的 SQL 语句可以通过预览功能查看:
点击「保存」创建这个字段,就可以在表结构中看到它了:
由于 views
有默认值,所以目前所有记录的 views
值都是 0:
可以通过「编辑」功能将其设置为对应的模拟值:
接下来,我们就可以通过 sum
函数对结果进行求和统计了:
avg
可用于统计查询结果中某个字段的平均值,和 sum
一样,也是作用于数字类型字段,比如我们可以通过它来统计所有文章的平均浏览数:
如果是一个不能被整除的数字,平均数会精确到小数点后四位。
max
可用于获取查询结果中某个数字类型字段的最大值,比如要获取浏览数最高的文章信息可以这么做:
MySQL 命令行默认中文乱码,我们可以通过 set names utf8mb4;
将编码类型设置为 utf8mb4
,这样就可以正常显示中文和 Emoji 表情符号了。
另外,这里还用到了子查询的概念,就是将一个查询的结果作为另一个查询的条件,这里我们将最大浏览数作为子查询的结果传递给父查询作为查询条件,获取对应的文章信息。
与 max
相对,min
count
함수는 쿼리 결과의 총 개수를 계산하는 데 사용할 수 있습니다. 이 함수는 일반적으로 페이징 쿼리를 수행할 때 사용됩니다. 결과를 직접 확인하기 위해 명령줄에서 시연합니다. as
를 통해 필드 별칭을 지정할 수 있습니다. 여기서 post
테이블에는 총 3개의 레코드가 있습니다. 이므로 쿼리 결과는 3
입니다. sum
은 통계 쿼리 결과의 특정 필드를 합산하는 데 사용할 수 있으므로 숫자 유형 필드에만 사용할 수 있습니다. 여기서는 게시물입니다.
해당 기사 레코드의 조회수를 저장하는 데 사용되는 새 필드 views
가 테이블에 추가됩니다. post
테이블 구조에서 content
필드 뒤에 새 필드를 추가하도록 선택하고 "실행"을 클릭합니다:
views
로 설정하고 해당 유형을 UNSIGNED INT0
으로 설정됩니다. 해당 SQL 문은 미리보기 기능을 통해 볼 수 있습니다: 🎜🎜🎜을 통해 설정할 수 있습니다. "편집" 기능 해당 시뮬레이션 값: 🎜🎜🎜 🎜다음으로이 필드를 생성하려면 "저장"을 클릭하고 테이블 구조에 추가할 수 있습니다. 보았습니다:
views
에는 기본값이 있으므로 현재 모든 레코드의views
값은 0입니다:
sum
함수를 통해 결과를 요약할 수 있습니다. 🎜🎜🎜avg
는 쿼리 결과에서 필드의 평균 값을 계산하는 데 사용할 수 있습니다. sum
은 동일하며 숫자 필드에서도 작동합니다. 예를 들어 모든 기사의 평균 조회수를 계산하는 데 사용할 수 있습니다. 🎜🎜🎜🎜나누기가 어려운 숫자라면 평균은 소수점 4자리까지 정확합니다 . 🎜max
는 쿼리 결과에서 특정 숫자 필드의 최대값을 가져오는 데 사용할 수 있습니다. 예를 들어 조회수가 가장 높은 기사 정보를 가져오는 데 사용할 수 있습니다. , 다음과 같이 할 수 있습니다: 🎜🎜🎜🎜MySQL 명령줄의 기본값은 중국어 왜곡 문자로 설정되어 있으므로 set names utf8mb4;를 전달할 수 있습니다. 인코딩 유형을 utf8mb4
로 설정하면 중국어 및 이모티콘 이모티콘이 정상적으로 표시될 수 있습니다. 🎜🎜또한 여기서는 한 쿼리의 결과를 다른 쿼리의 조건으로 사용하는 하위 쿼리 개념도 사용됩니다. 해당 기사 정보를 얻기 위해 상위 쿼리에 대한 하위 쿼리를 쿼리 조건으로 사용합니다. 🎜max
와 관련하여 min
함수는 쿼리 결과에서 숫자 필드의 최소값을 얻는 데 사용됩니다. 최소 기사 정보는 다음과 같습니다. 🎜🎜🎜🎜🎜Summary🎜🎜 좋습니다. MySQL 데이터베이스의 기본 쿼리, 작업 및 통계에 대해서는 여기서 간단히 소개하겠습니다. MySQL과 그 운영에 대한 이해. 다음 튜토리얼에서는 PHP에서 MySQL 데이터베이스에 연결하고 추가, 삭제, 수정 및 쿼리 작업을 수행하는 방법을 소개합니다. 페이징, 그룹화, 연결 쿼리, 연관 관계, 인덱스 설정과 같은 좀 더 복잡한 작업에 대해 설명합니다. 및 응용 프로그램에 대해서는 후속 자습서에서 구체적인 예를 통해 설명하겠습니다. 🎜🎜이 기사는 https://xueyuanjun.com/post/21656🎜🎜🎜🎜🎜에서 따왔습니다. 더 많은 관련 기사를 알고 싶다면 🎜php mysql🎜 칼럼을 주목해주세요! 🎜🎜🎜위 내용은 MySQL 기본 사용법 (2) DCL 문 및 집계 함수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!