首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MYSQL到sqlsrv

MYSQL到sqlsrv
EN

Stack Overflow用户
提问于 2014-04-22 16:45:18
回答 2查看 1K关注 0票数 0

工作转换我的mysql php代码到sqlsrv,但有问题找到相同的函数。

代码如下:

代码语言:javascript
复制
   $result=sqlsrv_query($conn,$sql) or die("Couldn't execute query:<br>" . sqlsrv_error(). "<br>" . sqlsrv_errno()); 


$file_ending = "xls";
$reals=array();
//header info for browser
header("Content-Type: application/xls");    
header("Content-Disposition: attachment; filename=$filename.xls");  
header("Pragma: no-cache"); 
header("Expires: 0");
/*******Start of Formatting for Excel*******/   
//define separator (defines columns in excel & tabs in word)
$sep = "\t"; //tabbed character

//start of printing column names as names of MySQL fields

/*for ($i = 0; $i < sqlsrv_num_fields($result); $i++) {
    $type = sqlsrv_field_metadata($result,$i);
    echo sqlsrv_field_metadata($result,$i) . "\t";
    if ($type == "real")
    {
        $reals[] = $i;
    }
}
*/
$i=0;
foreach( sqlsrv_field_metadata( $result ) as $fieldMetadata ) {    
       echo $fieldMetadata["Name"]+"\t";
       if($fieldMetadata["Type"]=="real")//$fieldMetadata["Type"]=== SQL_REAL
       {
           $reals[] = $i;
       }
       $i++;
}


print("\n");    
//end of printing column names  
//start while loop to get data
while($row = sqlsrv_num_rows($result))
{
    $schema_insert = "";
    for($j=0; $j<sqlsrv_num_fields($result);$j++)
    {
        if(!isset($row[$j]))
            $schema_insert .= "NULL".$sep;
        elseif ($row[$j] != ""){
            if (in_array($j, $reals)){
                $schema_insert .= str_replace(".",",","$row[$j]").$sep;
            } else {
                $schema_insert .= "$row[$j]".$sep;
            }
        }
        else
            $schema_insert .= "".$sep;
    }
    $schema_insert = str_replace($sep."$", "", $schema_insert);
    $schema_insert = preg_replace("/\r\n|\n\r|\n|\r/", " ", $schema_insert);
    $schema_insert .= "\t";
    print(trim($schema_insert));
    print "\n";

} 

我不确定sqlsrv中的field_type和field_name是什么相等的,但这不起作用:

代码语言:javascript
复制
for ($i = 0; $i < sqlsrv_num_fields($result); $i++) {
    $type = sqlsrv_get_field($result,$i);
    echo sqlsrv_get_field($result,$i) . "\t";
    if ($type == "real")
    {
        $reals[] = $i;
    }
}
EN

回答 2

Stack Overflow用户

发布于 2014-04-25 18:12:55

我是一个ASP.Net开发人员,对PHP了解很少。下面的内容可能会对你有所帮助。只需检查一次。

代码语言:javascript
复制
$stmt = sqlsrv_prepare( $conn, $sql );
$result=sqlsrv_query($conn, $sql);
$i=0;

foreach( sqlsrv_field_metadata( $stmt ) as $fieldMetadata ) {    
       echo $fieldMetadata["Name"]+"\t";
       if($fieldMetadata["Type"]=="real")//$fieldMetadata["Type"]=== SQL_REAL
       {
           $reals[] = $i
       }
       $i++;
}

我在这里发布之前没有运行它,如果它不工作,请让我知道。

票数 1
EN

Stack Overflow用户

发布于 2014-04-23 06:48:44

sqlsrv_field_metadata()可以提供您需要的信息,请参阅Microsofts documentation

类型应为7 (SQL_REAL)表示实数,或6 (SQL_FLOAT)表示float。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23214652

复制
相关文章

相似问题

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