以下是相关代码:
function connect(){
// DB credentials and info defined here....
$connection = odbc_connect("DRIVER={SQL Server Native Client 11.0}; Server=$server; Database=$db;", $loginname, $loginpass);
return $connection;
}
function odbc_fetch_results($stmt, &$results) {
$numrows = odbc_num_rows($stmt);
$row = odbc_fetch_array($stmt);
print_r($row); // Prints: Array ( [MEASUREMENT_UNI] => kg)
if($row){
$results = array ($row);
while( $row = odbc_fetch_array($stmt)){
array_push($results, $row);
}
}
return $numrows;
}
$sql = "select * from measurements where ID=$id";
$stmt = executeSQL($conn,$sql);
$nrows = odbc_fetch_results($stmt, $results);
odbc_free_result($stmt);
print_r($result[0]); // Prints: Array ( [0] => Array ( [MEASUREMENT_UNI] => kg) )
结果应该包含一个名为MEASUREMENT_UNIT的列(当我做一个print_r我可以验证)被截短到MEASUREMENT_UNI,只有15个字符。最后一个字母T被切断。
我也尝试使用SQL Server数据库上不同的表和不同列的查询作为测试,以确保它与我正在使用的特定表或列不是任何奇怪的设置。我验证了与不同的表/列相同的事情:当我运行如上所示的选择查询时,列名称被截断为最多15个字符。
我还尝试了一个select,它指定字段名称,如从ID = $ id而不是select *的测量中选择MEASUREMENT_UNIT,但也不能解决问题。
我在这里看过其他类似的帖子,但他们似乎都表示我应该能够获得至少30个字符,而不是我看到的15个字符的限制。
为什么列名称被截断为15个字符?
编辑:连接到MySQL服务器数据库似乎并没有导致同样的问题。来自MySQL表的DB列名称并没有被截断,这导致我相信这不是ODBC插件的问题。
$connection = odbc_connect("DRIVER={MySQL};Server=$server; Database=$db;", $loginname, $loginpass);
$sql = "select * from measurements where ID=$id";
$stmt = executeSQL($conn,$sql);
$nrows = odbc_fetch_results($stmt, $results);
odbc_free_result($stmt);
print_r($result[0]); // Prints CORRECTLY: Array ( [0] => Array ( [MEASUREMENT_UNIT] => kg) )
请注意,上述两个代码段都在同一个服务器上的相同文件中进行了相同的PHP ODBC安装。