Php MYSQL到sqlsrv
正在将mysql php代码转换为sqlsrv,但在查找相同的函数时遇到问题 代码如下:Php MYSQL到sqlsrv,php,mysql,sql,sql-server,sqlsrv,Php,Mysql,Sql,Sql Server,Sqlsrv,正在将mysql php代码转换为sqlsrv,但在查找相同的函数时遇到问题 代码如下: $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("C
$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";
}
$result=sqlsrv_query($conn,$sql)或die(“无法执行查询:
”.sqlsrv_error()。“
”.sqlsrv_errno());
$file_ending=“xls”;
$reals=array();
//浏览器的标题信息
标题(“内容类型:应用程序/xls”);
标题(“内容处置:附件;文件名=$filename.xls”);
标题(“杂注:无缓存”);
标题(“到期日:0”);
/*******Excel格式设置的开始******/
//定义分隔符(定义excel中的列和word中的选项卡)
$sep=“\t”//制表符
//开始将列名打印为MySQL字段的名称
/*对于($i=0;$i 对于($j=0;$jsqlsrv\u field\u metadata()
可以提供您需要的信息,请参阅
类型应该是7(SQL_REAL)表示实数,或者是6(SQL_FLOAT)表示浮点数。我是一名ASP.Net开发人员,对PHP知之甚少。下面的内容可能对您有用。只需检查一次
$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++;
}
在发布到这里之前,我没有运行过它,如果它不起作用,请告诉我。您能告诉我如何在我的案例中使用sqlsrv_field_元数据吗?我已经消除了错误,但是excel文档只包含一个0值的单元格。@user3270211,您能详细说明一下您的问题吗?我已经粘贴了全部代码在编辑中。这是excel包含的内容:
$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++;
}