PHP中MySQL操作

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

本次使用的demo是MySQL的示例数据库employees,点击下载地址,注意在导入的时候,在employees.sql文件中,将source改成你当前的目录。

PHP中的demo代码可以在ideone下载到。

这里使用的是mysqli的方式,其他还有mysql和pdo方式,官方有篇比较的3者区别的文章《Overview》。

一、连接数据库

1.1、连接

mysqli_connect

打开一个到 MySQL 服务器的连接。有面向对象风格和过程化风格。

$link = mysqli_connect("localhost", "root", "123456", "employees");//面向过程
$link = new mysqli("localhost", "root", "123456", "employees");//面向对象

如果成功则返回一个 MySQL 连接对象, 或者在失败时返回 FALSE

 

1.2、设置编码

set_charsetquery。query在下面就会有讲到,这里的话其实就是执行一条语句“SET NAMES utf8”。

设置在数据库间传输字符时所用的默认字符编码。

$link->query("SET NAMES utf8");//执行语句
    
mysqli_set_charset($link, 'utf8');//面向过程
$link->set_charset('utf8');//面向对象

成功时返回 TRUE, 或者在失败时返回 FALSE

 

二、查询

2.1、对数据库执行一次查询

mysqli_queryquery。返回的信息中并没有记录信息,需要再使用方法获取。

$sql = 'select * from employees limit 10';
$result = mysqli_query($link, $sql);//面向过程
$result = $link->query($sql);//面向对象

失败时返回 FALSE成功执行SELECT, SHOW, DESCRIBE或 EXPLAIN查询会返回一个mysqli_result 对象,其他查询则返回TRUE

接下来的2和3就是根据mysqli_result对象来的。

还有就是下面的所有方法都有面向过程和面向对象的方式,为了节省篇幅,下面例子都是面向对象的方式。

 

2.2、查询记录获取

fetch_all、fetch_array、fetch_assoc与fetch_row,返回的是array。

fetch_fields、fetch_field、fetch_object与fetch_field_direct,返回是stdClass Object。

data_seek

重置指针到起始,当做fetch_fields、fetch_assoc等读取数据的时候,指针会变化。

 

fetch_all

返回记录数组,这个方法有可以传递一个参数resulttype,三个常量MYSQLI_ASSOC, MYSQLI_NUM, or MYSQLI_BOTH。默认是MYSQLI_NUM。

$data = $result->fetch_all(MYSQLI_ASSOC);

获取所有结果行并返回结果集作为关联数组数字数组,或两者兼而有之

下面的第一张返回结果图,引用的参数是MYSQLI_ASSOC,第二张引用的参数是MYSQLI_NUM。其实就是key的不同。

 

fetch_array

返回一条记录数组,或没有记录返回NULL。与fetch_all一样,也有个参数resulttype,三个常量供选择。默认是MYSQLI_BOTH。

$data = $result->fetch_array(MYSQLI_ASSOC);

 

fetch_assoc

没有resulttype参数,返回的是一条关联数组,或者没记录返回NULL。如果数组中包含相同的键名,那么将取最后一列。

 

fetch_row

同样没有resulttype参数,返回的是一条数字数组,或者没有记录返回NULL

 

fetch_fields

用此方法获取表中所有的字段信息,包括字段名、字段长度、所属表等。

返回多个对象的数组,如果没有就返回FALSE

 

fetch_field

与上面的方法相对,只会获取某一个字段信息。配合field_seek,可以根据需要获得某个位置的字段信息。

返回个对象的数组,如果没有就返回FALSE

$result->field_seek(1);
$fields = $result->fetch_field();

注意上面的代码,返回的将是第二个字段的信息。

 

fetch_object

可以传入两个参数class_name和params,返回一个关联对象,如果没有数据返回NULL

 

fetch_field_direct

可以传入一个参数fieldnr,也就是字段的位置。效果等效于上面的fetch_fieldfield_seek的配合。

 

2.3、插入更新等信息获取

employees表的主键原先不是自增长的,我后面改了下字段,目前表中有499999条数据。

$sql = "insert into employees(`birth_date`,`first_name`,`last_name`,`gender`,`hire_date`) values ('1988-10-9', 'pw', 'strick', 'M', '1988-10-9')";
$result = $link->query($sql);
var_dump($link->affected_rows);//受影响行数
var_dump($link->insert_id);//主键
//print_r(mysqli_error($link));//打印错误信息

上面的$result返回的将是一个boolean值,而主键和影响行数是需要从mysqli对象中获取。

 

三、预处理

3.1、添加更新等操作

预处理能有效的防止sql注入的产生,mysqli_stmt是预处理类。

$sql = "insert into employees(`birth_date`,`first_name`,`last_name`,`gender`,`hire_date`) values (?,?,?,?,?)";
$stmt = $link->prepare($sql);//获得预处理对象//bind_param中的第N个参数,必须得用变量赋值
$birth_date = '1989-10-9';$first_name = 'pw2';$last_name = 'strick2';$gender = 'M';$hire_date = '1988-10-9';
$stmt->bind_param('sssss', $birth_date, $first_name, $last_name, $gender, $hire_date);//绑定时使用变量绑定 //$stmt->bind_param('sssss', '1989-10-9', 'pw2', 'strick2', 'M', '1988-10-9');//不能使用这种方式 $stmt->execute();//执行预处理 var_dump($stmt->insert_id);//主键 var_dump($stmt->affected_rows);//受影响行数

prepare

初始化一个预处理对象,传入string类型的查询语句。返回一个mysqli_stmt对象,失败则返回FALSE

bind_param

绑定预处理查询语句中的变量。第一个参数是指定数据类型。

 

3.2、查询

$sql = 'select * from employees limit ?';
$stmt = $link->prepare($sql);
$count = 10;
$stmt->bind_param("i", $count);
$stmt->execute();
$result = $stmt->get_result();//结果集取后的操作就和之前一样了

与上面不同的就是要先preparebind_param,然后execute,最后是get_result获取一个mysqli_result对象,接下来就是和上面的操作一样了。

 

demo数据库下载:

http://download.csdn.net/detail/loneleaf1/9271903

demo代码下载:

http://ideone.com/uSzZTi

 

参考资料:

http://segmentfault.com/a/1190000003841357   PHP mysqli 操作数据库





    本文转自 咖啡机(K.F.J)   博客园博客,原文链接:http://www.cnblogs.com/strick/p/4968562.html,如需转载请自行联系原作者

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3天前
|
Oracle 关系型数据库 MySQL
实时计算 Flink版操作报错合集之用CTAS从mysql同步数据到hologres,改了字段长度,报错提示需要全部重新同步如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
45 8
|
3天前
|
SQL 关系型数据库 MySQL
实时计算 Flink版操作报错合集之程序初始化mysql没有完成就报错如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
15 4
|
3天前
|
关系型数据库 MySQL 数据库
实时计算 Flink版操作报错合集之sqlserver mysql都用的胖包,sqlserver的成功了,mysql报这个错如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
20 6
|
3天前
|
SQL Oracle 关系型数据库
实时计算 Flink版操作报错合集之连接器换成2.4.2之后,mysql作业一直报错如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
16 3
|
6天前
|
SQL 关系型数据库 MySQL
Mysql忘记密码操作
Mysql忘记密码操作
28 1
|
6天前
|
SQL 关系型数据库 MySQL
DQL操作MySql
DQL操作MySql
13 0
|
6天前
|
SQL Java 关系型数据库
【JAVA基础篇教学】第十六篇:Java连接和操作MySQL数据库
【JAVA基础篇教学】第十六篇:Java连接和操作MySQL数据库
|
6天前
|
SQL 存储 关系型数据库
【MySQL】DDL的表操作详解:创建&查询&修改&删除
【MySQL】DDL的表操作详解:创建&查询&修改&删除
|
6天前
|
SQL DataWorks 关系型数据库
DataWorks操作报错合集之DataWorks在同步mysql时报错Code:[Framework-02],mysql里面有个json类型字段,是什么原因导致的
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
36 0
|
6天前
|
关系型数据库 MySQL Java
使用shardingjdbc执行MySQL游标操作时报错
使用shardingjdbc执行MySQL游标操作时报错