sql >> Databáze >  >> RDS >> Sqlserver

Při INSERT do tabulky s vypočítaným sloupcem PHP/PDO dojde k chybě serveru SQL 1934

Ukázalo se, že problém měl co do činění s parametry SET. Použil jsem níže uvedený kód získaný z Zde . Chcete-li zjistit, které možnosti byly nastaveny v SQL Server Management Studio (kde vložení fungovalo). Potom umístění každého z nich do souboru exec před mým příkazem vložení způsobilo, že věci znovu fungovaly. Nepotřeboval jsem ponechat všechny možnosti, takže níže uvedu ty, které byly nutné, aby to fungovalo.

DECLARE @options INT
SELECT @options = @@OPTIONS

PRINT @options
IF ( (1 & @options) = 1 ) PRINT 'DISABLE_DEF_CNST_CHK' 
IF ( (2 & @options) = 2 ) PRINT 'IMPLICIT_TRANSACTIONS' 
IF ( (4 & @options) = 4 ) PRINT 'CURSOR_CLOSE_ON_COMMIT' 
IF ( (8 & @options) = 8 ) PRINT 'ANSI_WARNINGS' 
IF ( (16 & @options) = 16 ) PRINT 'ANSI_PADDING' 
IF ( (32 & @options) = 32 ) PRINT 'ANSI_NULLS' 
IF ( (64 & @options) = 64 ) PRINT 'ARITHABORT' 
IF ( (128 & @options) = 128 ) PRINT 'ARITHIGNORE'
IF ( (256 & @options) = 256 ) PRINT 'QUOTED_IDENTIFIER' 
IF ( (512 & @options) = 512 ) PRINT 'NOCOUNT' 
IF ( (1024 & @options) = 1024 ) PRINT 'ANSI_NULL_DFLT_ON' 
IF ( (2048 & @options) = 2048 ) PRINT 'ANSI_NULL_DFLT_OFF' 
IF ( (4096 & @options) = 4096 ) PRINT 'CONCAT_NULL_YIELDS_NULL' 
IF ( (8192 & @options) = 8192 ) PRINT 'NUMERIC_ROUNDABORT' 
IF ( (16384 & @options) = 16384 ) PRINT 'XACT_ABORT'

Zde jsou možnosti, které jsem nakonec potřeboval:

$dbPDO->exec("SET ANSI_WARNINGS ON");                                                                               
$dbPDO->exec("SET ANSI_PADDING ON");
$dbPDO->exec("SET ANSI_NULLS ON");
$dbPDO->exec("SET QUOTED_IDENTIFIER ON");
$dbPDO->exec("SET CONCAT_NULL_YIELDS_NULL ON");

Aktualizace:Zdá se, že omezení FK vedla k následující chybě. Výše uvedené také tuto chybu opravily.



  1. Znaková data nepřecházejí z php do jquery

  2. Optimalizační prahy – seskupování a agregace dat, část 2

  3. Spring JDBC BeanPropertyRowMapper ano ne ('Y','N') na booleovské vlastnosti fazole

  4. Flask-SQLAlchemy kontroluje, zda databázový server reaguje