1

ADO.NET エンティティ データ モデルとしてインポートした SQL データベースがあります。次に、Linq を使用して DataGridView を設定します。他のテーブルから計算された追加の列を使用して、2 つのテーブルを拡張しました。たとえば、OrderNumber、DateApproved、RequestorID などのフィールドを持つ Orders テーブルがあります。また、SKU、OrderNUMber、QuantityOrdered などのフィールドを持つ OrderDetails であるテーブルもあります。OrderDetails からのアイテム (SKU) がバックオーダーされているかどうかを計算する Orders テーブルの新しい列 IsBackOrdered をコーディングしました。

テーブル Orders を DataGridView.DataSource にバインドすると、すべてが期待どおりに機能します。次に、テーブルの検索フィルターを作成するように指示されました。

BindingSource を Linq クエリにマップしようとしましたが、BindingSource は DataTable を想定しています。Linq ResultSet を DataTable (以下のコード) に変換するきちんとした小さなメソッドを見つけましたが、次の行でカスタム フィールド (列) をバーフします。DBNull.Value;

あなたが提供したいあなたの意見や有益な洞察を前もって感謝します.

public static DataTable LinqToDataTable<T>(IEnumerable<T> varlist)
        {
            var dtReturn = new DataTable();

            // column names
            PropertyInfo[] oProps = null;

            if (varlist == null)
                return dtReturn;

            foreach (T rec in varlist)
            {
                // Use reflection to get property names, to create table, Only first time, others will follow
                if (oProps == null)
                {
                    oProps = rec.GetType().GetProperties();
                    foreach (PropertyInfo pi in oProps)
                    {
                        Type colType = pi.PropertyType;

                        if ((colType.IsGenericType) && (colType.GetGenericTypeDefinition() == typeof(Nullable<>)))
                        {
                            colType = colType.GetGenericArguments()[0];
                        }

                        dtReturn.Columns.Add(new DataColumn(pi.Name, colType));
                    }
                }

                DataRow dr = dtReturn.NewRow();

                foreach (PropertyInfo pi in oProps)
                {
                    dr[pi.Name] = pi.GetValue(rec, null) ?? DBNull.Value;
                }

                dtReturn.Rows.Add(dr);
            }
            return dtReturn;
        }
4

1 に答える 1