4

SqlDependency でこの SQL ステートメントを使用すると問題が発生します。SqlDependency.OnChange イベントをアクティブにするのではなく、SQL Server クエリ ウィンドウで期待どおりの結果を返します。

SELECT [Order].OrderId
FROM [dbo].[Order]
WHERE [Order].CreatedOn > '20150815 21:11:57.502'

https://technet.microsoft.com/en-us/library/ms181122(v=sql.105).aspxのサポートされている SELECT ステートメントのセクションを読みましたが、違反しているルールは見つかりませんでした。

何か案は?

アップデート:

以下の私の完全なコード:

    private void CheckForNewOrders(DateTime dt)
    {
        string json = null;
        string conStr = ConfigurationManager.ConnectionStrings["connstring"].ConnectionString;

        using (SqlConnection connection = new SqlConnection(conStr))
        {
            string query = string.Format(@"
                    SELECT [Order].OrderId
                    FROM [dbo].[Order]
                    WHERE [Order].CreatedOn > '{0}'"
, dt.ToString("yyyyMMdd HH:mm:ss.fff"));  // 20150814 00:00:00.000

            using (SqlCommand command = new SqlCommand(query, connection))
            {
                command.Notification = null;
                SqlDependency dependency = new SqlDependency(command);
                dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);
                connection.Open();
                SqlDataReader reader = command.ExecuteReader();

                if (reader.HasRows)
                {
                    reader.Read();
                    json = "testing ... "; reader[0].ToString();
                }
            }
        }
    }

    private void dependency_OnChange(object sender, SqlNotificationEventArgs e)
    {
        if (e.Type == SqlNotificationType.Change)
        {
            CheckForNewOrders(DateTime.Now);
        }
    }

更新(jmeloseguiの回答に応じて):

            query = string.Format(@"
                    SELECT [Order].OrderId
                    FROM [dbo].[Order]
                    WHERE [Order].CreatedOn > @CreatedOn");

...

            using (SqlCommand command = new SqlCommand(query, connection))
            {
                command.Parameters.Add("@CreatedOn", SqlDbType.DateTime);
                command.Parameters["@CreatedOn"].Value = DateTime.Now;

                command.Notification = null;
                SqlDependency dependency = new SqlDependency(command);
                dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);
                connection.Open();
                SqlDataReader reader = command.ExecuteReader();

                if (reader.HasRows)
                {
                ...
                }
            }
4

2 に答える 2

3

そのタイプではなく、通知イベントを取得する必要があると思います。

メソッドにelseブランチを追加して、次のようdependency_OnChangeな他のものを取得しているかどうかを確認できますか?SqlNotificationType

private void dependency_OnChange(object sender, SqlNotificationEventArgs e)
{
    if (e.Type == SqlNotificationType.Change)
    {
        CheckForNewOrders(DateTime.Now);
    }
    else
    {
        //Do somthing here
        Console.WriteLine(e.Type);
    }
}

アップデート

型付きパラメータを追加してみてください:

WHERE [Order].CreatedOn > @myDateTime

文字列変換を使用する代わりに、DateTime 型のパラメーターを渡します。

于 2015-08-15T17:08:51.243 に答える
0

まず、すべての SQL 依存関係サービスの制限を確認してください。SQL テーブルの変更が発生すると、SQL 依存関係イベントで where 句が機能しません。クエリを変更する必要があります。

query = string.Format(@"
                SELECT [Order].OrderId
                FROM [dbo].[Order]
                ORDER BY [dbo].[Order].DateTime desc
        );

これらの変更を適用し、プロジェクトをデバッグしてください。

于 2015-11-16T14:00:28.840 に答える