dsnw2651 2018-07-03 13:19
浏览 55
已采纳

如何从PHP中的mssql DB获取价值

Firstly I got the workers name from BIRTHDAYS and then want to get e-mail address from USERS.There is no problem to take workers name's from Table1 but when I try to get the e-mail addresses the db returns me NULL.My DB is mssql.

<?php
include_once("connect.php");
$today = '05.07';
$today1 = $today . "%";
$sql = "SELECT NAME FROM BIRTHDAYS WHERE BIRTH LIKE '$today1' ";
$stmt = sqlsrv_query($conn,$sql);
if($stmt == false){
    echo "failed";
}else{
   $dizi = array();
   while($rows = sqlsrv_fetch_array($stmt,SQLSRV_FETCH_ASSOC))
   {
    $dizi[] = array('NAME' =>$rows['NAME']);
    $newarray = json_encode($dizi,JSON_UNESCAPED_UNICODE);
   }
 }

    foreach(json_decode($newarray) as $nameObj) 
{
    $nameArr = (array) $nameObj;
    $names = reset($nameArr);
    mb_convert_case($names, MB_CASE_UPPER, 'UTF-8');
    echo $sql2 = "SELECT EMAIL FROM USERS WHERE NAME = '$names' ";
    echo "<br>";
    $stmt2 = sqlsrv_query($conn,$sql2); 
        if($stmt2 == false)
        {
        echo "failed";
        }
        else
        {
        $dizi2 = array();   
        while($rows1 = sqlsrv_fetch_array($stmt2,SQLSRV_FETCH_ASSOC))
        {   
            $dizi1[] = array('EMAIL' =>$rows['EMAIL']);
            echo $newarray1 = json_encode($dizi1,JSON_UNESCAPED_UNICODE);
        }   
    }
}   
?>
  • 写回答

1条回答 默认 最新

  • duandushang5148 2018-07-03 13:46
    关注
     while($rows1 = sqlsrv_fetch_array($stmt2,SQLSRV_FETCH_ASSOC))
            {   
                $dizi1[] = array('EMAIL' =>$rows['EMAIL']);
                echo $newarray1 = json_encode($dizi1,JSON_UNESCAPED_UNICODE);
            } 
    

    you put in $rows1 and would take it from $rows NULL is correct answer :)

    take $rows1['EMAIL'] and it would work

    and why foreach =?

    you can put the statement in while-loop like this:

      while ($rows = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)) {
    
        $names = $rows['NAME'];
        $sql2 = "SELECT EMAIL FROM USERS WHERE NAME = '$names' ";
        echo "<br>";
        $stmt2 = sqlsrv_query($conn, $sql2);
        if ($stmt2 == false) {
            echo "failed";
        } else {
            $dizi2 = array();
            while ($rows1 = sqlsrv_fetch_array($stmt2, SQLSRV_FETCH_ASSOC)) {
                $dizi1[]        = array('EMAIL' => $rows1['EMAIL']);
                echo $newarray1 = json_encode($dizi1, JSON_UNESCAPED_UNICODE);
            }
        }
    
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度