当mysql遇上PHP

这篇具有很好参考价值的文章主要介绍了当mysql遇上PHP。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一.利用PHP连接mySQL数据库

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

当mysql遇上PHP

PHP河的河神问他。。。。

当mysql遇上PHP

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

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

当mysql遇上PHP

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

  • 面向对象接口:通过调用对象中的函数完成数据库操作
  • 面向过程接口:直接调用PHP内置的函数实现数据库操作

因为执行写改删操作的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 "<br/>";
   }
   $mysqli_result->free();//释放结果集
   $mysqli ->close();//关闭数据库连接
?>

复制

首先通过

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

复制

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

运行结果

当mysql遇上PHP

思维导图

当mysql遇上PHP

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

关于query的返回值:

  • 执行失败,返回false
  • 执行成功
  • 如果执行的语句,即query是SELECT,SHOW,EXPLAIN 或 DESCRIBE,则返回一个结果集对象
  • 如果是其他,则返回false
面向过程:
<?php
   @$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 "<br/>";
   }
   mysqli_free_result($mysqli_result);//释放结果集
   mysqli_close($mysqli);//关闭数据库连接
?>

复制

【注意点】

  1. mysqli_fetch_assoc(面向过程)和fetch_assoc(面向对象)这两个方法返回的是一个关联数组变量$row
  2. 在命令行界面里,我们需要做选择数据库的选择,即使用“USE 所选数据库”这个命令,但在这里我们在一开始连接的时候就选择了数据库了。例如:mysqli_connect('localhost', 'root', 'phw441423', 'penghuwan');中我们选择了数据库penghuwan所以就不用写USE语句了
  3. 最后记得要释放结果集和关闭连接

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

  • 如何记忆? 一般情况下:面向过程函数名= mysqli_ +面向对象函数名 例如: 返回结果集对象的方法: 面向对象:query 面向过程:mysqli_query 从结果集对象中返回某一行(形式为关联数组)的方法: 面向对象:fetch_assoc 面向过程:mysqli_fetch_assoc
  • 两者联系 一般情况下,面向对象接口中的对象将会成为面向过程接口中的第一个参数 例如: 通过mysqli对象取得结果集的时候: 面向过程:$mysqli_result = mysqli_query($mysqli, $query); 面向对象:$mysqli_result = $mysqli->query($query);

写操作:

面向对象:
<?php
   @$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();//关闭数据库连接
?>

复制

运行结果:

当mysql遇上PHP

思维导图

当mysql遇上PHP

面向过程:

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

二.通过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

<?php
   @$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()第二个即以后的参数中写入具体的变量值!否则会报错: 例如,我们把:
    <?PHP
      $name1 = 'D';
      $number1 = 40;
      $stmt->bind_param("si",$name1,$number1);
    ?>

复制

改成:

<?PHP
   $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()函数:

<?php
   @$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 "<br/>";
   }
   $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():

复制

即:

 <?PHP
   $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模板语句
?>

复制

运行:报错消失

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

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

  1. 检查输入是否为空值,这点就不加赘述了
  2. 去除首尾空格(假设我们在录入数据库前没有去除空格的话,例如将“【空格】彭湖湾”录入数据库,那么在进行“【空格】彭湖湾”===“彭湖湾”的匹配时便会返回false)
  3. 对魔术字符串转义(如果不进行转义,字符串中的双引号和单引号会对我们的SQL语句造成干扰)
    <?php
      $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 "<br/>";
      echo '重新取出值'.stripslashes($text);
    ?>

复制

输入空值的时候:

输入带空格和魔术字符串的文本——“【空格】penghuwan”文章来源地址https://www.toymoban.com/news/detail-497134.html

到了这里,关于当mysql遇上PHP的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 利用pgloader工具将MySQL数据迁移至PostgreSQL数据库

    一、简介 pgloader是一款开源软件,可以将各种来源的数据加载到PostgreSQL数据库中,支持动态读取数据,使用 COPY 流式传输协议将数据加载到 PostgreSQL 数据库中,并使用单独的线程读取和写入数据,由于能够直接从源数据库加载数据。今天我们就借助pgloader这款工具实现将MySQL数

    2024年02月13日
    浏览(63)
  • Python 连接 MySQL 数据库

    在实际数据分析和建模过程中,我们通常需要从数据库中读取数据,并将其转化为 Pandas dataframe 对象进行进一步处理。而 MySQL 数据库是最常用的关系型数据库之一,因此在 Python 中如何连接 MySQL 数据库并查询数据成为了一个重要的问题。 本文将介绍两种方法来连接 MySQL 数据

    2024年02月16日
    浏览(52)
  • C++连接mysql数据库

    目录 一、准备 二、读取数据 三、修改数据 参考博客 mysql安装及操作 首先在本地下载mysql数据库,或者使用在线数据库,在数据库中创建一个表,往表里填入数据,不然无法读取到数据。运行代码前,将libmysql的静态库和动态库拷贝到代码路径,c++工程的包含路径配置成mys

    2024年02月15日
    浏览(50)
  • c++ 连接mysql数据库

            使用vs2019对window11中的数据库进行连接 1. 配置连接环境         首先需要把mysql中的头文件和库文件放入到c++项目工程中 1.打开安装MySQL的目录,在windows系统中如果是默认路径,应该和我的是一样的:C:Program FilesMySQLMySQL Server 8.0 2.找到include,和lib文件,inclu

    2024年02月02日
    浏览(49)
  • scala连接mysql数据库

    scala中通常是通过JDBC组件来连接Mysql。JDBC, 全称为Java DataBase Connectivity standard。 加载依赖 其中包含 JDBC driver 1.1 spark组件直接连接(推荐) 通过spark.read直接连接,直接得到dataframe 注意:driver的类名根据不同的JDBC版本不同,早一些的版本为 com.mysql.jdbc ,而不是 com.mysql.cj.jdbc

    2024年02月13日
    浏览(39)
  • Java连接mysql数据库

    java连接mysql大致需要这六步: 导入驱动包 :这里我使用的是mysql-connector-java-8.0.17.jar( 点击下载 ),这个包连接mysql5.6,5.7,8.0版本都没问题。 Class.forName(\\\"com.mysql.cj.jdbc.Driver\\\"); url和账户名密码 JDBC连接串: jdbc:mysql://地址:端口/数据库 获取连接 : DriverManager.getConnection(url, user

    2024年02月02日
    浏览(50)
  • Mysql查询数据库连接状态及连接信息

    使用MySQL时,需要了解当前数据库的情况,例如当前的数据库大小、字符集、用户等等。下面总结了一些查看数据库相关信息的命令 查看显示所有数据库 查看当前使用的数据库 查看数据库使用端口 查看当前数据库大小 例如,我要查看INVOICE数据库的大小,那么可以通过下面

    2024年02月11日
    浏览(57)
  • MySQL数据库,JDBC连接数据库操作流程详细介绍

    在学完 MySQL 和 Java 后,我们通常会尝试使用 Java编译器 连接 MySQL数据库,从而达到使用编译器来操作数据库的效果。连接的这个过程会用 JDBC 相关知识,因此我把 JDBC 包的下载及导入流程,以及 JDBC 的使用流程整理下来分享给大家。 目录 1. 啥是JDBC? 2. JDBC依赖包 2.1 依赖包

    2024年02月06日
    浏览(104)
  • 使用python连接mysql数据库

    第一章 Python 机器学习入门之连接mysql数据库 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。 在控制台输入如下: 代码如下(示例): 演示

    2024年02月16日
    浏览(69)
  • Django的mysql数据库连接

    首先Mysql和navicate Premuim 已经安装好,并且可以建立数据库的连接,本次需使用的工具是 1、vs code 2、navicate Premuim 3、Mysql 打开vs code ,按Ctrl+ Shift + ~ ,调出vs code的终端界面,输入以下命令创建 test11 项目  django-admin startproject test11 (1)创建虚拟环境命令: 需要跳转到项目test1

    2024年02月05日
    浏览(61)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包