2014-07-01 50 views
0

我有一個工作配置: TestLink 1.9.10 + PHP 5.4 + IIS 7 + MSSQL服務器2008 R2 UTF8數據以錯誤的編碼插入到數據庫中。 另外我使用SQLSRV和PDO_SQLSRV 3.0.1版本 試圖將varchar更改爲nvarchar DBfield類型。沒有結果。 任何想法?MSSQL服務器2008 R2無法以UTF-8格式存儲數據

回答

1
Hi putting "N" prefix for each string value like: 
insert into table(col1,col2) values(N'value1',N'value2'); 

and example of PHP: 

<?php 
//Returns records with Id#46 or first name starting with 'Mary' 

$server = '127.0.0.1'; 
$link = mssql_connect($server, 'sql_user', 'sql_user_pass'); 

//Select DB 
$dbn = 'dbName'; 
mssql_select_db($dbn); 

//input variables 
$name='Mary%'; 
$id=46; 

//necesssary for stored procedure 
$params="@name varchar(50),@id int"; 
$paramslist="@name='$name%',@id='$id'"; 

$sql = "select FirstName,LastName,EmpId from employees where FirstName like @name or EmpId = @id " ; 

$dbsql = "EXEC sp_executesql 
      N'$sql', 
      N'$params', 
      $paramslist"; 

//important to have the "N'" ! 

$result=mssql_query($dbsql,$link); 
?> 
+0

它有助於將UTF8數據手動插入數據庫。但是這個解決方案並不適合我。因爲我無法更改整個應用程序的php代碼。不過謝謝你的幫助。 我發現了我的問題的另一個解決方案: 我將字符集從UTF8更改爲WINDOWS-1251。 所以它有幫助。 –

相關問題