MSSQLSERVER_4186
詳細
製品名 |
SQL Server |
製品バージョン |
11.0 |
製品ビルド番号 |
|
イベント ID |
4186 |
イベント ソース |
MSSQLSERVER |
コンポーネント |
SQLEngine |
シンボル名 |
|
メッセージ テキスト |
列 '%ls. %.*ls' は、OUTPUT 句で参照できません。列定義にサブクエリが含まれているか、列定義でユーザー データまたはシステム データにアクセスする関数を参照しています。 関数は、スキーマ バインドされていない場合、既定でデータ アクセスを実行するように想定されています。 列定義からサブクエリまたは関数を削除するか、OUTPUT 句から列を削除することを検討してください。 |
説明
非決定的な動作を防ぐために、ビューまたはインライン テーブル値関数から返される列が次のいずれかの方法で定義されている場合、OUTPUT 句ではその列を参照できません。
サブクエリ
ユーザー データやシステム データにアクセスするユーザー定義関数、またはそのようなアクセスを行うと想定されるユーザー定義関数
ユーザー データやシステム データにアクセスするユーザー定義関数を定義に含む計算列
使用例
サブクエリで定義されたビュー列
次の例では、選択リストでサブクエリを使用して State 列を定義するビューを作成します。 次に、UPDATE ステートメントで OUTPUT 句の State 列を参照すると、選択リストのサブクエリが原因でエラーが発生します。
USE AdventureWorks2012;
GO
CREATE VIEW dbo.V1
AS
SELECT City,
-- subquery to return the State name
(SELECT Name FROM Person.StateProvince AS sp
WHERE sp.StateProvinceID = a.StateProvinceID) AS State
FROM Person.Address AS a;
GO
--Reference the State column in the OUTPUT clause of an UPDATE statement
UPDATE dbo.V1
SET City = City + 'Test'
OUTPUT deleted.City, deleted.State, inserted.City, inserted.State
WHERE State = 'Texas';
GO
関数で定義されたビュー列
次の例では、データにアクセスするスカラー関数 dbo.ufnGetStock を選択リストで使用して CurrentInventory 列を定義するビューを作成します。 次に、UPDATE ステートメントで OUTPUT 句の CurrentInventory 列を参照します。
USE AdventureWorks2012;
GO
CREATE VIEW Production.ReorderLevels
AS
SELECT ProductID, ProductModelID, ReorderPoint,
dbo.ufnGetStock(ProductID) AS CurrentInventory
FROM Production.Product;
GO
UPDATE Production.ReorderLevels
SET ReorderPoint += CurrentInventory
OUTPUT deleted.ReorderPoint, deleted.CurrentInventory,
inserted.ReorderPoint, inserted.CurrentInventory
WHERE ProductModelID BETWEEN 75 and 80;
ユーザーのアクション
エラー 4186 は、次のいずれかの方法で解決できます。
サブクエリの代わりに結合を使用して、ビューまたは関数の列を定義します。 たとえば、dbo.V1 ビューは次のように作成し直すことができます。
USE AdventureWorks2012; GO CREATE VIEW dbo.V1 AS SELECT City, sp.Name AS State FROM Person.Address AS a JOIN Person.StateProvince AS sp ON sp.StateProvinceID = a.StateProvinceID;
ユーザー定義関数の定義を調べます。 関数でユーザー データまたはシステム データにアクセスしない場合は、WITH SCHEMABINDING 句を含めるように関数を変更します。
OUTPUT 句から列を削除します。