Generi c класс для преобразования списка объектов в IEnumerable <SqlDataRecord> - PullRequest
0 голосов
/ 26 марта 2020

У меня есть этот объект:

public class ConsentData
{
    public string ConsentName { get; set; }
    public bool ConsentValue { get; set; }
    public DateTime ConsentDate { get; set; }
}

Я должен передать список ConsentData хранимой процедуре на SQL Сервере через параметр табличного значения.

Поиск способ преобразования списка ConsentData в список SqlDataRecord Я нашел этот обобщенный c класс в Интернете:

public class SqlTableValueSupport<T> : List<T>, IEnumerable<SqlDataRecord> where T : class, new()
    {
        IEnumerator<SqlDataRecord> IEnumerable<SqlDataRecord>.GetEnumerator()
        {
            //Create Columns (SqlMetaData)
            List<SqlMetaData> records = new List<SqlMetaData>();
            var properties = typeof(T).GetProperties();
            foreach (var prop in properties)
            {
                SqlDbType sdbtyp = GetSqlType(prop.PropertyType);
                records.Add(new SqlMetaData(prop.Name, sdbtyp));
            }

            //Create records/rows (SqlDataRecord)
            SqlDataRecord ret = new SqlDataRecord(records.ToArray());

            foreach (T data in this)
            {
                for (int i = 0; i < properties.Length; i++)
                {
                    ret.SetValue(i, properties[i].GetValue(data, null));
                }

                yield return ret;
            }
        }

        // Map C# Types to SqlDbType
        private SqlDbType GetSqlType(Type type)
        {
            SqlDbType val = SqlDbType.VarChar;
            if (type == typeof(Int64) || type == typeof(Nullable<Int64>))
            {
                val = SqlDbType.BigInt;
            }
            else if (type == typeof(Byte[]))
            {
                val = SqlDbType.Binary;
            }
            else if (type == typeof(Boolean) || type == typeof(Nullable<Boolean>))
            {
                val = SqlDbType.Bit;
            }
            else if (type == typeof(DateTime) || type == typeof(Nullable<DateTime>))
            {
                val = SqlDbType.DateTime;
            }
            else if (type == typeof(Decimal))
            {
                val = SqlDbType.Decimal;
            }
            // Please refer to the following document to add other types
            // http://msdn.microsoft.com/en-us/library/ms131092.aspx
            return val;
        }
    }

Я хотел бы знать, как использовать класс, как я могу передать список ConsentData и получить список SqlDataRecord?

1 Ответ

0 голосов
/ 20 апреля 2020

В конце концов, я решил проблему, обработав класс методом stati c. Это класс:

public class SqlTableValueSupport<T> where T : class
{
    public static DataTable ConvertData(List<T> ValuesList)
    {
        DataTable dtData = new DataTable();
        var objectReference = ValuesList.GetType().GetGenericArguments()[0];
        var properties = objectReference.GetProperties();
        foreach (var prop in properties)
        {
            dtData.Columns.Add(prop.Name, prop.PropertyType);
        }

        foreach (var item in ValuesList)
        {
            var dataArray = new List<object>();
            foreach (var prop in properties)
            {
                dataArray.Add(prop.GetValue(item));
            }

            dtData.Rows.Add(dataArray.ToArray());
        }

        return dtData;
    }
}

Метод вызывается следующим образом

var ListOfMyObjectDT = SqlTableValueSupport<MyObject>.ConvertData(ListOfMyObject);
...