更多优质内容
请关注公众号

PHP基础(十七) 使用PHP操作Mysql-阿沛IT博客

正文内容

PHP基础(十七) 使用PHP操作Mysql

栏目:PHP 系列:PHP基础系列 发布时间:2019-12-07 18:23 浏览量:3320

PHP访问MySQL数据库服务器是通过安装相应的扩展模块完成的,本章重点是介绍使用mysqli扩展模块中的函数去访问MySQL。

如果对MySQL不了解的朋友可以查看本站中MySQL的文章:

Mysql基础教程(一) Mysql数据库概述和简单命令

要想使用这个功能扩展模块,PHP的Linux版本必须在编译时加上一个--with-mysqli选项。PHP的Windows版本则通过一个DLL文件提供了相应的扩展。无论使用的是哪一种操作系统,都必须在php.ini文件里启用这个扩展以确保PHP能够找到所有必要的DLL。可以通过查看phpinfo()确认mysqli模块是否安装。


在PHP脚本中操作MySQL数据库的的八个步骤如下:
1.连接MySQL数据库服务器并选择数据库
2.判断是否连接正确
3.设置字符集
4.准备SQL语句
5.发送SQL语句到MySQL服务器
6.处理结果集
7.释放结果集资源
8.关闭数据库连接


通过PHP脚本程序去管理MySQL服务器中的数据,也必须先建立连接,然后才能通过PHP中的函数向服务器中发送SQL查询语句。PHP可以通过mysqli扩展功能模块去连接MySQL服务器,办法是调用mysqli_connect()函数,和使用MySQL客户机程序连接MySQL服务器类似。 

resource mysqli_connect ( [string host [, string username [, string password [, string dbname [, int port [,string socket]]]]] )

/* 检查连接 */
if (mysqli_connect_errno()) {
         printf("Connect failed: %s\n",  mysqli_connect_error()  );
         exit();
}


获取错误和信息

1. 返回最近函数调用的错误代码
     int mysqli_errno ( mysqli $link )


2.返回最近函数调用的错误信息
     string mysqli_error ( mysqli $link )


选择数据库

bool mysqli_select_db ( mysqli $link,string $dbname )


设置字符集

bool mysqli_set_charset (mysqli $link , string $charset )


准备sql语句

设置字符集完毕之后,我们需要为读取或写入数据设计SQL语句字符串,
例如:
$sql = “select username,password from bbs_user”;


发送SQL语句

设计好SQL语句之后,我们使用函数mysqli_query()函数,将SQL语句发送到MySQL数据库服务器,由MySQL数据库服务器来执行此SQL语句,这里注意,我们之所以将SQL语句赋值给一个变量是为了出现错误的时候便于排错,我们可以直接输出$sql这个变量。
int/resource mysqli_query ( mysqli $link,string $query )


处理结果

将SQL语句发送到MySQL服务器之后,MySQL服务器会将执行SQL语句之后的结果返回给PHP端,这里的结果分为两种:
    1.布尔型
    2.结果集资源类型
当我们执行的SQL语句是DML语句,也就是增,删,改三种语句,这时mysqli_query()返回的类型是布尔类型,执行成功返回真,失败返回假,但有时SQL语句执行成功,但不一定有受影响行数,所以我们可以使用mysqli_affected_rows()函数返回


受影响行数;当我们执行的是DQL语句,也就是查询语句,mysqli_query()函数将返回的是结果集资源类型,我们可以使用mysqli_num_rows($result)函数来获取结果集当中的记录条数,但是我们无法将结果集资源当中的数据得到,因此PHP为我们提供了4个函数,来解析此结果集资源:
1.mysqli_fetch_array()    返回索引和关联的混合数组
2.mysqli_fetch_assoc()    返回关联数组
3.mysqli_fetch_row()        返回索引数组
4.mysqli_fetch_object()    返回一个对象


处理结果

如果没有特殊要求,尽量不要去使用mysqli_fetch_array()方法。使用mysqli_fetch_row()或mysqli_fetch_assoc()函数实现相同的功能,效率会更高一些。上述四个函数每执行一次,结果集资源的指针都将向后移动一位,直到最后一位,将返回布尔类型的FALSE,因此,我们可以使用条件型循环while配合上述四个函数来使用,以mysqli_fetch_assoc()函数为例,如下所示:
while($row=mysqli_fetch_assoc($result)){
    //$row为一条记录的数组    
}


从结果集中取得一行作为关联数组,或数字数组,或二者兼有
array mysqli_fetch_array ( resource $result [, int $ result_type ] )


从结果集中取得一行作为关联数组 
array mysqli_fetch_assoc ( resource $result )


从结果集中取得一行作为对象
object mysqli_fetch_object ( resource $result )


从结果集中取得一行作为枚举数组
array mysqli_fetch_row ( resource $result )


取得结果集中行的数目
int mysqli_num_rows ( resource $result )


除此之外,我们还可以使用mysqli_insert_id()来获取插入的上一条记录的主键ID的值,可以使用mysqli_num_fileds()来获取结果集中字段的个数,mysqli_fetch_field()函数将取得具体字段的信息,mysqli_result()获取查询记录的第n条信息。


取得前一次 MySQL 操作所影响的记录行数
int mysqli_affected_rows ([ resource $link_identifier ] )


取得上一步 INSERT 操作产生的 ID 
int mysqli_insert_id ([ resource $link_identifier ] )


取得结果集中字段的数目
int mysqli_num_fields ( resource $result )


从结果集中取得列信息并作为对象返回
object mysqli_fetch_field ( resource $result)


释放结果集资源 关闭数据库连接

PHP会把结果数据表一直保存到PHP脚本执行结束,如果必须提前释放某次查询的结果数据表,就可使用mysqli_free_result()函数提前释放它,最后将数据库连接关闭掉,我们使用mysqli_close()函数来完成。
bool mysqli_free_result ( resource $result )
bool mysqli_close ([ resource $link_identifier ] )





更多内容请关注微信公众号
zbpblog微信公众号

如果您需要转载,可以点击下方按钮可以进行复制粘贴;本站博客文章为原创,请转载时注明以下信息

张柏沛IT技术博客 > PHP基础(十七) 使用PHP操作Mysql

热门推荐
推荐新闻