首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将$intNumField = mysql_num_fields($objQuery);转换为面向对象的Php

如何将$intNumField = mysql_num_fields($objQuery);转换为面向对象的Php
EN

Stack Overflow用户
提问于 2015-02-19 14:49:58
回答 1查看 168关注 0票数 0

如何在下面的代码中将mysql_num_fields()转换成面向对象的php。

代码语言:javascript
复制
 $objConnect = mysql_connect("localhost","root","john123");
        $objDB = mysql_select_db("mydatabase");
        $strSQL = "SELECT * FROM `cman_tickets`";
        print_r($strSQL);
        //$strSQL = "SELECT * FROM `cman_tickets`";
        $objQuery = mysql_query($strSQL);
        $intNumField = mysql_num_fields($objQuery);
        $resultArray = array();
        while($obResult = mysql_fetch_array($objQuery))
        {
        $arrCol = array();
        for($i=0;$i<$intNumField;$i++)
        {
                $arrCol[mysql_field_name($objQuery,$i)] = $obResult[$i];
        }
        array_push($resultArray,$arrCol);
        }

        mysql_close($objConnect);

        echo json_encode($resultArray);
EN

回答 1

Stack Overflow用户

发布于 2015-02-19 14:59:46

要使用面向对象的php,你必须使用mysqli而不是mysql。

代码语言:javascript
复制
mysql_num_fields() 

可以替换为

代码语言:javascript
复制
mysqli_result::$field_count

由于mysql_*函数已被弃用,因此最好避免这种情况

代码语言:javascript
复制
    $objConnect =  new mysqli("localhost","root","john123","mydatabase");
    $strSQL = "SELECT * FROM `cman_tickets`";
    print_r($strSQL);

    $objQuery = $objConnect->query($strSQL);
    $intNumField = $objQuery->field_count; // to get the field count
    $resultArray = array();

    while($obResult = $objQuery->fetch_array())
    {

        $arrCol = array();
        for($i=0;$i<$intNumField;$i++)
        {
            $arrCol[$objQuery->fetch_field_direct($i)] = $obResult[$i];
         }
         array_push($resultArray,$arrCol);
    }

    echo json_encode($resultArray);
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28600226

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档