0

0

mysql进阶1_MySQL

php中文网

php中文网

发布时间:2016-06-01 13:13:08

|

1120人浏览过

|

来源于php中文网

原创

在我们用php处理数据的时候总会遇到些比较麻烦的事情,比如:两个二维数组,一个装的是文章分类表内容,一个装的是文章列表,有关联字段,完全等值,要求在列表文章的时候同时能在标题的前面显示栏目名称,此时循环文章列表,在循环中再次循环栏目列表,对比关联字段,相同的就是这篇文章所在的栏目了,取其名称显示,这是php的做法,如果文章比较多,或者栏目较多,比如100篇文章有100个栏目,循环的数量将是一万次,这个时候呢其实可以用mysql自己进行计算的,这种做法是双表联查,基本语法如下:

Select表1.字段,表2.字段 from 表1,表2 where 表1.关联字段=表2.关联字段,做个测试自行建如下表:

栏目表结构menu

tid int(10)

name varchar(32)

 

文章表结构article

wid int(10)

tid int(10)

title varchar(100)

content text

执行下面语句:

 SELECT `menu`.`name`, `article`.`id`,`article`.`title` 

FROM `article`,`menu` 

WHERE `article`.`tid` = `menu`.`tid`

 

我只显示了栏目名称,文章的ID 和 标题 ,如果是取这个结果输出的话。。那就省事了。一次循环就可以了。

结果如上图。

在php运算量大的时候把一些运算交给mysql处理会大大减少php的工作量,数据量大的时候mysql会明显快点的,除了双表联查,mysql还提供了另外的一种做法叫做对照查询,语法如下:

SELECT 表1.字段, 表2字段

FROM 表1

LEFT JOIN 表2 ON 表1.关联字段 = 表2.关联字段

在此使用了

LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。

在此使用的原理和上面的完全不同

原理是:对照查询,是以其中一表为基准。若是right则是表2为基准

而双表联查:则是按两张表的数据能关联上的时候。才视为符合查询条件。

如果用 inner join 那和双表联查的结果基本上一致了。

如果我们做的一个商城运营到一段时间后老板想知道有多少实际交易及每个用户的交易额,知道产生多少交易select count(*) from 表名但是知道多少个用户交易过,就不好算了,每个用户又分别交易多少笔呢,这个时候可以使用分组功能,关键字为group by拿之前的表测试下我们想知道每个栏目下分别有多少篇文章相当于每个用户分别产生了多少笔交易,

select `tid`,count(*) from `article` GROUP BY `tid`

分组查询,相当于把数据库中的指定字段,相同的数据叠在一起。 这个时候使用 count 的话,返回的不是一共有多少组。而是每一组有多少条数据。

如果我们手上有几篇文章的 id,如果我们手上有几篇文章的 id,比如,我们现在手上有 3 6 9 三个 id

按刚才的文章表。应该怎么查呢。 才能让它们出现在一个结果里。

估计有人会想到这个吧

select * from `article` where `wid`=3 or `wid`=6 or `wid` = 9

如果是这样的话,又会存在一个新的问题,对于 PHP 来说,要写很多 or  这个时候用in再合适不过,

点卡销卡源码
点卡销卡源码

点卡销卡源码是一个以php+MySQL进行开发的点卡回收平台源码。软件必须使用宝塔面板进行搭建,否则有可能会出现无法安装的问题。

下载

in 语法格式

SELECT column_name(s)
FROM table_name
WHERE column_name IN (value1,value2,...)

如果要查的值不是很多的话,用这种方式,是很省事的。如果你要查的值,数据是成千上万级的。那就是另一回事。。子查询。

我先来做个假设,如果我们手上有几千个会员,我只想看前20个人的交易记录。此时可以用对照查询,

我们查询用户表的语句大概会是这样子。

select * from `user`where `vip` = 1

比如交易表名叫 shop 购物表,两张表都有 username 字段对应。 我们就可以用子查询。把第一个查询结果假设为一张表, 假定为表  vip

如果用刚才的对照查询。语法会是这样

select *     //返回所有字段

from `shop`  //从交易表查

right join `vip`  //以右边,也就是 VIP表为准

on `vip`.`username` = `shop`.`username`因为只要 vip 用户的交易记录。所以,左表 shop 的数据,有些是不要的。当然是以右表为准。

select * from `user`where `vip` = 1

 

右表是这条语句的查询结果

select * 

from `shop`

right join 

  (select * from `user` where `vip` = 1) as `vip`

on `vip`.`username` = `shop`.`username`

(select * from `user` where `vip` = 1) as `vip`

把这条语句的查询结果,视为一张表,临时命名为 vip

这样一来,从 shop 表查到的交易记录。都会以 vip 这张“虚拟表”为准,选择性输出。

得到的结果,当然也就是所有 VIP 用户的交易记录了,这就是所谓的子查询,在一条查询语句里面,还有另一条查询语句。当然,还有另外一种写法也可以做到,不用对照查询。

先准备好我们的子查询语句。所有 VIP 的用户名。

select `username` from `user` where `vip` = 1

 

select * from `shop` where `username` = '一个用户名' 这条语句,可以从交易表里,得到一个用户的所有交易记录, 如果两条语句合并起来呢。

select * from `shop` where `username` = (select `username` from `user` where `vip` = 1)

这是子查询的另一种用法。

这种做法,子查询返回的结果,必须只有一个字段。

select * from `article` 

where `tid` in 

  (select `tid` from `menu` where `tid` > 1) 

在数据量大的时候。。适当的选择这些“有点复杂”的 SQL 语句,让处理数据“更专业”的数据库把结果算好给我们。往往可以达到事半功倍的效果。 

抱怨一句 想当好一个合格的程序员再怎么努力也不为过。。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

39

2026.02.06

java多线程方法汇总
java多线程方法汇总

本专题整合了java多线程面试题、实现函数、执行并发相关内容,阅读专题下面的文章了解更多详细内容。

17

2026.02.06

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

289

2026.02.06

快手网页版入口与电脑端使用指南 快手官方短视频观看入口
快手网页版入口与电脑端使用指南 快手官方短视频观看入口

本专题汇总了快手网页版的最新入口地址和电脑版使用方法,详细提供快手官网直接访问链接、网页端操作教程,以及如何无需下载安装直接观看短视频的方式,帮助用户轻松浏览和观看快手短视频内容。

150

2026.02.06

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

11

2026.02.06

Python 微服务架构与 FastAPI 框架
Python 微服务架构与 FastAPI 框架

本专题系统讲解 Python 微服务架构设计与 FastAPI 框架应用,涵盖 FastAPI 的快速开发、路由与依赖注入、数据模型验证、API 文档自动生成、OAuth2 与 JWT 身份验证、异步支持、部署与扩展等。通过实际案例,帮助学习者掌握 使用 FastAPI 构建高效、可扩展的微服务应用,提高服务响应速度与系统可维护性。

7

2026.02.06

JavaScript 异步编程与事件驱动架构
JavaScript 异步编程与事件驱动架构

本专题深入讲解 JavaScript 异步编程与事件驱动架构,涵盖 Promise、async/await、事件循环机制、回调函数、任务队列与微任务队列、以及如何设计高效的异步应用架构。通过多个实际示例,帮助开发者掌握 如何处理复杂异步操作,并利用事件驱动设计模式构建高效、响应式应用。

11

2026.02.06

java连接字符串方法汇总
java连接字符串方法汇总

本专题整合了java连接字符串教程合集,阅读专题下面的文章了解更多详细操作。

47

2026.02.05

java中fail含义
java中fail含义

本专题整合了java中fail的含义、作用相关内容,阅读专题下面的文章了解更多详细内容。

29

2026.02.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.1万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 823人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号