Procedura: Recuperare i tipi di data e ora come stringhe usando il driver SQLSRV
Quando si usa il driver SQLSRV per i driver Microsoft per PHP per SQL Server, è possibile recuperare i tipi di data e ora (smalldatetime, datetime, date, time, datetime2 e datetimeoffset) come stringhe specificando l'opzione seguente nella stringa di connessione o a livello di istruzione:
'ReturnDatesAsStrings'=>true
Il valore predefinito è false, vale a dire che i tipi smalldatetime, datetime, date, time, datetime2 e datetimeoffset verranno restituiti come oggetti DateTime PHP. Se questa opzione è impostata a livello di istruzione, esegue l'override dell'impostazione a livello di connessione.
Per impostazione predefinita, il driver PDO_SQLSRV restituisce i tipi di data e ora come stringhe. Per riprenderli come oggetti DateTime PHP, vedere Come fare a…: recuperare i tipi di data e ora come oggetti Datetime PHP usando PDO_SQLSRV
Esempio 1
L'esempio seguente illustra la sintassi per specificare il recupero dei tipi di data e ora come stringhe.
<?php
$serverName = "MyServer";
$connectionInfo = array("Database"=>"AdventureWorks", 'ReturnDatesAsStrings'=> true);
$conn = sqlsrv_connect($serverName, $connectionInfo);
if ($conn === false) {
echo "Could not connect.\n";
die(print_r(sqlsrv_errors(), true));
}
sqlsrv_close($conn);
?>
Esempio 2
L'esempio seguente illustra che è possibile recuperare le date come stringhe specificando UTF-8 in fase di recupero della stringa, anche quando la connessione è stata stabilita con "ReturnDatesAsStrings" => false
.
<?php
$serverName = "MyServer";
$connectionInfo = array("Database"=>"AdventureWorks", "ReturnDatesAsStrings" => false);
$conn = sqlsrv_connect($serverName, $connectionInfo);
if ($conn === false) {
echo "Could not connect.\n";
die(print_r(sqlsrv_errors(), true));
}
$tsql = "SELECT VersionDate FROM AWBuildVersion";
$stmt = sqlsrv_query($conn, $tsql);
if ($stmt === false) {
echo "Error in statement preparation/execution.\n";
die(print_r(sqlsrv_errors(), true));
}
sqlsrv_fetch($stmt);
// retrieve date as string
$date = sqlsrv_get_field($stmt, 0, SQLSRV_PHPTYPE_STRING("UTF-8"));
if ($date === false) {
die(print_r(sqlsrv_errors(), true));
}
echo $date;
sqlsrv_close($conn);
?>
Esempio 3
L'esempio seguente illustra come recuperare le date come stringhe specificando UTF-8 e "ReturnDatesAsStrings" => true
nella stringa di connessione.
<?php
$serverName = "MyServer";
$connectionInfo = array("Database"=>"AdventureWorks", 'ReturnDatesAsStrings'=> true, "CharacterSet" => 'utf-8');
$conn = sqlsrv_connect($serverName, $connectionInfo);
if ($conn === false) {
echo "Could not connect.\n";
die(print_r(sqlsrv_errors(), true));
}
$tsql = "SELECT VersionDate FROM AWBuildVersion";
$stmt = sqlsrv_query($conn, $tsql);
if ($stmt === false) {
echo "Error in statement preparation/execution.\n";
die(print_r(sqlsrv_errors(), true));
}
sqlsrv_fetch($stmt);
// retrieve date as string
$date = sqlsrv_get_field($stmt, 0);
if ($date === false) {
die(print_r(sqlsrv_errors(), true));
}
echo $date;
sqlsrv_close($conn);
?>
Esempio 4
L'esempio seguente illustra come recuperare la data come tipo PHP. 'ReturnDatesAsStrings'=> false
è attivato per impostazione predefinita.
<?php
$serverName = "MyServer";
$connectionInfo = array("Database"=>"AdventureWorks");
$conn = sqlsrv_connect($serverName, $connectionInfo);
if ($conn === false) {
echo "Could not connect.\n";
die(print_r(sqlsrv_errors(), true));
}
$tsql = "SELECT VersionDate FROM AWBuildVersion";
$stmt = sqlsrv_query($conn, $tsql);
if ($stmt === false) {
echo "Error in statement preparation/execution.\n";
die(print_r(sqlsrv_errors(), true));
}
sqlsrv_fetch($stmt);
// retrieve date as a DateTime object, then convert to string using PHP's date_format function
$date = sqlsrv_get_field($stmt, 0);
if ($date === false) {
die(print_r(sqlsrv_errors(), true));
}
$date_string = date_format($date, 'jS, F Y');
echo "Date = $date_string\n";
sqlsrv_close($conn);
?>
Esempio 5
L'opzione ReturnDatesAsStrings a livello di istruzione esegue l'override dell'opzione di connessione corrispondente.
<?php
$serverName = 'MyServer';
$connectionInfo = array('Database' => 'MyDatabase', 'ReturnDatesAsStrings' => false);
$conn = sqlsrv_connect($serverName, $connectionInfo);
if ($conn === false) {
echo "Could not connect.\n";
die(print_r(sqlsrv_errors(), true));
}
$tableName = 'MyTable';
$options = array('ReturnDatesAsStrings' => true);
$query = "SELECT DateTimeCol FROM $tableName";
$stmt = sqlsrv_prepare($conn, $query, array(), $options);
if ($stmt === false) {
echo "Error in statement preparation/execution.\n";
die(print_r(sqlsrv_errors(), true));
}
sqlsrv_execute($stmt);
// Expect the fetched value to be a string
$field = sqlsrv_get_field($stmt, 0);
echo $field . PHP_EOL;
sqlsrv_close($conn);
?>
Vedi anche
Procedura: Recuperare i tipi di data e ora come oggetti Datetime PHP usando PDO_SQLSRV