mysql查询语句(mysql学习笔记七)_MySQL
bitsCN.com
Sql语句
一般顺序GHOL : group by,having ,order by,limit
如果是分组,应该使用对分组字段进行排序的group by语法
Limit start ,length
去除重复记录默认为all
Select distinct 字段 from
Select distinct * from 没用(所有字段组合不相同才认为不相同,用在这里基本没用),记录值完全一样时取其一个
Union查询
把两个select 结果union起来
( select 语句1)union(select 语句2)
选出英语最高分和数学最高分的学生的id,name ,class
注意加括号
有重复记录时的合并
按english由高到低和由低到高的结果合并
在符合语句中 order by功能受影响,需加上limit
子语句的排序
1.将子语句包裹在子括号内
2.子语句的 order by
中有order by配合Limit使用时才生效。
原因是:union在做子语句时,会对没有limit的order by优化(忽略)
所有结果排序
只需要在最后一个select语句后增加相应排序即可。
子语句括号非必须最后一个排序默认针对所有结果。
Union检索的字段必须个数一样(否者出错),数据类型也一样(发生类型转换) 列名由第一个select检索列名来定
子查询
语句内部的查询语句
表中数据
查出英语成绩最高的学生的信息
不用子查询:
但有2个学生英语成绩最高且一致,这个时候在不知道表里数据的情况下就不能使用这种查询方法
思路:先找出英语成绩最大的那个值,再找出哪些学生的英语成绩与这个最大的值相等。这样一步一步进行查询。
只检索一个字段时可以作为一个值使用,必须只检索一个字段
子查询分类
不同的分类会有不同的使用方式
分类标准:
子查询出现的位置
子查询的返回值形式
返回值分类:
单一值,单列,多列,多行多列(表)
出现位置:
Where 型,where 后
From型 from后
Exists型
使用:
标量的:获得一个值后用关系运算符进行运算(> >=, )
列子查询(只是1列):获得一列通常是对个行的一列值(一个集合)
使用in,not in运算符
查出班级为php101中所有学生的信息
集合操作符还有
Any(集合) 集合中的任意一个
=any(集合) 等于集合中的任意一个即可
等同于in
=All(集合) 集合中的所有元素
!=all(集合) 不等于集合中的所有元素等同于Not in
!=any(集合) 不等于集合中的任意一个元素成立即可,即为只要不等于其中的一个元素即为成立的。
注意:这种语法不该出现在实际开发中
Some(集合) 集合中的一些
语法上与any一样
总结:
=any 等同于in
!=all 等同于 not in
Some 和any同义
All,any ,some可以使用除了=,!=之外运算符,比in强大
返回一行
在参与比较时,使用括号可以构建一行
(field1,field2,…)
表中数据
现在要查询出和贺8在同样的班级且与他math成绩一样的同学的信息
子查询
返回一个表
如果用在from子句内,要求要是一个表
现在是查询结果,必须给这个查询结果起别名
表中数据
查询php103班 english不及格的学生信息
必须有别名
Exists
如果子查询可以返回数据则返回真,否者返回假
有以下2表
A表
B表
在a中查询出id在 b中有的记录
先获取a表的第一行记录,在子查询中判断a表的id与b表的id比较
连接查询
Join
每个实体,一个表
一个业务逻辑,使用多个实体的数据
多张表应该在一起使用,将多个表的记录连接起来
Teacher表
Teacher_class1表
查出代课老师的代课信息
笛卡尔(交叉)连接
内连接处理
在连接时,是可以省略连接条件的。意味着,所有的左表数据,都要与右表的记录做一个连接
共存在m*n个连接
称之为交叉连接或笛卡尔集
此时可以使用 cross join代替inner join
Mysql中cross join与inner join相同
Inner join是默认的连接方式(inner 省略)
等效的
也可使用
表示笛卡尔积
结果虽然一样
On数据连接条件
Where数据过滤条件
但 where是先连接成笛卡尔积
然后做筛选,而on 是在连接时就判断
上表是连接条件2个
下表是
过滤条件2个
下表连接过滤各一个
Using:要求负责连接的两个实体之间字段名称一致。
查询条件与外连接通用 外连接不能用where作为连接条件。
注意:
无论是连接条件还是连接查询多字段列表,都没必要一定要写表名.字段语法,是否写取决于是否发生冲突。建议写上。
别名
表应该别名,保证简洁清晰。
列别名
外连接:
分类
左外连接
右外连接
全外连接(暂不支持)
左连接
在连接时,如果出现左边表,数据连接不到右边表的情况,则左表的数据在最终结果内保留。而如果出现右表的数据连接不到左标的情况,右表数据被丢弃。
由于内连接没有左右连接之分,left outer join中outer可以省略。
在外连接中不可以用where做连接条件可用on ,using
表别名可以用在连接条件里,但字段别名不可以。
表起别名后,在筛选或者连接条件里必须用别名,原名不能用了
左表teacher里的数据孙武连接不上也保留。
全外连接左外与右外 union(取并集)
内连接是左外右外交集
Using会去掉结果中重复字段,并放在列首
外连接不能使用没有条件的连接(不像内连接那样形成笛卡尔积)
自然连接
通过mysql自己判断完成连接过程。不需要指定连接条件,mysql会使用多表内相同的字段作为连接条件。
表one数据
Two表数据
自然连接也有内外之分
内:natural join
外:左外natural left join ,右外 natural right join

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











빅 데이터 구조 처리 기술: 청킹(Chunking): 데이터 세트를 분할하고 청크로 처리하여 메모리 소비를 줄입니다. 생성기: 전체 데이터 세트를 로드하지 않고 데이터 항목을 하나씩 생성하므로 무제한 데이터 세트에 적합합니다. 스트리밍: 파일을 읽거나 결과를 한 줄씩 쿼리하므로 대용량 파일이나 원격 데이터에 적합합니다. 외부 저장소: 매우 큰 데이터 세트의 경우 데이터를 데이터베이스 또는 NoSQL에 저장합니다.

선형 복잡성에서 로그 복잡성까지 조회 시간을 줄이는 인덱스를 구축하여 MySQL 쿼리 성능을 최적화할 수 있습니다. SQL 삽입을 방지하고 쿼리 성능을 향상하려면 PREPAREDStatements를 사용하세요. 쿼리 결과를 제한하고 서버에서 처리되는 데이터의 양을 줄입니다. 적절한 조인 유형 사용, 인덱스 생성, 하위 쿼리 사용 고려 등 조인 쿼리를 최적화합니다. 쿼리를 분석하여 병목 현상을 식별하고, 캐싱을 사용하여 데이터베이스 로드를 줄이고, 오버헤드를 최소화합니다.

PHP에서 MySQL 데이터베이스를 백업하고 복원하는 작업은 다음 단계에 따라 수행할 수 있습니다. 데이터베이스 백업: mysqldump 명령을 사용하여 데이터베이스를 SQL 파일로 덤프합니다. 데이터베이스 복원: mysql 명령을 사용하여 SQL 파일에서 데이터베이스를 복원합니다.

MySQL 테이블에 데이터를 삽입하는 방법은 무엇입니까? 데이터베이스에 연결: mysqli를 사용하여 데이터베이스에 대한 연결을 설정합니다. SQL 쿼리 준비: 삽입할 열과 값을 지정하는 INSERT 문을 작성합니다. 쿼리 실행: query() 메서드를 사용하여 삽입 쿼리를 실행하면 확인 메시지가 출력됩니다.

MySQL 8.4(2024년 최신 LTS 릴리스)에 도입된 주요 변경 사항 중 하나는 "MySQL 기본 비밀번호" 플러그인이 더 이상 기본적으로 활성화되지 않는다는 것입니다. 또한 MySQL 9.0에서는 이 플러그인을 완전히 제거합니다. 이 변경 사항은 PHP 및 기타 앱에 영향을 미칩니다.

PHP에서 MySQL 저장 프로시저를 사용하려면: PDO 또는 MySQLi 확장을 사용하여 MySQL 데이터베이스에 연결합니다. 저장 프로시저를 호출하는 문을 준비합니다. 저장 프로시저를 실행합니다. 결과 집합을 처리합니다(저장 프로시저가 결과를 반환하는 경우). 데이터베이스 연결을 닫습니다.

PHP를 사용하여 MySQL 테이블을 생성하려면 다음 단계가 필요합니다. 데이터베이스에 연결합니다. 데이터베이스가 없으면 작성하십시오. 데이터베이스를 선택합니다. 테이블을 생성합니다. 쿼리를 실행합니다. 연결을 닫습니다.

Oracle 데이터베이스와 MySQL은 모두 관계형 모델을 기반으로 하는 데이터베이스이지만 호환성, 확장성, 데이터 유형 및 보안 측면에서 Oracle이 우수하고, MySQL은 속도와 유연성에 중점을 두고 중소 규모 데이터 세트에 더 적합합니다. ① Oracle은 광범위한 데이터 유형을 제공하고, ② 고급 보안 기능을 제공하고, ③ 엔터프라이즈급 애플리케이션에 적합하고, ① MySQL은 NoSQL 데이터 유형을 지원하고, ② 보안 조치가 적고, ③ 중소 규모 애플리케이션에 적합합니다.
