찾다
데이터 베이스MySQL 튜토리얼MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?

Mysql on, in, as, where의 차이점

답변: Where 쿼리 조건은 내부 및 외부 연결 시 on을 별칭으로 사용하여 특정 값이 특정 조건에 있는지 쿼리합니다

2 생성 테이블: 학생, 점수

학생:

MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?

점수:

MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?

where

SELECT * FROM student WHERE s_sex='男'

MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?

예: 켜기

SELECT * FROM student LEFT JOIN score on student.s_id=score.s_id;

MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?

on 및 where 조합 :

SELECT * FROM student LEFT JOIN score on student.s_id=score.s_id WHERE s_name='赵雷'

MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?

예: in

SELECT * FROM score WHERE s_id in (SELECT s_id FROM student WHERE s_name='赵雷')

MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?

as

select * from score as a LEFT JOIN student as b on a.s_id=b.s_id where s_name='赵雷'

MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?

Mysql 문 문제 해결

1. 왼쪽 조인 데이터 필터링 문제

다음 조건에서만 가능합니다. 왼쪽 조인의 오른쪽에 있는 테이블을 필터링합니다. 왼쪽 테이블이 오른쪽 테이블 데이터와 일치하지 않으면 추가 후 원래 오른쪽 테이블 위치에 null이 표시됩니다. 이후의 조건에 따라 모든 데이터가 필터링됩니다.

2. 동일한 데이터가 반복적으로 필터링되어 사용됩니다.

with <name> as()

as를 사용하여 mysql에서 임시 테이블을 생성할 수 있습니다. 예제에 따르면 실행 시간은 더 이상 존재하지 않습니다. 기사 테이블이지만 테이블의 모든 데이터가 필요한 것은 아닙니다. 따라서 먼저 임시 테이블 arc를 필터링하고 생성한 다음 arc를 작동하겠습니다.

위 예제의 단순한 연산이라면 with...as를 사용할 필요는 없지만, 기사 테이블을 다른 테이블과 공동으로 쿼리하거나 심지어 중첩해야 하는 경우 is_del = 0으로 판단됩니다. 최종 SQL 문은 매우 복잡하고 오류가 발생하기 쉬울 수 있지만 arc를 사용하면 데이터를 반복적으로 필터링할 필요가 없습니다.

with...as의 SQL은 더 복잡할 수 있습니다. 예를 들어 기사 테이블에 name_id가 있지만 더 자주 name을 사용하여 검색할 수 있습니다. 이를 수행하려면 임시 테이블을 사용하십시오.

3. 특정 필드를 기준으로 정렬하여 마지막 3개 데이터 또는 각 카테고리의 처음 3개 데이터를 가져옵니다.

저는 초보자이고 문제를 해결하는 방법은 한 가지만 알고 있지만 시도해 보겠습니다. 간단하고 대중적인 방식으로 설명하는 것이 최선입니다.

예:

with arc as( 
    select id,arc.title,update_time,is_top,cId,pid,name_id from article arc where is_del = 0 
) 
select * from arc

예에서 cId는 카테고리 ID이고 updateTime은 업데이트 시간입니다. 문제에 대한 해결책은 뉴스 홈페이지에서 요구하는 것처럼 arc의 각 카테고리에 대한 최신 세 가지 데이터를 선택하는 것입니다. 세 가지 뉴스에 대해 데이터베이스의 데이터에 따라 order by cId, updateTime desc를 사용하여 카테고리 및 업데이트 시간별로 데이터를 정렬할 수 있습니다. 기존 데이터베이스의 각 카테고리에 대한 데이터를 저장하므로 임시 필드를 추가할 수 있습니다.

updateTimeSort 이 카테고리의 각 카테고리에 있는 각 하위 항목의 정렬을 나타냅니다. 현재 문제에서 이 임시 필드는 업데이트 시간에 따라 카테고리의 각 하위 항목을 정렬하는 updateTime 필드와 관련되어야 합니다.

샘플 코드에서 볼 수 있듯이 두 테이블 a1과 a2는 모두 arc 테이블의 별칭이며 a2를 기본 쿼리로 결합합니다. a2의 현재 데이터와 동일한 카테고리를 찾으려면 테이블에서 업데이트 시간이 a2의 현재 데이터에 있는 데이터 수보다 늦으면 count(*)+1을 볼 수 있습니다. 데이터가 속한 카테고리에서 최신 업데이트 시간이 있는 경우에는 하나를 추가하지 않아도 됩니다. count(*)의 값은 0입니다. count(*)+1을 사용하면 1부터 데이터를 정렬할 수 있습니다.

결국 updateTimeSort

a1에서 updateTimeSort의 필터링 논리만 변경하면 됩니다. updateTime > a2 .updateTime은 a1.updateTime

으로 변경되었습니다. 샘플 코드에는 실제로 임시 테이블인 또 다른 테이블 a3이 있음을 알 수 있습니다. 임시 테이블이므로 이번에도 반복해 보겠습니다. 코드에서 볼 수 있듯이 임시 테이블은 다른 형태로도 존재할 수 있습니다. 일반적으로 SQL이 복잡할 때만 사용하므로 이 방법을 사용하면 문제를 해결할 수 있습니다. 현재 많은 문제가 있으며 각각 고유한 문제가 있습니다. 장단점은 상황에 따라 다릅니다.

4、业务逻辑书写位置问题

接触sql多了会发现,sql其实能帮我们解决一定的业务问题,明显的有sql的存储过程和方法,对sql语句的批量处理其实在一定程度上帮我们解决一定的业务问题,但缺点也很明显,当新手接触这个项目时他很难搞清楚某个功能到底是如何实现的,不利于维护。

一般来说我们解决业务是在server层,有时会使用sql解决一些问题,但很少,在sever处理受制于计算机硬件,在数据库处理受制于数据库性能,相比之下,计算机硬件更易于扩展,因此还是不推荐大量使用sql解决问题的。

例如上个问题:根据某个字段排序取每个类别最后三条数据或前三条数据问题,虽然问题基本解决但让存在一些 ‘bug’,例如排序时会产生1、2、3、3、4这种排序,这是因为同个类别内有两条数据更新时间重复了,那我们直观想法(还是要看个人经验值)应该是,既然问题出在数据库,那应该在数据库查询的时候就解决这个问题,但事实上,让数据库去解决并不好解决,数据库的强项在于各种搜索算法,不在于逻辑处理,因此我们就要转移到server层处理,会有不少人陷于这个坑,花费大量时间去找办法让数据库去处理这类问题,但其实就算数据库处理得了,它也不一定有server层处理的效率高,当然如果是为了学习更多东西,这些时间也是值得花的,但是这种解题思路还是要改变下的。将1、2、3、3、4问题交给server处理也就是利用java等高级语言处理这种问题,相信熟用这些语言的开发者解决这些问题都是小case了。

5、查找另一表内和本表相关字段的数量

先复习下知识:用过count函数的人都清楚一旦使用count这类聚合函数,不做其他处理数据就会归为一行数据,但很多时候我们并不期望这样的结果,以此就要想些办法能用聚合函数,也能获取很多数据,我常用的是利用group by分组。

回归问题,现有(现不讨论表是否合理)文章表(id,title,content)有文章id,标题,文章内容三个字段,点赞收藏表(id,arc_id,fav,like)有表id,文章id,收藏字段(0未收藏,1收藏),点赞字段(0未点赞,1点赞),现要查询文章表内每篇文章的点赞收藏数,sql语句:

select art.title,art.content, 
count(case afl.fav when 1 then 1 end) as collectNum, 
count(case afl.like when 1 then 1 end) as likeNum 
from article art 
left join article_favor_like afl on afl.arc_id = art.id 
group by afl.arc_id //这是关键

如果没有group by afl.arc_id 后果就是,查出来一行数据,数据还牛头不对马嘴,但通过对文章收藏表中的文章id进行分组就可以针对每个文章id查询数据,这样left join时右表就有每个文章id对相应的收藏数与点赞数,而不是表内所有点赞数和收藏数,最终数据也是我们所需的。

6、关于union的使用

例子:

select id,title,content,1 isArc from arc 
union 
select id,name,content,0 isArc from news
  • 使用union进行的是上下整合

  • 被联合的数据列数要求一致

  • 列数相同,数据类型不同会自动进行数据类型转换

  • 联合后的列的名字由联合中第一次出现的列名为依据,即使后续被联合数据有自己的列名也不会使用,在例子中最终列名为:id,title,content,name等列名不会使用,因此使用union一般配合别名使用统一结果。

  • 有时候会区分数据是哪个表的,可以通过附加额外的字段来区别,就像例子中的isArc字段,news表中的isArc可以不写,原因也就是第4条,最终列名由第一次出现的列名决定,后续数据列名有没有都可以。

7、limit的巧用

limit一般用于分页,功能是获取指定区间内的数据,因此我们也可以用它来减少数据库的查询,例子:

select * from arc where id = 12 limit 1

数据库查询由索引还好,没有索引是要遍历数据库的,有些数据经由条件筛选在逻辑上应该是唯一的,使用limit 1可以使数据库查询到该数据时不再搜索,减少数据库搜索次数,但这种方法仅是一种技巧,想大幅度优化sql还要另想办法。

8、update ignore和insert ignore的使用

//标题是唯一索引,&#39;新标题&#39;存在则更新操作不执行 
update ignore arc set title = &#39;新标题&#39; 
 
//标题是唯一索引,&#39;标题1号&#39;存在则插入操作不执行 
insert ignore into arc values(null,&#39;标题1号&#39;,&#39;文章内容&#39;)

有这种需求,数据存在时不执行任何操作,不存在则更新或插入,一个办法是使用ingore,它会忽略数据库报错,而数据库执行原子操作时报错是会回滚的,因此只要我们给数据加上主键或唯一索引,当被更新字段或插入字段与原有数据冲突时会报错,但因为ingore会忽视这种报错,后端也就不会报错,sql也未执行,达到了目的,有人会对报错敏感,其实也没什么,报错也是在检查数据是发现不合理之处给的一个提醒或警告,对数据库无害的。

9、mysql存在更新,不存在则插入

区别于上面那个需求,这个是当插入的数据存在时更新数据,不再是不做任何操作,例子:

//本例子中title不是唯一索引,id是主键 
insert into arc values(1,&#39;标题1号&#39;,&#39;文章内容&#39;) 
on duplicate key update title=&#39;标题1号&#39;
//若要更新多个字段使用&#39;,&#39;隔开,例:title=&#39;标题1号&#39;,content=&#39;文章内容&#39;

在例子中,当id为1的数据存在时,更新标题和内容,不存在则插入,如果执行更新操作,未设置新值的字段保持原来的值。

还有一个REPLACE INTO也可以达到这种效果,区别在于,REPLACE INTO更新时是先删除后插入会破坏原有索引,id为3的数据更新时会删除插入id为4的数据,未更新新值的字段设置为默认值或null。

无论是两个中的哪种方式判断数据是否存在的依据都是主键和唯一索引。

위 내용은 MySQL에서 on, in, as 및 where의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
MySQL과 다른 SQL 방언의 구문의 차이점은 무엇입니까?MySQL과 다른 SQL 방언의 구문의 차이점은 무엇입니까?Apr 27, 2025 am 12:26 AM

mysqldiffersfromothersqldialectsinsyntaxforlimit, 자동 점유, 문자열 comparison, 하위 쿼리 및 퍼포먼스 앤 알리 분석 .1) mysqluse Slimit, whilesqlSerVerusestOpandoracleSrownum.2) MySql'Sauto_incrementContrastSwithPostgresql'serialandoracle '

MySQL 파티셔닝이란 무엇입니까?MySQL 파티셔닝이란 무엇입니까?Apr 27, 2025 am 12:23 AM

MySQL 파티셔닝은 성능을 향상시키고 유지 보수를 단순화합니다. 1) 큰 테이블을 특정 기준 (예 : 날짜 범위)으로 작은 조각으로 나누고, 2) 데이터를 독립적 인 파일로 물리적으로 나눌 수 있습니다.

MySQL에서 어떻게 권한을 부여하고 취소합니까?MySQL에서 어떻게 권한을 부여하고 취소합니까?Apr 27, 2025 am 12:21 AM

MySQL에서 권한을 부여하고 취소하는 방법은 무엇입니까? 1. 보조금 명세서를 사용하여 grantallprivilegesondatabase_name.to'username'@'host '와 같은 부여 권한; 2. Revoke 문을 사용하여 Revokeallprivilegesondatabase_name.from'username'@'host '와 같은 권한을 취소하여 허가 변경의 적시에 의사 소통을 보장하십시오.

InnoDB와 MyISAM 스토리지 엔진의 차이점을 설명하십시오.InnoDB와 MyISAM 스토리지 엔진의 차이점을 설명하십시오.Apr 27, 2025 am 12:20 AM

InnoDB는 거래 지원 및 높은 동시성이 필요한 응용 프로그램에 적합한 반면, MyISAM은 더 많은 읽기와 덜 쓰는 응용 프로그램에 적합합니다. 1. INNODB는 전자 상거래 및 은행 시스템에 적합한 거래 및 은행 수준의 자물쇠를 지원합니다. 2. Myisam은 블로깅 및 컨텐츠 관리 시스템에 적합한 빠른 읽기 및 색인을 제공합니다.

MySQL의 다른 유형의 조인은 무엇입니까?MySQL의 다른 유형의 조인은 무엇입니까?Apr 27, 2025 am 12:13 AM

MySQL에는 Innerjoin, Leftjoin, RightJoin 및 FullouterJoin의 네 가지 주요 조인 유형이 있습니다. 1. 결합 조건을 충족하는 두 테이블의 모든 행을 반환합니다. 2. Leftjoin 오른쪽 테이블에 일치하는 행이 없더라도 왼쪽 테이블의 모든 행을 반환합니다. 3. RightJoin은 LeftJoin과 상반되며 오른쪽 테이블의 모든 행을 반환합니다. 4. FULLOUTERNOIN은 조건을 충족 시키거나 충족하지 않는 두 테이블의 모든 행을 반환합니다.

MySQL에서 사용 가능한 다른 스토리지 엔진은 무엇입니까?MySQL에서 사용 가능한 다른 스토리지 엔진은 무엇입니까?Apr 26, 2025 am 12:27 AM

mysqloffersvariousStorageEngines, 각각의 everitedforentUsecases : 1) innodbisidealforapplicationsneedingAcidCoInceandHighConcurrency, 지원 트랜잭션 및 foreignKeys.2) myIsAmisbestforread-heverworkloads, memoryengineis

MySQL의 일반적인 보안 취약점은 무엇입니까?MySQL의 일반적인 보안 취약점은 무엇입니까?Apr 26, 2025 am 12:27 AM

MySQL의 일반적인 보안 취약점에는 SQL 주입, 약한 암호, 부적절한 권한 구성 및 업데이트되지 않은 소프트웨어가 포함됩니다. 1. 전처리 명령문을 사용하여 SQL 주입을 방지 할 수 있습니다. 2. 강력한 비밀번호 전략을 사용하여 약한 암호는 피할 수 있습니다. 3. 정기적 인 검토 및 사용자 권한 조정을 통해 부적절한 권한 구성을 해결할 수 있습니다. 4. Unupdated 소프트웨어는 MySQL 버전을 정기적으로 확인하고 업데이트하여 패치 할 수 있습니다.

MySQL에서 느린 쿼리를 어떻게 식별 할 수 있습니까?MySQL에서 느린 쿼리를 어떻게 식별 할 수 있습니까?Apr 26, 2025 am 12:15 AM

느린 쿼리 로그를 활성화하고 임계 값을 설정하여 MySQL에서 느린 쿼리를 식별 할 수 있습니다. 1. 느린 쿼리 로그를 활성화하고 임계 값을 설정하십시오. 2. 느린 쿼리 로그 파일을보고 분석하고 심층 분석을 위해 MySQLDumpSlow 또는 PT-Query 소수성과 같은 도구를 사용하십시오. 3. 인덱스 최적화, 쿼리 재 작성 및 select*의 사용을 피함으로써 느린 쿼리 최적화를 달성 할 수 있습니다.

See all articles

핫 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기