Получить тип данных столбца SQL Server, используя C # - PullRequest
5 голосов
/ 15 марта 2012

Я не уверен, что именно я делаю не так, может кто-нибудь исправить это, пожалуйста?Мне нужно определить тип извлеченного столбца из базы данных SQL Server с помощью C #.

Скажи, у меня есть это:

SqlConnection cn = new SqlConnection("Sql Connection String");
SqlCommand cmd = new SqlCommand("SELECT * FROM [TableName]", cn);
SqlDataReader rdr = cmd.ExecuteReader();

while (rdr.Read())
{
    for (int c = 0; c < rdr.VisibleFieldCount; c++)
    {
        System.Type type = rdr.GetFieldType(c);

        //So can I do this? (Pseudo-code)
        //switch(type)
        //{
        //case string:
        //case int:
        //case DateTime:
        //etc.
        //}
    }
}

1 Ответ

10 голосов
/ 15 марта 2012

Вы можете сделать следующее:

/* ... code .... */

System.Type type = rdr.GetFieldType(c);

switch (Type.GetTypeCode(type))
{
    case TypeCode.DateTime:
        break;
    case TypeCode.String:
        break;
    default: break;
}

/* ... code .... */
...