作为信息系统开发,必然要用到数据库。PHP与MySQL数据库搭配是最好的。本任务主要是帮助大家掌握MySQL数据库的安装与配置,安装数据库管理工具,并掌握PHP中如何连接MySQL数据库。
1、安装MySQL数据库
搭建PHP开发或生产环境,随XAMPP一道安装MariaDB是最好的选择,默认使用phpMyAdmin数据库工具(Web形式管理)。
但如果要与c/s端共用数据库,可以单独安装MySQL或MariaDB数据库。
为什么会有MariaDB?
如果你计算机之前已经安装MySQL,可以继续使用。
注意以下几方面:
(1)选择Server only。当然Developer(Default)也没有问题。
(2)注意认证模式要选用传统方式(mysql_native_passowrd),因为我们现在使用的PHP版本是PHP 7.3。PHP 7.4则可以选择强密码方式(caching_sha2_password)
2、安装数据库管理工具
推荐使用Navicat Premium 15。当然也可以选择你喜欢的其它数据库管理工具。
注意使用破解时,一定要关注防病毒软件。
3、安装示例数据库Sakila
本课程数据库示例继续使用Sakila数据库。已经在Java课程中做过介绍。
导入数据前要先创建好Sakila数据库,注意创建时选择好字符集(utf-8)和排序规则(utb8_general_ci)。
4、PHP连接MySQL数据库
PHP访问MySQL数据库有三种方式:面向过程mysqli,面向对象mysqli和PHP数据对象(PDO)。本任务使用面向过程mysqli,推荐使用面向对象mysqli。连接其它类型数据库要使用PDO。
面向过程mysqli就是使用PHP系统函数,面向对象mysqli就是使用mysqli类对象。注意:PHP7中已经摒弃传统的mysql,而是使用mysqli,但是很多文章(包括官方手册)在介绍时仍然使用mysql,注意要转换成mysqli。
一般访问数据库都需要以下过程(以查询为例):
(1)建立数据库连接,使用mysqli_connect函数。
(2)使用数据库连接和SQL语句执行查询,使用mysqli_query函数。
(3)处理结果集(处理多条结果用while循环,单条用if就可以)
使用mysqli_fetch_array数,从结果集中提取一行记录,保存到数组。(可以是数值数组,关联数组,或者两者都有)
(4)关闭数据库连接。
4.1 建立数据库连接
建议使用die语句进行错误处理:
可以使用mysqli_connect_error()函数得到最近一次的错误信息(没有错误时返回空串),使用mysqli_connect_errno()函数得到最近一次的错误代码(0表示成功,在mysql源码Docs/mysqld_error.txt中有定义)。
4.2 执行数据库查询
执行数据库查询使用SQL语句。为保证SQL语句正确,该语句尽量在Navicat中验证过。
失败时返回false,使用select等查询SQL语句时返回mysqli_result对象,其它SQL语句返回true。
Mysqli_query()函数还有第3个可选参数int $resultmode
,取值为MYSQLI_STORE_RESULT一次查询就将结果缓存下来供以后操作,数据库连接可以关闭(缺点是耗内存)。取值MYSQLI_USE_RESULT时,本次query并没有从数据库读取数据,而是每次fetch时再去数据库读取一条记录。
4.3 从结果集提取记录
实际上有4个函数可以从结果集中提取一条记录:
- mysqli_fetch_row:数值数组,以整数为索引
- mysqli_fetch_assoc:关联数组,以字段名为索引
- mysqli_fetch_array:两者都有,也可以由第2个参数指定数值数组或关联数组
- mysqli_fetch_object:对象,字段是这个对象的属性。
即:用 $row=mysqi_fetch_xxx($result);从结果集$result中提取一条记录,则获取Email字段值(第3个字段)可以:
- 使用row:$row[2]
- 使用assoc:$row['email']
- 使用array:上述两者均可
- 使用object:$row->email
4.4 关闭数据库连接
使用mysqli_close()函数,如:
5、课后练习
有条件的同学,务必练习下安装MySQL(已经安装忽略)、安装Navicat(或其它管理工具)、导入示例Sakila数据库。
并编写简单测试程序,从Sakila数据库中读取某张表的数据并显示出来。