博客提纲

利用PHP连接mySQL数据库

两套接口:面向对象和面向过程

实现写改删查(CUBD)实例

通过prepare语句处理相同类型的不同SQL语句

通过bind_param()绑定参数,及相关注意事项

通过bind_result()绑定结果,以及相关注意事项

将文本写入数据库前应做的检测和处理

检查是否为空(未输入值)

去首尾空格

魔鬼字符串转义

一.利用PHP连接mySQL数据库

这要从一个故事说起。

某一天,一位名叫MySQL的农夫的一把斧子(数据库操作)掉进了一条名为PHP的河里,这时候,一位好心的河神出现了

PHP河的河神问他。。。。

下面,咱们还是说正经的把!。。。(:3 」∠)

在我主机(localhost)的penghuwan数据库下,有张mytable的表如下图所示

PHP针对mysql数据库的操作有两套接口:面向对象接口和面向过程接口;

面向对象接口:通过调用对象中的函数完成数据库操作

面向过程接口:直接调用PHP内置的函数实现数据库操作

因为执行写改删操作的PHP语句类似,所以这里只以“写操作”和“查操作”为例子

读操作:

面向对象:

@$mysqli = new mysqli('localhost', 'root', 'phw441423', 'penghuwan');//(主机,账号,密码,数据库) 返回一个mysqli对象

if($mysqli->connect_error){//当有连接错误的时候,结束脚本运行并且报错

die('连接错误,这个错误是'.$mysqli->connect_error);//die()函数:1结束脚本运行,2输出一段文本(括号内)

}

$query = "SELECT * FROM mytable";//把一段SQL语句保存在$query变量中

$mysqli_result = $mysqli->query($query);//通过调用上面返回的mysqli对象中的方法,返回一个结果集对象(mysqli_result)

while($row = $mysqli_result->fetch_assoc()){//调用mysqli_result的方法fetch_assoc()后,返回的是一个数组变量$row

echo $row['name'];//访问返回数组变量$row中的数组成员,对应mytable表中的name列

echo $row['number'];;//访问返回数组变量$row中的数组成员,对应mytable表中的number

echo "
";

}

$mysqli_result->free();//释放结果集

$mysqli ->close();//关闭数据库连接

?>

首先通过

new mysqli($host, $username, $passwd, $dbname)

获取一个mysqli对象,然后在下面我们就可以通过调用对象中的方法query方法去实现写改删查

运行结果:

思维导图

上面的例子中,一个关键的方法是mysqli对象的query方法,意为查询.但实际上,它除了能运行“查”的SQL语句外,还能运行“写改删”的SQL语句。

关于query的返回值:

执行失败,返回false

执行成功

如果执行的语句,即query是SELECT,SHOW,EXPLAIN 或 DESCRIBE,则返回一个结果集对象

如果是其他,则返回false

面向过程:

@$mysqli = mysqli_connect('localhost', 'root', 'phw441423', 'penghuwan');//(主机,账号,密码,数据库) 返回一个mysqli对象

if(mysqli_connect_error()){//当有连接错误的时候,结束脚本运行并且报错

die('连接错误,这个错误是'.mysqli_connect_error());;//die()函数:1结束脚本运行,2输出一段文本(括号内)

}

$query = "SELECT * FROM mytable";//把一段SQL语句保存在$query变量中

$mysqli_result = mysqli_query($mysqli, $query);//在面向过程风格里,$mysqli对象成了该方法中的参数,也返回一个结果集对象(mysqli_result)

while($row = mysqli_fetch_assoc($mysqli_result)){// 返回的是一个数组变量$row

echo $row['name'];//访问返回数组变量$row中的数组成员,对应mytable表中的name列

echo $row['number'];;//访问返回数组变量$row中的数组成员,对应mytable表中的number

echo "
";

}

mysqli_free_result($mysqli_result);//释放结果集

mysqli_close($mysqli);//关闭数据库连接

?>

【注意点】

mysqli_fetch_assoc(面向过程)和fetch_assoc(面向对象)这两个方法返回的是一个关联数组变量$row

在命令行界面里,我们需要做选择数据库的选择,即使用“USE 所选数据库”这个命令,但在这里我们在一开始连接的时候就选择了数据库了。例如:mysqli_connect('localhost', 'root', 'phw441423', 'penghuwan');中我们选择了数据库penghuwan所以就不用写USE语句了

最后记得要释放结果集和关闭连接

拥有两套接口固然增加了记忆难度,但如果你注意观察的话,两套接口函数的名称是联系紧密的。

如何记忆?

一般情况下:面向过程函数名= mysqli_ +面向对象函数名

例如:

返回结果集对象的方法:

面向对象:query 面向过程:mysqli_query

从结果集对象中返回某一行(形式为关联数组)的方法:

面向对象:fetch_assoc 面向过程:mysqli_fetch_assoc

两者联系

一般情况下,面向对象接口中的对象将会成为面向过程接口中的第一个参数

例如:

通过mysqli对象取得结果集的时候:

面向过程:$mysqli_result = mysqli_query($mysqli, $query);

面向对象:$mysqli_result = $mysqli->query($query);

写操作:

面向对象:

@$mysqli = new mysqli('localhost', 'root', 'phw441423', 'penghuwan');//(主机,账号,密码,数据库) 返回一个mysqli对象

if($mysqli->connect_error){//当有连接错误的时候,结束脚本运行并且报错

die('连接错误,这个错误是'.$mysqli->connect_error);//die()函数:1结束脚本运行,2输出一段文本(括号内)

}

$query = "INSERT INTO mytable VALUES('C',30)";//把一段SQL语句保存在$query变量中

$mysqli->query($query);// 此时返回的不是结果集对象,而是一个boolean,代表成功或失败

$mysqli ->close();//关闭数据库连接

?>

运行结果:

思维导图

面向过程:

和第一个“查”的例子类似,这里不多加赘述。

二.通过prepare语句处理相同类型的不同SQL语句

通过bind_param()绑定参数,及相关注意事项

在实际操作中,我们可能需要处理大量相同类型的不同SQL语句,例如

"SELECT * FROM mytable WHERE name = ‘A’"

或者

"SELECT * FROM mytable WHERE name = ‘B’"

这样的语句。你可能会试图自己封装函数来避免写一大堆相同类型的语句。但实际上,PHP已经给我们封装好了一系列的内置函数,它就是prepare语句:

我们接下来实现这样一段PHP脚本:

通过prepare语句给mytable插入两行数据(类型相同的不同SQL语句)

我们原来的mytable表长这样:

我们下面向其中插入两行

列1

列2

D

40

E

50

@$mysqli = new mysqli('localhost', 'root', 'phw441423', 'penghuwan');//(主机,账号,密码,数据库) 返回一个mysqli对象

if($mysqli->connect_error){//当有连接错误的时候,结束脚本运行并且报错

die('连接错误,这个错误是'.$mysqli->connect_error);//die()函数:1结束脚本运行,2输出一段文本(括号内)

}

$query = "INSERT INTO mytable VALUES(?,?)";//,“?”表示模板中要被实际替换的变量

$stmt = $mysqli->prepare($query);//通过prepare函数生成mysqli_statement对象

$name1 = 'D';

$number1 = 40;

$stmt->bind_param("si",$name1,$number1);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"

$stmt->execute();//第一次执行

$name2 = 'E';

$number2 = 50;

$stmt->bind_param("si",$name2,$number2);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"

$stmt->execute();//第二次执行

$stmt->close();//关闭mysqli_statement

$mysqli ->close();//关闭数据库连接

?>

思维导图

运行结束后:

关键的一个方法是bind_param()方法,它接受多个参数,其中

第一个参数代表后面参数的类型。

第一个参数是一个字符串,由固定顺序的字符组成,这些字符包括“s”,”i”,”d”,”b”,分别表示字符串,整型,双精度和二进制文本,依次代表后面参数的类型。

字符

代表类型

“s”

字符串

“i”

整型

“d”

双精度

“b”

二进制文本

例如:我们上面的$stmt->bind_param("si",$name1,$number1);代表:$name1是字符串类型,,$number1是整型

【注意】

不能直接向bind_param()第二个即以后的参数中写入具体的变量值!否则会报错:

例如,我们把:

$name1 = 'D';

$number1 = 40;

$stmt->bind_param("si",$name1,$number1);

?>

改成:

$stmt->bind_param("si",'D',40);

?>

运行:

【注意】

你只能写入变量的名称而不能写具体的类型值——

一个bind_param()函数对应一个execute()函数,如果连续写多个bind_param()再写execute()函数,相当于最后一个bind_param()覆盖前面写的的 bind_param()

例如我们把上面的

$name1 = 'D';

$number1 = 40;

$stmt->bind_param("si",$name1,$number1);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"

$stmt->execute();//第一次执行

$name2 = 'E';

$number2 = 50;

$stmt->bind_param("si",$name2,$number2);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"

$stmt->execute();//第二次执行

改成:

$name1 = 'D';

$number1 = 40;

$stmt->bind_param("si",$name1,$number1);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"

$name2 = 'E';

$number2 = 50;

$stmt->bind_param("si",$name2,$number2);//通过mysqli_statement对象的bind_param方法用实际的变量替换模板中的"?"

$stmt->execute();//第二次执行

运行结果:

它并不会批量执行$name1,$number1和$name2,$number2的插入,而是只插入了$name2,$number2,因为最后一个bind_param()覆盖前面写的的 bind_param()

通过bind_result()绑定结果,及相关注意事项

上面的例子中我们演示了如何绑定参数,下面我来演示如何绑定结果,这里将用到bind_result()函数:

@$mysqli = new mysqli('localhost', 'root', 'phw441423', 'penghuwan');//(主机,账号,密码,数据库) 返回一个mysqli对象

if($mysqli->connect_error){//当有连接错误的时候,结束脚本运行并且报错

die('连接错误,这个错误是'.$mysqli->connect_error);//die()函数:1结束脚本运行,2输出一段文本(括号内)

}

$query = "SELECT * FROM mytable";//prepare函数的参数

$stmt = $mysqli->prepare($query);//通过prepare函数生成mysqli_statement对象

$stmt->bind_result($name,$number);//将执行结果绑定到$name和,$number中

$stmt->execute();// 执行生成查询结果

while($stmt->fetch()){// 将查询结果中的第一行的列值分别赋给$name和,$number,同时游标移到下一行

echo $name.' '.$number;//输出mytable中当前行各个列的列值

echo "
";

}

$stmt->close();//关闭mysqli_statement

$mysqli ->close();//关闭数据库连接

?>

思维导图

运行结果如下:

【注意】

bind_param必须放在execute语句的前面,但bind_result放在execute前后均可

例如:我们将上面对应的代码改成:

$stmt->execute();// 执行生成查询结果

$stmt->bind_result($name,$number);//将执行结果绑定到$name和,$number中

运行结果同上(但注意bind_result应放在fetch语句前)

excute()执行完毕的时候,$name,$number仍为空,直到fetch()第一次执行的时候,$name,$number才取到对应行的列值

将上面例子中对应代码改成:

$stmt->bind_result($name,$number);//将执行结果绑定到$name和,$number中

$stmt->execute();// 执行生成查询结果

echo 'execute执行后$name的值为';

var_dump($name);

运行结果:

同一个prepare模板可多次使用,但前后使用两个prepare模板中间,必须关闭现有的mysqli_statement

$query1 = "SELECT name FROM mytable";

$stmt = $mysqli->prepare($query1);

$stmt->execute();//执行第一个prepare模板语句

$query2 = "SELECT number FROM mytable";//prepare函数的参数

$stmt = $mysqli->prepare($query2);

$stmt->execute();//执行第二个prepare模板语句 [注],这就是24行

提示的错误是,我对一个boolean值调用了execute函数

我尝试输出$stmt(最下面那个),输出为false(这里不做展示了)

这说明执行第二个prepare模板语句的时候失败了,那这时候该怎么办呢?

让我们在两段prepare模板语句间加上

$stmt->close():

即:

$query1 = "SELECT name FROM mytable";

$stmt = $mysqli->prepare($query1);

$stmt->execute();//执行第一个prepare模板语句

$stmt->close();

$query2 = "SELECT number FROM mytable";//prepare函数的参数

$stmt = $mysqli->prepare($query2);

$stmt->execute();//执行第二个prepare模板语句

?>

运行:报错消失

三.将字符串写入数据库前应做的检测和处理

应该注意的是三个方面的事情:

检查输入是否为空值,这点就不加赘述了

去除首尾空格(假设我们在录入数据库前没有去除空格的话,例如将“【空格】彭湖湾”录入数据库,那么在进行“【空格】彭湖湾”===“彭湖湾”的匹配时便会返回false)

对魔术字符串转义(如果不进行转义,字符串中的双引号和单引号会对我们的SQL语句造成干扰)

$text = $_GET['text'];// 从from表单中name属性为“text”的输入框中取得值

if(!$text){//如果text为空则输出警告,并结束脚本

echo '您还没有输入任何值哦';

exit();

}

$text = trim($text);//去除首尾空格

if(!get_magic_quotes_gpc()){//检查是否自动开启了魔术字符串转义,如果没有,则手动转义魔术字符串

$text = addslashes($text);

}

echo '经过处理后的值'.$text;

echo "
";

echo '重新取出值'.stripslashes($text);

?>

输入空值的时候:

输入带空格和魔术字符串的文本——“【空格】penghuwan”

参考资料

《php和mysql的web开发》--(澳)威利,(澳)汤姆森 著

PHP官方文档 链接:http://php.net/manual/zh/

stackOverFlow社区 链接: https://stackoverflow.com/

php mysql die_【PHP】当mysql遇上PHP相关推荐

  1. centos7不能安装mysql数据库_Centos7 上安装mysql遇上的问题:mysql无法正常启动-Go语言中文社区...

    第一次在Centos上安装mysql遇到的一些问题. 第一步就遇到问题,安装mysql-server报错没有可用包. [解决方法] 先要安装mysql # wget http://repo.mysql ...

  2. Centos7 上安装mysql遇上的问题:mysql无法正常启动

    第一次在Centos上安装mysql遇到的一些问题. 第一步就遇到问题,安装mysql-server报错没有可用包.   [解决方法]  先要安装mysql # wget http://repo.my ...

  3. mysql全局权限账户%登录不上ERROR 1045 (28000): Access denied for user #39;mhz#39;@#39;localhost#39; (using ...

    mysql全局权限账户%登录不上 ERROR 1045 (28000): Access denied for user 'mhz'@'localhost' (using password: YES)  ...

  4. linux mysql 知乎_在 Linux 上安装 MariaDB 或 MySQL | Linux 中国

    开始在 Linux 系统上使用开源的 SQL 数据库吧. (本文字数:2332,阅读时长大约:3 分钟) MariaDB 和 MySQL 都是使用 SQL 的开源数据库,并且共享相同的初始代码库.Ma ...

  5. 把mysql部署在局域网的服务器上,远程连接mysql时报错误代码1130 Host ‘***.***.***.***’is not allowed to connect to this MySQL

    ==刚学习mysql的时候,知道DBMS分为两类: ①基于文件共享的dbms(access) ②基于客户机–服务器的DBMS(Mysql.Oracle),在使用客户端时需要安装服务端,数据也存储在服务 ...

  6. centos安装mysql 简书_在centos上安装mysql

    由于mysql易主甲骨文以后,centos7担心mysql慢慢会封闭不再开源所以将yum里面的数据库更换名字为MariaDB.两者差不多没有太大区别. 如何在centos7上安装mysql 解决思路通 ...

  7. java写一个窗体并连接MySQL_大神帮忙写一个简单地java页面,连接MySQL数据库之后能够显示数据库上的数据...

    展开全部 用jdbc 连接mysql数据库就行了,网上搜下一大把. --记得在classpath下加入mysql 的jdbc驱动包. /** * @author :来e68a84e8a2ad32313 ...

  8. linux mysql帮助文档,在 Linux 上安装 MySQL

    ## 2.5 在 Linux 上安装 MySQL Linux 支持多种不同的 Linux 安装解决方案. We recommend that you use one of the distributi ...

  9. linux一台机器如何安装两个mysql,在一台linux机器上启动两个mysql实例

    环境:linux主机上已经yum安装了mysql,而且数据库正在运行. 在不关闭/重启mysql的情况下,重新启动一个新的mysql实例,使用3307端口,实现一台机器上同时运行两个数据库实例. 1. ...

  10. Mysql数据库从本地导出 服务器上导入时报 ERROR 2005 HY000 Unknown MySQL ser

    分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow 也欢迎大家转载本篇文章.分享知识,造福人民,实现我们中华民族伟大复兴! 今天在做 ...

最新文章

  1. 山寨上网本溃败的两点教训
  2. 昨日,全球股市进入ICU!89岁股神巴菲特惊叹活久见!苹果微软万亿美金市值摇摇欲坠...
  3. 《Nmap渗透测试指南》—第1章1.2节Windows下安装Nmap
  4. 皮一皮:这才是持之以恒的专一...
  5. python笔记:深拷贝与浅拷贝
  6. how does SAP UI5 filter for list work in xml view
  7. A small tip to explore how to call a method of a control
  8. 做生意最重要的诚信呢??? | 今日最佳
  9. 105_Power Pivot财务科目(层级深度筛选深度)
  10. 知新 | koa框架入门到熟练第二章
  11. 将servlet[login]标记为不可用_30分钟上手OUTLOOK - 邮件标记
  12. JavaScript学习(四十六)—练习题
  13. vuex的store机制1
  14. RocketMq在windows下安装
  15. 蚂蚁金融科技守护金融安全,蚂蚁风险大脑助阵
  16. M语言简单示例--网页数据抓取
  17. 简单有限元分析技术(详细步骤讲解)
  18. 51单片机堆栈深入剖析(转)
  19. SBUS转485增程方案,SBUS控制远程机器人方案
  20. 新华三2018校园招聘笔试面试题学习

热门文章

  1. word2007 正文自动变为大纲一级 问题
  2. Win10安装Kali子系统
  3. 大数据剖析 | 北京VS上海: 活着为了工作还是工作为了生活?
  4. (加快设计)推荐一个SketchUp的3D模型库
  5. “富贵树”身价十五万,湖南小伙返乡创业,一年卖出800多万
  6. 在测试中实施人工智能
  7. 计算机三级网络技术最全知识点总结【5】
  8. opencv图像旋转和翻转,cv2.flip,cv2.rotate
  9. 一个猜拳写了一晚上 麻痹……
  10. ​UG塑胶模具设计结构分析是如何挤压成型的