zoukankan      html  css  js  c++  java
  • php链接mysql数据库

            php连接数据库有三种方法,刚刚发现通过mysql_connect,mysql_query连接已被废弃,而现在推荐的是通过“面向对象方法”和“PDO方法”连接数据库。

            而我在使用面向对象的方法连接时,查询出来的结果中文无法显示,网上给的大部分解决办法都是针对老式连接方法的解决办法,不过最终还是找到了解决办法。

            大体的连接方法如下:

    <?php
    header("Content-type: text/html; charset=utf-8");
    $mysql_url="localhost";//数据库服务器的地址
    $mysql_username="";//数据库用户名的名称
    $mysql_password="";//连接数据库的密码
    $mysql_database="";//数据库的名字
    $db=new mysqli($mysql_url,$mysql_username,$mysql_password,$mysql_database);
    if(mysqli_connect_error()){//数据库连接失败时提示
    echo 'Could not connect to database.';
    exit;
    }
    mysqli_query($db,'set names utf8');//给查询结果设置编码
    $result=$db->query("SELECT * FROM yc_brand");//此处sql语句表面不能加单引号或双引号
    $all=$result->fetch_all();//获取结果集中的所有数据var_dump($all);
    ?>

            其中查询结果是一个对象 $result,因为是对象,所以没法直接打印使用。

            我们可以调用该对象的方法来将其转换为数组等表现形式。

            比较常用的有fetch_row,fetch_array,fetch_all


    一、fetch_row()

    $row = $result->fetch_row()

    此方法得到的$row是一个一维数组,每次只会得到一组“记录”,即:如果你查出来的应该是10组记录,而他每次只会返回给你一组记录。

    需要用一个while循环将每次查询出来的一维数组再装到一个一维数组中,形成一个二维数组(如装有10组记录的二维数组)。

    这种方法的特点是:查询出来的一维数组内的键名默认为从0开始的数字

    $rows= array();//建立一个数组用来装查询结果
    while($row = $result->fetch_row()){//只要能查到结果就执行
    $rows[] = $row;//将每次查的结果装到之前定义的数组
    }
    var_dump($rows);
    


    二、fetch_array()

    $row = $result->fetch_array()

    此方法总体与fetch_row相同,他们两的不同之处在于,fetch_array()查出来的一维数组中里面每一列有两个键值名,原表的列名会自动成为各个键值名,而也会拥有从0开始自动排序的键值名


    三、fetch_all()

    $rows = $result ->fetch_all();

    此方法得出来得$rows为一个二维数组,其实“就相当于fetch_row方法已经循环完存完一维数组的二维数组$rows”,可以直接打印。

  • 相关阅读:
    【完结】php+MySQL实战案例【九】总结及源码分享
    php+MySQL实战案例【八】用户注册
    php+MySQL实战案例【七】数据编辑、删除
    php+MySQL实战案例【六】数据分页查询
    php+MySQL实战案例【五】新增用户
    php+MySQL实战案例【四】管理员登录
    php+MySQL实战案例【三】数据表设计
    php+MySQL实战案例【二】php数据库辅助类
    5700清空所有配置的方法
    华为设备默认console密码
  • 原文地址:https://www.cnblogs.com/red-code/p/5288647.html
Copyright © 2011-2022 走看看