목차
1. 使用group by的简单例子
2. group by 原理分析
2.1 explain 分析
2.2 group by 的简单执行流程
1. 그룹 사용 by
2. 원칙별 그룹화
2.1 분석 설명
2.2 group by의 간단한 실행 과정
3. where 和 having的区别
3.1 group by + where 的执行流程
3.2 group by + having 的执行
3.3 同时有where、group by 、having的执行顺序
3.4 where + having 区别总结
4. 使用 group by 注意的问题
4.1 group by一定要配合聚合函数使用嘛?
4.2 group by 后面跟的字段一定要出现在select中嘛。
5. group by的一些优化方案
5.1 group by 后面的字段加索引
5.2 order by null 不用排序
5.3 尽量只使用内存临时表
5.4 使用SQL_BIG_RESULT优化
6. 一个生产慢SQL如何优化
데이터 베이스 MySQL 튜토리얼 MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

Jan 17, 2022 pm 07:28 PM
group by mysql

MySql에서 그룹별을 어떻게 사용하나요? 다음 글은 group by 사용법에 대한 심층적인 분석을 제공할 것입니다. 도움이 되기를 바랍니다.

MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

일상적인 개발에서는 group by를 자주 사용합니다. 친애하는 친구 여러분, 그룹화가 어떻게 작동하는지 아시나요? 그룹화 기준갖기의 차이점은 무엇인가요? 그룹화의 최적화 아이디어는 무엇인가요? group by를 사용할 때 주의해야 할 문제는 무엇인가요? 이번 글에서는 group by를 극복하는 방법을 함께 배워보겠습니다~group by。亲爱的小伙伴,你是否知道group by的工作原理呢?group byhaving有什么区别呢?group by的优化思路是怎样的呢?使用group by有哪些需要注意的问题呢?本文将跟大家一起来学习,攻克group by~

  • 使用group by的简单例子
  • group by 工作原理
  • group by + where 和 group by + having的区别
  • group by 优化思路
  • group by 使用注意点
  • 一个生产慢SQL如何优化

【相关推荐:mysql视频教程

1. 使用group by的简单例子

group by一般用于分组统计,它表达的逻辑就是根据一定的规则,进行分组。我们先从一个简单的例子,一起复习一下哈。

假设用一张员工表,表结构如下:

CREATE TABLE `staff` (
  `id` bigint(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',
  `id_card` varchar(20) NOT NULL COMMENT '身份证号码',
  `name` varchar(64) NOT NULL COMMENT '姓名',
  `age` int(4) NOT NULL COMMENT '年龄',
  `city` varchar(64) NOT NULL COMMENT '城市',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='员工表';
로그인 후 복사

表存量的数据如下:

MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

我们现在有这么一个需求:统计每个城市的员工数量。对应的 SQL 语句就可以这么写:

select city ,count(*) as num from staff group by city;
로그인 후 복사

执行结果如下:

MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

这条SQL语句的逻辑很清楚啦,但是它的底层执行流程是怎样的呢?

2. group by 原理分析

2.1 explain 分析

我们先用explain查看一下执行计划

explain select city ,count(*) as num from staff group by city;
로그인 후 복사
로그인 후 복사

MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

  • Extra 这个字段的Using temporary表示在执行分组的时候使用了临时表
  • Extra 这个字段的Using filesort表示使用了排序

group by 怎么就使用到临时表和排序了呢?我们来看下这个SQL的执行流程

2.2 group by 的简单执行流程

explain select city ,count(*) as num from staff group by city;
로그인 후 복사
로그인 후 복사

我们一起来看下这个SQL的执行流程哈

  1. 创建内存临时表,表里有两个字段citynum
  2. 全表扫描staff的记录,依次取出city = 'X'的记录。
  • 判断临时表中是否有为 city='X'的行,没有就插入一个记录 (X,1);
  • 如果临时表中有city='X'的行的行,就将x 这一行的num值加 1;
  1. 遍历完成后,再根据字段city排序,得到结果集返回给客户端。

这个流程的执行图如下:

MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

临时表的排序是怎样的呢?

就是把需要排序的字段,放到sort buffer,排完就返回。在这里注意一点哈,排序分全字段排序rowid排序

  • 如果是全字段排序,需要查询返回的字段,都放入sort buffer,根据排序字段排完,直接返回
  • 如果是rowid排序,只是需要排序的字段放入sort buffer,然后多一次回表操作,再返回。
  • 怎么确定走的是全字段排序还是rowid 排序排序呢?由一个数据库参数控制的,max_length_for_sort_data
    • group by를 사용하는 간단한 예
    • group by 작동 원리
  • group by + where와 group by + had의 차이점
  • group by 최적화 아이디어

  • group by 사용 시 주의사항

  • 느린 프로덕션 SQL을 최적화하는 방법🎜🎜🎜[관련 권장사항: mysql 비디오 튜토리얼]🎜

    1. 그룹 사용 by

    🎜group by의 간단한 예는 일반적으로 통계 그룹화에 사용됩니다. 이것이 표현하는 논리는 입니다. >특정 규칙에 따라 그룹화 . 간단한 예부터 시작해 함께 살펴보겠습니다. 🎜🎜직원 테이블을 사용한다고 가정해 보겠습니다. 테이블 구조는 다음과 같습니다. 🎜
    select city ,count(*) as num from staff where age> 30 group by city;
    //加索引
    alter table staff add index idx_age (age);
    로그인 후 복사
    로그인 후 복사
    🎜테이블 인벤토리 데이터는 다음과 같습니다. 🎜🎜MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)🎜🎜이제 각 도시의 직원 수를 세어보세요가 필요합니다. 해당 SQL 문은 다음과 같이 작성할 수 있습니다. 🎜
    explain select city ,count(*) as num from staff where age> 30 group by city;
    로그인 후 복사
    로그인 후 복사
    🎜실행 결과는 다음과 같습니다. 🎜🎜MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)🎜🎜이 SQL 문의 논리는 매우 명확하지만 기본 실행 프로세스는 무엇입니까? 🎜

    2. 원칙별 그룹화

    2.1 분석 설명

    🎜 먼저 설명을 사용하여 실행 계획을 확인해 보겠습니다🎜
    select city ,count(*) as num from staff  group by city having num >= 3;
    로그인 후 복사
    로그인 후 복사
    🎜MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)🎜
    • 이 필드의 추가 Using temporary는 수행 시 임시 테이블이 사용됨을 나타냅니다. grouping 🎜
    • Extra 이 필드의 Using filesortsort🎜🎜🎜group by 사용을 나타냅니다. 사용 방법 임시 테이블 및 정렬? 이 SQL의 실행 과정을 살펴보겠습니다🎜

      2.2 group by의 간단한 실행 과정

      select city ,count(*) as num from staff  where age> 19 group by city having num >= 3;
      로그인 후 복사
      로그인 후 복사
      🎜 이 SQL 실행 프로세스의 실행 프로세스🎜
      1. citynum 두 필드가 있는 임시 메모리 테이블을 생성합니다. 🎜
      2. 전체 테이블 스캔 직원의 기록에서 도시 = 'X'의 기록을 차례로 꺼냅니다. 🎜
      • 임시 테이블에 city='X'인 행이 있는지 확인합니다. 그렇지 않으면 레코드(X,1)를 삽입합니다. >임시인 경우 테이블에 city='X'인 행이 있는 경우 x 행의 num 값에 1을 추가합니다. 🎜🎜
        1. 순회가 완료된 후 다음과 같이 합니다. city</ code>필드에 <strong>정렬</strong>을 수행하고 결과 세트를 가져와 클라이언트에 반환합니다. 🎜</ol>🎜이 프로세스의 실행 다이어그램은 다음과 같습니다. 🎜🎜<img src="/static/imghw/default1.png" data-src="https://img.php.cn/upload/image/793/555/513/1642418550467450.png" class="lazy" title=" 164241850361512MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명) " alt="MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)"/>🎜🎜임시 테이블 정렬은 어떻게 되나요? 🎜<blockquote>🎜정렬이 필요한 필드를 정렬 버퍼에 넣고 정렬 후 반환하면 됩니다. 여기서 주목해야 할 점은 정렬이 <strong>전체 필드 정렬</strong>과 <strong>rowid 정렬</strong>로 나누어진다는 것입니다.🎜<ul><li><code>전체 필드 정렬</code인 경우 >, 쿼리해야 합니다. 반환된 필드는 <code>정렬 버퍼에 넣고 정렬 필드에 따라 정렬된 후 직접 반환됩니다🎜
        2. rowid인 경우 정렬, 필요합니다. 정렬된 필드를 정렬 버퍼에 넣은 다음 테이블로 돌아가기 작업을 한 번 더 수행한 후 반환합니다. 🎜
        3. 전체 필드 정렬을 사용할지, 행 ID 정렬을 사용할지 어떻게 결정하나요? 데이터베이스 매개변수인 max_length_for_sort_data🎜🎜🎜🎜에 의해 제어됩니다. 정렬에 대해 더 자세히 알고 싶은 친구는 이 기사를 읽어보세요. 🎜

          3. where 和 having的区别

          • group by + where 的执行流程
          • group by + having 的执行流程
          • 同时有where、group by 、having的执行顺序

          3.1 group by + where 的执行流程

          有些小伙伴觉得上一小节的SQL太简单啦,如果加了where条件之后,并且where条件列加了索引呢,执行流程是怎样

          好的,我们给它加个条件,并且加个idx_age的索引,如下:

          select city ,count(*) as num from staff where age> 30 group by city;
          //加索引
          alter table staff add index idx_age (age);
          로그인 후 복사
          로그인 후 복사

          再来expain分析一下:

          explain select city ,count(*) as num from staff where age> 30 group by city;
          로그인 후 복사
          로그인 후 복사

          MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          从explain 执行计划结果,可以发现查询条件命中了idx_age的索引,并且使用了临时表和排序

          Using index condition:表示索引下推优化,根据索引尽可能的过滤数据,然后再返回给服务器层根据where其他条件进行过滤。这里单个索引为什么会出现索引下推呢?explain出现并不代表一定是使用了索引下推,只是代表可以使用,但是不一定用了。大家如果有想法或者有疑问,可以加我微信讨论哈。

          执行流程如下:

          1、创建内存临时表,表里有两个字段citynum

          2、扫描索引树idx_age,找到大于年龄大于30的主键ID

          3、通过主键ID,回表找到city = 'X'

          • 判断临时表中是否有为 city='X'的行,没有就插入一个记录 (X,1);
          • 如果临时表中有city='X'的行的行,就将x 这一行的num值加 1;

          4、继续重复2,3步骤,找到所有满足条件的数据,

          5、最后根据字段city排序,得到结果集返回给客户端。

          3.2 group by + having 的执行

          如果你要查询每个城市的员工数量,获取到员工数量不低于3的城市,having可以很好解决你的问题,SQL酱紫写:

          select city ,count(*) as num from staff  group by city having num >= 3;
          로그인 후 복사
          로그인 후 복사

          查询结果如下:

          MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          having称为分组过滤条件,它对返回的结果集操作。

          3.3 同时有where、group by 、having的执行顺序

          如果一个SQL同时含有where、group by、having子句,执行顺序是怎样的呢。

          比如这个SQL:

          select city ,count(*) as num from staff  where age> 19 group by city having num >= 3;
          로그인 후 복사
          로그인 후 복사
          • 执行where子句查找符合年龄大于19的员工数据

          • group by子句对员工数据,根据城市分组。

          • group by子句形成的城市组,运行聚集函数计算每一组的员工数量值;

          • 最后用having子句选出员工数量大于等于3的城市组。

          3.4 where + having 区别总结

          • having子句用于分组后筛选,where子句用于条件筛选
          • having一般都是配合group by 和聚合函数一起出现如(count(),sum(),avg(),max(),min())
          • where条件子句中不能使用聚集函数,而having子句就可以。
          • having只能用在group by之后,where执行在group by之前

          4. 使用 group by 注意的问题

          使用group by 主要有这几点需要注意:

          • group by一定要配合聚合函数一起使用嘛?
          • group by的字段一定要出现在select中嘛
          • group by导致的慢SQL问题

          4.1 group by一定要配合聚合函数使用嘛?

          group by 就是分组统计的意思,一般情况都是配合聚合函数 如(count(),sum(),avg(),max(),min())一起使用。

          • count() 数量
          • sum() 总和
          • avg() 平均
          • max() 最大值
          • min() 最小值

          如果没有配合聚合函数使用可以吗?

          我用的是Mysql 5.7 ,是可以的。不会报错,并且返回的是,分组的第一行数据。

          比如这个SQL:

          select city,id_card,age from staff group by  city;
          로그인 후 복사

          查询结果是

          MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          大家对比看下,返回的就是每个分组的第一条数据

          MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          当然,平时大家使用的时候,group by还是配合聚合函数使用的,除非一些特殊场景,比如你想去重,当然去重用distinct也是可以的。

          4.2 group by 后面跟的字段一定要出现在select中嘛。

          不一定,比如以下SQL:

          select max(age)  from staff group by city;
          로그인 후 복사

          执行结果如下:

          MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          分组字段city不在select 后面,并不会报错。当然,这个可能跟不同的数据库,不同的版本有关吧。大家使用的时候,可以先验证一下就好。有一句话叫做,纸上得来终觉浅,绝知此事要躬行

          4.3 <span style="font-size: 16px;">group by</span>导致的慢SQL问题

          到了最重要的一个注意问题啦,group by使用不当,很容易就会产生慢SQL 问题。因为它既用到临时表,又默认用到排序。有时候还可能用到磁盘临时表

          • 如果执行过程中,会发现内存临时表大小到达了上限(控制这个上限的参数就是tmp_table_size),会把内存临时表转成磁盘临时表
          • 如果数据量很大,很可能这个查询需要的磁盘临时表,就会占用大量的磁盘空间。

          这些都是导致慢SQL的x因素,我们一起来探讨优化方案哈。

          5. group by的一些优化方案

          从哪些方向去优化呢?

          • 方向1: 既然它默认会排序,我们不给它排是不是就行啦。
          • 方向2:既然临时表是影响group by性能的X因素,我们是不是可以不用临时表?

          我们一起来想下,执行group by语句为什么需要临时表呢?group by的语义逻辑,就是统计不同的值出现的个数。如果这个这些值一开始就是有序的,我们是不是直接往下扫描统计就好了,就不用临时表来记录并统计结果啦?

          • group by 后面的字段加索引
          • order by null 不用排序
          • 尽量只使用内存临时表
          • 使用SQL_BIG_RESULT

          5.1 group by 后面的字段加索引

          如何保证group by后面的字段数值一开始就是有序的呢?当然就是加索引啦。

          我们回到一下这个SQL

          select city ,count(*) as num from staff where age= 19 group by city;
          로그인 후 복사

          它的执行计划

          MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          如果我们给它加个联合索引idx_age_city(age,city)

          alter table staff add index idx_age_city(age,city);
          로그인 후 복사

          再去看执行计划,发现既不用排序,也不需要临时表啦。

          1MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          加合适的索引是优化group by最简单有效的优化方式。

          5.2 order by null 不用排序

          并不是所有场景都适合加索引的,如果碰上不适合创建索引的场景,我们如何优化呢?

          如果你的需求并不需要对结果集进行排序,可以使用order by null

          select city ,count(*) as num from staff group by city order by null
          로그인 후 복사

          执行计划如下,已经没有filesort

          1MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          5.3 尽量只使用内存临时表

          如果group by需要统计的数据不多,我们可以尽量只使用内存临时表;因为如果group by 的过程因为数据放不下,导致用到磁盘临时表的话,是比较耗时的。因此可以适当调大tmp_table_size参数,来避免用到磁盘临时表

          5.4 使用SQL_BIG_RESULT优化

          如果数据量实在太大怎么办呢?总不能无限调大tmp_table_size吧?但也不能眼睁睁看着数据先放到内存临时表,随着数据插入发现到达上限,再转成磁盘临时表吧?这样就有点不智能啦。

          因此,如果预估数据量比较大,我们使用SQL_BIG_RESULT 这个提示直接用磁盘临时表。MySQl优化器发现,磁盘临时表是B+树存储,存储效率不如数组来得高。因此会直接用数组来存

          示例SQl如下:

          select SQL_BIG_RESULT city ,count(*) as num from staff group by city;
          로그인 후 복사

          执行计划的Extra字段可以看到,执行没有再使用临时表,而是只有排序

          1MySql에서 그룹화를 사용하는 방법에 대해 자세히 알아보세요. (자세한 사용법 설명)

          执行流程如下:

          • 初始化 sort_buffer,放入city字段;

          • 扫描表staff,依次取出city的值,存入 sort_buffer 中;

          • 扫描完成后,对 sort_buffer的city字段做排序

          • 排序完成后,就得到了一个有序数组。

          • 根据有序数组,统计每个值出现的次数。

          6. 一个生产慢SQL如何优化

          最近遇到个生产慢SQL,跟group by相关的,给大家看下怎么优化哈。

          表结构如下:

          CREATE TABLE `staff` (
            `id` bigint(11) NOT NULL AUTO_INCREMENT COMMENT &#39;主键id&#39;,
            `id_card` varchar(20) NOT NULL COMMENT &#39;身份证号码&#39;,
            `name` varchar(64) NOT NULL COMMENT &#39;姓名&#39;,
            `status` varchar(64) NOT NULL COMMENT &#39;Y-已激活 I-初始化 D-已删除 R-审核中&#39;,
            `age` int(4) NOT NULL COMMENT &#39;年龄&#39;,
            `city` varchar(64) NOT NULL COMMENT &#39;城市&#39;,
            `enterprise_no` varchar(64) NOT NULL COMMENT &#39;企业号&#39;,
            `legal_cert_no` varchar(64) NOT NULL COMMENT &#39;法人号码&#39;,
            PRIMARY KEY (`id`)
          ) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT=&#39;员工表&#39;;
          로그인 후 복사

          查询的SQL是这样的:

          select * from t1 where status = #{status} group by #{legal_cert_no}
          로그인 후 복사

          我们先不去探讨这个SQL的=是否合理。如果就是这么个SQL,你会怎么优化呢?有想法的小伙伴可以留言讨论哈,也可以加我微信加群探讨。如果你觉得文章那里写得不对,也可以提出来哈,一起进步,加油呀

          更多编程相关知识,请访问:编程入门!!

          위 내용은 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 옷 제거제

    AI Hentai Generator

    AI Hentai Generator

    AI Hentai를 무료로 생성하십시오.

    인기 기사

    R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 최고의 그래픽 설정
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. 채팅 명령 및 사용 방법
    1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

    뜨거운 도구

    메모장++7.3.1

    메모장++7.3.1

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

    SublimeText3 중국어 버전

    SublimeText3 중국어 버전

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

    스튜디오 13.0.1 보내기

    스튜디오 13.0.1 보내기

    강력한 PHP 통합 개발 환경

    드림위버 CS6

    드림위버 CS6

    시각적 웹 개발 도구

    SublimeText3 Mac 버전

    SublimeText3 Mac 버전

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

    MySQL : 쉽게 학습하기위한 간단한 개념 MySQL : 쉽게 학습하기위한 간단한 개념 Apr 10, 2025 am 09:29 AM

    MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) 데이터베이스 및 테이블 작성 : CreateAbase 및 CreateTable 명령을 사용하십시오. 2) 기본 작업 : 삽입, 업데이트, 삭제 및 선택. 3) 고급 운영 : 가입, 하위 쿼리 및 거래 처리. 4) 디버깅 기술 : 확인, 데이터 유형 및 권한을 확인하십시오. 5) 최적화 제안 : 인덱스 사용, 선택을 피하고 거래를 사용하십시오.

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

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

    Navicat Premium을 만드는 방법 Navicat Premium을 만드는 방법 Apr 09, 2025 am 07:09 AM

    Navicat Premium을 사용하여 데이터베이스 생성 : 데이터베이스 서버에 연결하고 연결 매개 변수를 입력하십시오. 서버를 마우스 오른쪽 버튼으로 클릭하고 데이터베이스 생성을 선택하십시오. 새 데이터베이스의 이름과 지정된 문자 세트 및 Collation의 이름을 입력하십시오. 새 데이터베이스에 연결하고 객체 브라우저에서 테이블을 만듭니다. 테이블을 마우스 오른쪽 버튼으로 클릭하고 데이터 삽입을 선택하여 데이터를 삽입하십시오.

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

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

    Navicat에서 MySQL에 새로운 연결을 만드는 방법 Navicat에서 MySQL에 새로운 연결을 만드는 방법 Apr 09, 2025 am 07:21 AM

    응용 프로그램을 열고 새로운 연결 (Ctrl n)을 선택하여 Navicat에서 새로운 MySQL 연결을 만들 수 있습니다. "MySQL"을 연결 유형으로 선택하십시오. 호스트 이름/IP 주소, 포트, 사용자 이름 및 비밀번호를 입력하십시오. (선택 사항) 고급 옵션을 구성합니다. 연결을 저장하고 연결 이름을 입력하십시오.

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

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

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

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

    SQL이 행을 삭제 한 후 데이터를 복구하는 방법 SQL이 행을 삭제 한 후 데이터를 복구하는 방법 Apr 09, 2025 pm 12:21 PM

    백업 또는 트랜잭션 롤백 메커니즘이없는 한 데이터베이스에서 직접 삭제 된 행 복구는 일반적으로 불가능합니다. 키 포인트 : 거래 롤백 : 트랜잭션이 데이터를 복구하기 전에 롤백을 실행합니다. 백업 : 데이터베이스의 일반 백업을 사용하여 데이터를 신속하게 복원 할 수 있습니다. 데이터베이스 스냅 샷 : 데이터베이스의 읽기 전용 사본을 작성하고 데이터를 실수로 삭제 한 후 데이터를 복원 할 수 있습니다. 주의해서 삭제 명령문을 사용하십시오. 실수로 데이터를 삭제하지 않도록 조건을주의 깊게 점검하십시오. WHERE 절을 사용하십시오 : 삭제할 데이터를 명시 적으로 지정하십시오. 테스트 환경 사용 : 삭제 작업을 수행하기 전에 테스트하십시오.

    See all articles