• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    PHP5.5基于mysqli连接MySQL数据库和读取数据操作实例详解

    本文实例讲述了PHP5.5基于mysqli连接MySQL数据库和读取数据操作。分享给大家供大家参考,具体如下:

    在学习1. 开启PHP的API支持

    (1)首先修改您的php.ini的配置文件。

    查找下面的语句:

    ;extension=php_mysqli.dll
    
    

    将其修改为:

    extension=php_mysqli.dll
    
    

    (2)重新启动Apache/IIS,即可。

    (3)说明:PHP需要单独的文件来支持这个扩展库,一般在PHP目录下的ext目录里能找到php_mysqli.dll文件(PHP = 5.0.2 中是 libmysqli.dll),当然,在PHP的配置文件当中要有正确指向ext的信息(extension_dir)。假若您的PHP没有这个文件,您可以去下载PHP5的源码包。另外,这个API扩展,只能在PHP5以上版本使用。其它具体信息,请看下面。

    2.PHP mysqli身份证

    mysqli是“MySQL, Improved”的缩写,该扩展仅适用于PHP 5。它能用于MySQL 4.1.1和更高版本。该扩展完全支持MySQL 5.1中采用的鉴定协议,也支持预处理语句和多语句API。此外,该扩展还提供了先进的、面向对象的编程接口

    ?php
      /* Connect to a MySQL server 连接数据库服务器 */
      $link = mysqli_connect(
            'localhost', /* The host to connect to 连接MySQL地址 */
            'user',   /* The user to connect as 连接MySQL用户名 */
            'password', /* The password to use 连接MySQL密码 */
            'world');  /* The default database to query 连接数据库名称*/
      if (!$link) {
        printf("Can't connect to MySQL Server. Errorcode: %s ", mysqli_connect_error());
        exit;
      }
      /* Send a query to the server 向服务器发送查询请求*/
      if ($result = mysqli_query($link, 'SELECT Name, Population FROM City ORDER BY Population DESC LIMIT 5')) {
        //print("Very large cities are: ");
        /* Fetch the results of the query 返回查询的结果 */
        while( $row = mysqli_fetch_assoc($result) ){
          printf("%s (%s) ", $row['Name'], $row['Population']);
        }
        /* Destroy the result set and free the memory used for it 结束查询释放内存 */
        mysqli_free_result($result);
      }
      /* Close the connection 关闭连接*/
      mysqli_close($link);
    ?>
    
    

    使用 MySQLi

    以下实例中我们从 myDB 数据库的 MyGuests 表读取了 id, firstname 和 lastname 列的数据并显示在页面上:

    ?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";
    // 创建连接
    $conn = new mysqli($servername, $username, $password, $dbname);
    // Check connection
    if ($conn->connect_error) {
      die("连接失败: " . $conn->connect_error);
    }
    $sql = "SELECT id, firstname, lastname FROM MyGuests";
    $result = $conn->query($sql);
    if ($result->num_rows > 0) {
      // 输出数据
      while($row = $result->fetch_assoc()) {
        echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "br>";
      }
    } else {
      echo "0 结果";
    }
    $conn->close();
    ?>
    
    

    以上代码解析如下:

    首先,我们设置了 SQL 语句从 MyGuests数据表中读取 id, firstname 和 lastname 三个字段。之后我们使用改 SQL 语句从数据库中取出结果集并赋给复制给变量 $result。

    函数 num_rows() 判断返回的数据。

    如果返回的是多条数据,函数 fetch_assoc() 将结合集放入到关联数组并循环输出。 while() 循环出结果集,并输出 id, firstname 和 lastname 三个字段值。

    以下实例使用 MySQLi 面向过程的方式,效果类似以上代码:

    实例 (MySQLi - 面向过程)

    ?php
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDB";
    // 创建连接
    $conn = mysqli_connect($servername, $username, $password, $dbname);
    // Check connection
    if (!$conn) {
      die("连接失败: " . mysqli_connect_error());
    }
    $sql = "SELECT id, firstname, lastname FROM MyGuests";
    $result = mysqli_query($conn, $sql);
    if (mysqli_num_rows($result) > 0) {
      // 输出数据
      while($row = mysqli_fetch_assoc($result)) {
        echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "br>";
      }
    } else {
      echo "0 结果";
    }
    mysqli_close($conn);
    ?>
    
    

    使用 PDO (+ 预处理)

    以下实例使用了预处理语句。

    选取了 MyGuests 表中的 id, firstname 和 lastname 字段,并放到 HTML 表格中:

    ?php
    echo "table style='border: solid 1px black;'>";
    echo "tr>th>Id/th>th>Firstname/th>th>Lastname/th>/tr>";
    class TableRows extends RecursiveIteratorIterator {
      function __construct($it) {
        parent::__construct($it, self::LEAVES_ONLY);
      }
      function current() {
        return "td style='width:150px;border:1px solid black;'>" . parent::current(). "/td>";
      }
      function beginChildren() {
        echo "tr>";
      }
      function endChildren() {
        echo "/tr>" . "\n";
      }
    }
    $servername = "localhost";
    $username = "username";
    $password = "password";
    $dbname = "myDBPDO";
    try {
      $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
      $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
      $stmt = $conn->prepare("SELECT id, firstname, lastname FROM MyGuests");
      $stmt->execute();
      // 设置结果集为关联数组
      $result = $stmt->setFetchMode(PDO::FETCH_ASSOC);
      foreach(new TableRows(new RecursiveArrayIterator($stmt->fetchAll())) as $k=>$v) {
        echo $v;
      }
    }
    catch(PDOException $e) {
      echo "Error: " . $e->getMessage();
    }
    $conn = null;
    echo "/table>";
    ?>
    
    

    更多关于PHP相关内容感兴趣的读者可查看本站专题:《php+mysqli数据库程序设计技巧总结》、《php面向对象程序设计入门教程》、《PHP数组(Array)操作技巧大全》、《PHP基本语法入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

    希望本文所述对大家PHP程序设计有所帮助。

    您可能感兴趣的文章:
    • 解决php用mysql方式连接数据库出现Deprecated报错问题
    • PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】
    • php连接mysql数据库最简单的实现方法
    • PHP连接MySQL数据库并以json格式输出
    • javascript连接mysql与php通过odbc连接任意数据库的实例
    • PHP基于MySQLI函数封装的数据库连接工具类【定义与用法】
    • PHP连接MYSQL数据库的3种常用方法
    • PHP使用mysql与mysqli连接Mysql数据库用法示例
    • PHP连接MySQL数据库三种实现方法
    上一篇:PHP封装的mysqli数据库操作类示例
    下一篇:PHP get_html_translation_table()函数用法讲解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    PHP5.5基于mysqli连接MySQL数据库和读取数据操作实例详解 PHP5.5,基于,mysqli,连接,MySQL,