首页 数据库 mysql教程 图解MySQL数据库安装与实际操作

图解MySQL数据库安装与实际操作

Jun 07, 2016 pm 04:13 PM
mysql 主要 图解 安装 数据库

本文主要讲述的是图解MySQL数据库安装与实际操作的介绍, 你是否对获得图解MySQL数据库安装与实际实际操作感到十分头疼?如果是这样子的话,以下的文章将会给你相应的解决方案。 1.图解MySQL数据库安装和操作:初始的数据库 (和PHP搭配之最佳组合)数据库的安

本文主要讲述的是图解MySQL数据库安装与实际操作的介绍, 你是否对获得图解MySQL数据库安装与实际实际操作感到十分头疼?如果是这样子的话,以下的文章将会给你相应的解决方案。

1.图解MySQL数据库安装和操作:初始的数据库

(和PHP搭配之最佳组合)数据库的安装和操作

width="505" height="420" />

b.直接表示:select name '姓名' from students order by age

2.精确查找:

a.用in限定范围:select * from students where native in ('湖南', '四川')

b.between...and:select * from students where age between 20 and 30

c.“=”:select * from students where name = '李山'

d.like:select * from students where name like '李%' (注意查询条件中有“%”,则说明是部分匹配,而且还有先后信息在里面,即查找以“李”开头的匹配项。所以若查询有“李”的所有对象,应该命令:'%李%';若是第二个字为李,则应为'_李%'或'_李'或'_李_'。)

e.[]匹配检查符:select * from courses where cno like '[AC]%' (表示或的关系,与"in(...)"类似,而且"[]"可以表示范围,如:select * from courses where cno like '[A-C]%')

3.对于时间类型变量的处理

a.smalldatetime:直接按照字符串处理的方式进行处理,例如:

select * from students where birth > = '1980-1-1' and birth

4.图解MySQL数据库安装和操作.集函数

a.count()求和,如:select count(*) from students (求学生总人数)

b.avg(列)求平均,如:select avg(mark) from grades where cno=’B2’

c.max(列)和min(列),求最大与最小

5.分组group

常用于统计时,如分组查总数:

<ol class="dp-xml">
<li class="alt"><span><span>select gender,count(sno)   </span></span></li>
<li><span>from students  </span></li>
<li class="alt"><span>group by gender </span></li>
</ol>
登录后复制

(查看男女学生各有多少)

注意:从哪种角度分组就从哪列"group by"

对于多重分组,只需将分组规则罗列。比如查询各届各专业的男女同学人数 ,那么分组规则有:届别(grade)、专业(mno)和性别(gender),所以有"group by grade, mno, gender"

<ol class="dp-xml">
<li class="alt"><span><span>select grade, mno, gender, count(*)  </span></span></li>
<li><span>from students  </span></li>
<li class="alt"><span>group by grade, mno, gender </span></li>
</ol>
登录后复制

通常group还和having联用,比如查询1门课以上不及格的学生,则按学号(sno)分类有:

<ol class="dp-xml">
<li class="alt"><span><span>select sno,count(*) from grades   </span></span></li>
<li>
<span>where mark</span><span class="tag"><span class="tag-name">60</span><span> </span></span>
</li>
<li class="alt"><span>group by sno  </span></li>
<li>
<span>having count(*)</span><span class="tag">></span><span>1  </span>
</li>
</ol>
登录后复制

6.UNION联合

合并查询结果,如:

<ol class="dp-xml">
<li class="alt"><span><span>SELECT * FROM students  </span></span></li>
<li><span>WHERE name like ‘张%’  </span></li>
<li class="alt"><span>UNION [ALL]  </span></li>
<li><span>SELECT * FROM students  </span></li>
<li class="alt"><span>WHERE name like ‘李%’ </span></li>
</ol>
登录后复制

7.图解MySQL数据库安装和操作.多表查询

a.内连接

<ol class="dp-xml">
<li class="alt"><span><span>select g.sno,s.name,c.coursename   </span></span></li>
<li>
<span>from grades g JOIN students s ON </span><span class="attribute">g.sno</span><span>=s.sno  </span>
</li>
<li class="alt">
<span>JOIN courses c ON </span><span class="attribute">g.cno</span><span>=c.cno </span>
</li>
</ol>
登录后复制

(注意可以引用别名)

b.外连接

b1.左连接

<ol class="dp-xml">
<li class="alt"><span><span>select courses.cno,max(coursename),count(sno)   </span></span></li>
<li>
<span>from courses LEFT JOIN grades ON </span><span class="attribute">courses.cno</span><span>=</span><span class="attribute-value">grades</span><span>.cno   </span>
</li>
<li class="alt"><span>group by courses.cno </span></li>
</ol>
登录后复制

左连接特点:显示全部左边表中的所有项目,即使其中有些项中的数据未填写完全。

左外连接返回那些存在于左表而右表中却没有的行,再加上内连接的行。

b2.右连接

与左连接类似

b3.全连接

<ol class="dp-xml">
<li class="alt"><span><span>select sno,name,major   </span></span></li>
<li>
<span>from students FULL JOIN majors ON </span><span class="attribute">students.mno</span><span>=</span><span class="attribute-value">majors</span><span>.mno </span>
</li>
</ol>
登录后复制

两边表中的内容全部显示

c.自身连接

<ol class="dp-xml">
<li class="alt"><span><span>select c1.cno,c1.coursename,c1.pno,c2.coursename   </span></span></li>
<li>
<span>from courses c1,courses c2 where </span><span class="attribute">c1.pno</span><span>=</span><span class="attribute-value">c2</span><span>.cno </span>
</li>
</ol>
登录后复制

采用别名解决问题。

d.交叉连接

<ol class="dp-xml"><li class="alt"><span><span>select lastname+firstname from lastname CROSS JOIN firstanme </span></span></li></ol>
登录后复制

相当于做笛卡儿积

8.嵌套查询

a.用关键字IN,如查询李山的同乡:

<ol class="dp-xml">
<li class="alt"><span><span>select * from students  </span></span></li>
<li>
<span>where native in (select native from students where </span><span class="attribute">name</span><span>=’ 李山’)  </span>
</li>
</ol>
登录后复制

b.使用关键字EXIST,比如,下面两句是等价的:

<ol class="dp-xml">
<li class="alt"><span><span>select * from students  </span></span></li>
<li>
<span>where sno in (select sno from grades where </span><span class="attribute">cno</span><span>=’B2’)  </span>
</li>
<li class="alt"><span>select * from students where exists   </span></li>
<li><span>(select * from grades where   </span></li>
<li class="alt">
<span class="attribute">grades.sno</span><span>=</span><span class="attribute-value">students</span><span>.sno AND </span><span class="attribute">cno</span><span>=’B2’)  </span>
</li>
</ol>
登录后复制

9.关于排序order

a.对于排序order,有两种方法:asc升序和desc降序

b.对于排序order,可以按照查询条件中的某项排列,而且这项可用数字表示,如:

<ol class="dp-xml">
<li class="alt"><span><span>select sno,count(*) ,avg(mark) from grades   </span></span></li>
<li><span>group by sno  </span></li>
<li class="alt">
<span>having avg(mark)</span><span class="tag">></span><span>85  </span>
</li>
<li><span>order by 3  </span></li>
</ol>
登录后复制

10.图解MySQL数据库安装和操作.其他

a.对于有空格的识别名称,应该用"[]"括住。

b.对于某列中没有数据的特定查询可以用null判断,如select sno,courseno from grades where mark IS NULL

c.注意区分在嵌套查询中使用的any与all的区别,any相当于逻辑运算“||”而all则相当于逻辑运算“&&”

d.注意在做否定意义的查询是小心进入陷阱:

如,没有选修‘B2’课程的学生 :

<ol class="dp-xml">
<li class="alt"><span><span>select students.*  </span></span></li>
<li><span>from students, grades  </span></li>
<li class="alt">
<span>where </span><span class="attribute">students.sno</span><span>=</span><span class="attribute-value">grades</span><span>.sno  </span>
</li>
<li>
<span>AND grades.cno </span><span class="tag"><span class="tag">></span><span> ’B2’  </span></span>
</li>
</ol>
登录后复制

上面的查询方式是错误的,正确方式见下方:

<ol class="dp-xml">
<li class="alt"><span><span>select * from students  </span></span></li>
<li><span>where not exists (select * from grades   </span></li>
<li class="alt">
<span>where </span><span class="attribute">grades.sno</span><span>=</span><span class="attribute-value">students</span><span>.sno AND </span><span class="attribute">cno</span><span>=</span><span class="attribute-value">'B2'</span><span>)  </span>
</li>
</ol>
登录后复制

11.关于有难度多重嵌套查询的解决思想:

如,选修了全部课程的学生:

<ol class="dp-xml">
<li class="alt"><span><span>select *  </span></span></li>
<li><span>from students  </span></li>
<li class="alt"><span>where not exists ( select *  </span></li>
<li><span>from courses  </span></li>
<li class="alt"><span>where NOT EXISTS   </span></li>
<li><span>(select *  </span></li>
<li class="alt"><span>from grades  </span></li>
<li>
<span>where </span><span class="attribute">sno</span><span>=</span><span class="attribute-value">students</span><span>.sno  </span>
</li>
<li class="alt">
<span>AND </span><span class="attribute">cno</span><span>=</span><span class="attribute-value">courses</span><span>.cno)) </span>
</li>
</ol>
登录后复制

最外一重:从学生表中选,排除那些有课没选的。用not exist。由于讨论对象是课程,所以第二重查询从course表中找,排除那些选了课的即可。


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何优化 PHP 中的 MySQL 查询性能? 如何优化 PHP 中的 MySQL 查询性能? Jun 03, 2024 pm 08:11 PM

可以通过以下方式优化MySQL查询性能:建立索引,将查找时间从线性复杂度降至对数复杂度。使用PreparedStatements,防止SQL注入并提高查询性能。限制查询结果,减少服务器处理的数据量。优化连接查询,包括使用适当的连接类型、创建索引和考虑使用子查询。分析查询,识别瓶颈;使用缓存,减少数据库负载;优化PHP代码,尽量减少开销。

如何在 PHP 中使用 MySQL 备份和还原? 如何在 PHP 中使用 MySQL 备份和还原? Jun 03, 2024 pm 12:19 PM

在PHP中备份和还原MySQL数据库可通过以下步骤实现:备份数据库:使用mysqldump命令转储数据库为SQL文件。还原数据库:使用mysql命令从SQL文件还原数据库。

如何使用 PHP 插入数据到 MySQL 表中? 如何使用 PHP 插入数据到 MySQL 表中? Jun 02, 2024 pm 02:26 PM

如何将数据插入MySQL表中?连接到数据库:使用mysqli建立与数据库的连接。准备SQL查询:编写一个INSERT语句以指定要插入的列和值。执行查询:使用query()方法执行插入查询,如果成功,将输出一条确认消息。

如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 Dec 09, 2024 am 11:42 AM

MySQL 8.4(截至 2024 年的最新 LTS 版本)中引入的主要变化之一是默认情况下不再启用“MySQL 本机密码”插件。此外,MySQL 9.0完全删除了这个插件。 此更改会影响 PHP 和其他应用程序

如何在 PHP 中使用 MySQL 存储过程? 如何在 PHP 中使用 MySQL 存储过程? Jun 02, 2024 pm 02:13 PM

要在PHP中使用MySQL存储过程:使用PDO或MySQLi扩展连接到MySQL数据库。准备调用存储过程的语句。执行存储过程。处理结果集(如果存储过程返回结果)。关闭数据库连接。

如何使用 PHP 创建 MySQL 表? 如何使用 PHP 创建 MySQL 表? Jun 04, 2024 pm 01:57 PM

使用PHP创建MySQL表需要以下步骤:连接到数据库。创建数据库(如果不存在)。选择数据库。创建表。执行查询。关闭连接。

在PHP中使用MySQLi建立数据库连接的详尽教程 在PHP中使用MySQLi建立数据库连接的详尽教程 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 Jul 18, 2024 am 05:48 AM

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

See all articles