SQL SERVER数据类型与C#数据类型的转换和相关.........

    bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。 Int64

    int 从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。 Int32
    smallint 从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。存储大小为 2 个字节。Int16
    tinyint 从 0 到 255 的整型数据。存储大小为 1 字节。System.Byte

bit 1 或 0 的整数数据。Boolean
    decimal 从 -10^38 +1 到 10^38 –1 的固定精度和小数位的数字数据。 Decimal
    numeric 功能上等同于 decimal。 Decimal
    money 货币数据值介于 -2^63 (-922,337,203,685,477.5808) 与 2^63 - 1 (+922,337,203,685,477.5807) 之间,精确到货币单位的千分之十。Decimal
    smallmoney 货币数据值介于 -214,748.3648 与 +214,748.3647 之间,精确到货币单位的千分之十。Decimal

----------------------------------------------------------------------------------------------------------------
    float 从 -1.79E + 308 到 1.79E + 308 的浮点精度数字。Double
    real 从 -3.40E + 38 到 3.40E + 38 的浮点精度数字。 Single
    datetime 从 1753 年 1 月 1 日到 9999 年 12 月 31 日的日期和时间数据,精确到百分之三秒(或 3.33 毫秒)。 DateTime
    smalldatetime 从 1900 年 1 月 1 日到 2079 年 6 月 6 日的日期和时间数据,精确到分钟。DateTime

----------------------------------------------------------------------------------------------------------------

    char 固定长度的非 Unicode 字符数据,最大长度为 8,000 个字符。string
    varchar 可变长度的非 Unicode 数据,最长为 8,000 个字符。String
    text 可变长度的非 Unicode 数据,最大长度为 2^31 - 1 (2,147,483,647) 个字符。
string
    varchar 可变长度的非 Unicode 数据,在 SQL2005+ 以后用来取代text。 string
    Unicode 字符串 nchar 固定长度的 Unicode 数据,最大长度为 4,000 个字符。 string
    nvarchar 可变长度 Unicode 数据,其最大长度为 4,000 字符。sysname 是系统提供用户定义的数据类型,在功能上等同于 nvarchar(128),用于引用数据库对象名。 string
    ntext 可变长度 Unicode 数据,其最大长度为 2^30 - 1 (1,073,741,823) 个字符。 string
    nvarchar (max) 可变长度 Unicode 数据, 在 SQL 2005+ 以后用来取代ntext。 string

-----------------------------------------------------------------------------------------------------------
    binary 固定长度的二进制数据,其最大长度为 8,000 个字节。 Byte[]
    varbinary 可变长度的二进制数据,其最大长度为 8,000 个字节。 Byte[]
    image 可变长度的二进制数据,其最大长度为 2^31 - 1 (2,147,483,647) 个字节。Byte[]

-----------------------------------------------------------------------------------------------------------
    timestamp 数据库范围的唯一数字,每次更新行时也进行更新。DateTime
    uniqueidentifier 全局唯一标识符 (GUID)。Guid
-----------------------------------------------------------------------------------------------------------

附:SQL Server 2005 常用数据类型

精确数字型:bigint(8字节)、int(4字节)、smallint(2字节)、tinyint(1字节)

近似数字型:float(取决于位数)、real(4字节)

日期时间型:datetime(1753年1月1日~9999年12月31日,可精确到3.33毫秒)、smalldatetime(1900年1月1日~2079年6月6日,可精确到1分钟)

字符串型:char(1字符1字节,长度不足时自动补空)、nchar(1字符占2字节,数据长度不足自动补空)、varchar(1字符占1字 节,(max)输入实际长度再加2字节)、nvarchar(1字符2字节,(max)输入实际长度再加2字节)、text(1字符占1字节/最大 2GB)、ntext(1字符占2字节/最大2GB)、binary(固定长度,长度不够自动补0x00)、varbinary(可变长度,输入数据的实 际长度)、image(可变长度,输入数据的实际长度)

其他类型:cursor、sql_variant、table、timestamp、uniqueidentifier、xml

【注意】 区别nchar和nvarchar字符串:一般较常使用varchar和nvarchar,而很少使用char和nchar,因为我们不需要字符补足空白而占用字节空间,相比于varchar,nvarchar更支持中文格式字符串而不保留空白。

 

#region 数据库类型转换为C#类型
        public static string DataTypeToCType(string dataType)
        {
            string retType = "";
            if (dataType.Equals("text") || dataType.Equals("varchar") || dataType.Equals("char") || dataType.Equals("nvarchar") || dataType.Equals("nchar"))
                return "string";
            if (dataType.Equals("int"))
                return "int";
            //if (dataType.Equals("bigint"))
            //    return "Int64";
            if (dataType.Equals("smallint"))
                return "Int16";
            if (dataType.Equals("tinyint"))
                return "byte";
            if (dataType.Equals("bigint"))
                return "long";
            if (dataType.Equals("bit"))
                return "bool";
            if (dataType.Equals("money") || dataType.Equals("smallmoney") || dataType.Equals("numeric"))
                return "decimal";
            if (dataType.Equals("datetime") || dataType.Equals("smalldatetime") || dataType.Equals("timestamp"))
                return "DateTime";
            if (dataType.Equals("real"))
                return "Single";
            if (dataType.Equals("float"))
                return "double";
            if (dataType.Equals("image") || dataType.Equals("binary") || dataType.Equals("varbinary"))
                return "byte[]";
            if (dataType.Equals("uniqueidentifier"))
                return "Guid";

            return retType;
        }
        #endregion

 


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server 存储过程可以接收 DataTable 类型的数据,需要通过 User-Defined Table Type 实现。下面是具体的步骤: 1. 在 SQL Server 数据库中创建 User-Defined Table Type。例如,以下代码创建了一个名为 MyTableType 的 User-Defined Table Type,其中包含两个列:Id 和 Name。 ```sql CREATE TYPE MyTableType AS TABLE ( Id INT, Name NVARCHAR(50) ); ``` 2. 在存储过程中声明一个参数,类型为刚刚创建的 User-Defined Table Type。例如,以下代码声明了一个名为 @myTable 的参数,类型为 MyTableType。 ```sql CREATE PROCEDURE MyStoredProcedure @myTable MyTableType READONLY AS BEGIN -- 在这里使用 @myTable 参数进行操作 END ``` 3. 在 C# 代码中,创建一个 DataTable 对象并添加数据,然后将该 DataTable 对象转换SqlParameter 对象,并将其传递给 SQLServer.runSPDataTable 方法的第二个参数。例如,以下代码创建了一个名为 data 的 DataTable 对象,其中包含两行数据,然后将其传递给 runSPDataTable 方法。 ```csharp // 创建 DataTable 对象并添加数据 DataTable data = new DataTable("MyTableType"); data.Columns.Add("Id", typeof(int)); data.Columns.Add("Name", typeof(string)); data.Rows.Add(1, "John"); data.Rows.Add(2, "Mary"); // 创建 SqlParameter 对象 SqlParameter parameter = new SqlParameter(); parameter.ParameterName = "@myTable"; parameter.SqlDbType = SqlDbType.Structured; parameter.Value = data; // 调用 runSPDataTable 方法 DataTable result = sqlServer.runSPDataTable("MyStoredProcedure", new SqlParameter[] { parameter }, "MyDatabase"); ``` 以上就是在 SQL Server 存储过程中接收 DataTable 类型数据的方法,需要在数据库中创建 User-Defined Table Type,并在存储过程中声明参数类型为该 User-Defined Table Type。同时,在 C# 代码中需要将 DataTable 对象转换SqlParameter 对象并传递给 runSPDataTable 方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值