$db = new MySQLi("localhost","root","123","php0307");

!mysqli_connect_error() or die("连接错误");

$db->query("set names utf8");

Php使用mysqli_result类处理结果集有以下几种方法

fetch_all()

抓取所有的结果行并且以关联数据,数值索引数组,或者两者皆有的方式返回结果集。

fetch_array()

以一个关联数组,数值索引数组,或者两者皆有的方式抓取一行结果。

fetch_object()

以对象返回结果集的当前行。

fetch_row()

以枚举数组方式返回一行结果

fetch_assoc()

以一个关联数组方式抓取一行结果。

fetch_field_direct()

以对象返回结果集中单字段的元数据。

fetch_field()

以对象返回结果集中的列信息。

fetch_fields()

以对象数组返回代表结果集中的列信息。

fetch_all (从结果集中取得所有行作为关联数组)

  $sql="select * from user";

  $result=$link->query($sql);

  $row=$result->fetch_all(MYSQLI_BOTH);//参数MYSQL_ASSOC、MYSQLI_NUM、MYSQLI_BOTH规定产生数组类型

  $n=0;

  while($n<mysqli_num_rows($result)){

   echo "ID:".$row[$n]["id"]."用户名:".$row[$n]["name"]."密码:".$row[$n]["password"]."<br />";

   $n++;

  }

fetch_array

(以一个关联数组,数值索引数组,或者两者皆有的方式抓取一行结果)

 $sql="select * from user";

        $result=$link->query($sql);

        while($row=$result->fetch_array()){

            echo "ID:".$row["id"]."用户名:".$row[1]."密码:".$row["password"]."<br />";

        }//fetch_array方法不再有结果时返回返回NULL
//其返回结果可以是关联数组也可以是数值数组索引,故$row["id"]、$row[1]都可

fetch_object (以对象返回结果集的当前行)

  $sql="select * from user";

        $result=$link->query($sql);

        while($row=$result->fetch_object()){

            echo "ID:".$row->id."用户名:".$row->name."密码:".$row->password."<br />";

        }//如果无更多的行则返回NULL//返回的结果是对象,要以对象的方式调用

fetch_row (以枚举数组方式返回一行结果

 $sql="select * from user";

        $result=$link->query($sql);

        while($row=$result->fetch_row()){

            echo "ID:".$row[0]."用户名:".$row[1]."密码:".$row[2]."<br />";

        }//无更多行时返回NULL

//以数值下标调用数组,a[0]正确、a["id"]则不

fetch_assoc (以一个关联数组方式抓取一行结果)

 $sql="select * from user";

        $result=$link->query($sql);

        while($row=$result->fetch_assoc()){

            echo "ID:".$row["id"]."用户名:".$row["name"]."密码:".$row["password"]."<br />";

        }//无更多行时返回NULL

//以关联索引访问数组,a["id"]正确、a[0]则不

fetch_field_direct (以对象返回结果集中单字段的元数据既单列的信息)

 $sql="select * from user";

        $result=$link->query($sql);

        $n=0;

        while(1){

            if(!$row=$result->fetch_field_direct($n++)) break;

            echo "列名:".$row->name."所在表:".$row->table."数据类型:".$row->type."<br />";

        }//fetch_field_direct($n)只返回单个列,所以得不断调用该方法,没有该列时返回false

fetch_field (以对象返回结果集中的列信息)

  $sql="select * from user";

        $result=$link->query($sql);

        while($row=$result->fetch_field()){

            echo "列名:".$row->name."所在表:".$row->table."数据类型:".$row->type."<br />";

        }//该方法检索所有的列

//以对象方式返回列信息

//返回对象属性如:name - 列名,table - 该列所在的表名,type - 该列的类型,等

fetch_fields (以对象数组返回代表结果集中的列信息)

 $sql="select * from user";

        $result=$link->query($sql);

        $row=$result->fetch_fields();

        foreach($row as $val){

            echo "列名:".$val->name."所在表:".$val->table."数据类型:".$val->type."<br />";

        }//该方法功能与目的fetch_field一样

//不一样的是该方法返回一个对象数组(如:echo $row[0]->name;输出第一列的名字),而不是一次检索一列

另:mysqli_result类还有其他方法

field_tell()

返回字段指针的位置

data_seek()

调整结果指针到结果集中的一个任意行

num_fields()

返回结果集中的字段数(列数)

field_seek()

调整字段指针到特定的字段开始位置

free()

释放与某个结果集相关的内存

fetch_lengths()

返回结果集中当前行的列长度

num_rows()

返回结果集中的行数

PHP 数据库连接的更多相关文章

  1. Java数据库连接技术——JDBC

    大家好,今天我们学习了Java如何连接数据库.之前学过.net语言的数据库操作,感觉就是一通百通,大同小异. JDBC是Java数据库连接技术的简称,提供连接各种常用数据库的能力. JDBC API ...

  2. .NET跨平台之旅:数据库连接字符串写法引发的问题

    最近在一个ASP.NET Core站点中遇到一个奇怪问题.当用dotnet run命令启动站点后,开始的一段时间请求执行速度超慢,有时要超过20秒,有时甚至超过1分钟,日志中会记录这样的错误: Sys ...

  3. Entity Framework 6 Recipes 2nd Edition(12-3)译 -> 数据库连接日志

    12-3. 数据库连接日志 问题 你想为每次与数据库的连接和断开记录日志 解决方案 EF为DbContext的连接公开了一个StateChange 事件.我们需要处理这个事件, 为每次与数据库的连接和 ...

  4. 如何修复VUM在客户端启用之后报数据库连接失败的问题

    在上一篇随笔中介绍了关于重新注册VMware Update Manager(VUM)至vCenter Server中的方法,最近有朋友反应,原本切换过去好好的更新服务为什么某次使用一下就不灵了? 当时 ...

  5. JDBC_part1_Oracle数据库连接JDBC以及查询语句

    本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! JDBC part1 JDBC概述 jdbc是一种用于 ...

  6. tornado+sqlalchemy+celery,数据库连接消耗在哪里

    随着公司业务的发展,网站的日活数也逐渐增多,以前只需要考虑将所需要的功能实现就行了,当日活越来越大的时候,就需要考虑对服务器的资源使用消耗情况有一个清楚的认知.     最近老是发现数据库的连接数如果 ...

  7. Java第三方数据库连接池库-DBCP-C3P0-Tomcat内置连接池

    连接池原理 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去.我们可以通过设定连接池 ...

  8. Java-加载数据库驱动,取得数据库连接

    在Java中想要进行数据库操作,最重要的两个步骤就是加载数据驱动,然后取得数据库连接. 1.加载 数据库驱动( Class.forName(String className) ): 因为Java是一种 ...

  9. QT数据库连接的几个重要函数的使用及注意事项(原创)

    注:在这里数据库对象等同于数据库连接对象,也就是QSqlDatabase类的对象 QSqlDatabase QSqlDatabase::addDatabase((const QString & ...

  10. jdbc数据库连接过程及驱动加载与设计模式详解

    首先要导入JDBC的jar包:接下来,代码:Class.forName(xxx.xx.xx)返回的是一个类 Class.forName(xxx.xx.xx)的作用是要求JVM查找并加载指定的类, 也就 ...

随机推荐

  1. git 导出远程特定分之

    很多时候,git clone 只是 clone 下来了 master 分支,如果想 clone 特定分支.有的时候不知如何是好. 找到了如下的命令,记录一下.以便有需要的同学可以使用. git co ...

  2. coturn编译运行在Windows平台

    turn 编译安装到Windows平台 https://www.webrtc-experiment.com/docs/TURN-server-installation-guide.html#windo ...

  3. 微信小程序 图片设置为圆形

    要图片圆形显示,需要设置border-radius:50%,还要设置overflow:hidden,具体如下: Tip:user-avatar是图片控件的class .user-avatar { wi ...

  4. Chrome 浏览器中查看 webSocket 连接信息

      1.以下代码实现一个webSocket连接,在文本输入框中输入内容,点击发送,通过服务器,返回相同的内容显示在下方. 1 <!DOCTYPE html> 2 <html lang ...

  5. FLUENT求解传热系数surfaceheattransfercoef.的参考值的设置【转载】

    转载自:http://blog.sina.com.cn/s/blog_7ef78d170101ch30.html surface heat transfer coef. 计算公式: FLUENT求解传 ...

  6. gitconfig别名配置

    vim ~/.gitconfig 进行配置 [user] name = Your Name email = you@yourdomain.example.com [core] editor = vim ...

  7. MGI数据库挖掘 | MGI-Mouse Genome Informatics | InWeb database

    做生物信息,遗传发育,分析数据的时候总是要narrow down分析范围,高通量数据尤其是基因表达,在庞大的confounder面前,缩小分析范围是必须的,否则你会一直在混沌中游荡. 看一篇文章:20 ...

  8. (信贷风控九)行为评分卡模型python实现

    python信用评分卡建模(附代码,博主录制) https://study.163.com/course/introduction.htm?courseId=1005214003&utm_ca ...

  9. Composer 安装 Jira API 库

    环境要求: PHP >= 5.5.9 php JsonMapper phpdotenv 安装 下载安装 Composer curl -sS https://getcomposer.org/ins ...

  10. springboot mybatis的pagehelper分页

    maven repositary里,分页组件常用的有两个 com.github.pagehelper » pagehelper-spring-boot-starter  com.github.page ...