zoukankan      html  css  js  c++  java
  • 将DataTable作为存储过程参数的用法

    比较新奇的用法。

    最近工作中写了几个存储过程,需要向存储过程中传递字符串,因为SQL Server 2000中没有内置类似于 split 的函数,只好自己处理,将前台数据集中的一列用逗号拆分存到一个List<string>中,再转化为字符串传给存储过程,很是麻烦。今天看了下SQL Server 2008的新特性,发现有表变量的使用,及其将DataTable作为参数的用法,就尝试了一下,简单谈谈心得。

     示例代码下载

     

    一、测试环境

    1Windows Server 2008 R2 DataCenter

    2Visual Studio 2008 Team System With SP1

    3SQL Server 2008 Enterprise Edition With SP1

    由于是SQL Server 2008新特性,所以只能用2008

     

     二、测试概述

    测试项目很简单,就是添加新用户

     

     

    三、准备数据

    1、建立数据库、表、类型、存储过程

     

    复制代码
    复制代码
    代码
     1 IF NOT EXISTS(SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID('Users'AND OBJECTPROPERTY(id, N'IsUserTable'= 1)
     2 BEGIN
     3  CREATE TABLE dbo.Users
     4  (
     5   UserID INT IDENTITY(-1-1NOT NULL,
     6   UserName VARCHAR(20NOT NULL,
     7   UserPass VARCHAR(20NOT NULL,
     8   Sex BIT NULL,
     9   Age SMALLINT NULL,
    10   CONSTRAINT PK_Users_UserID PRIMARY KEY(UserID)
    11  )
    12 END
    13 IF NOT EXISTS(SELECT * FROM sys.table_types WHERE name = 'UserTable' AND is_user_defined = 1)
    14 BEGIN
    15  CREATE TYPE UserTable AS TABLE
    16  (
    17   UserName VARCHAR(20NOT NULL,
    18   UserPass VARCHAR(20NOT NULL,
    19   Sex BIT NULL,
    20   Age SMALLINT NULL
    21  )
    22 END
    23 GO
    24 
    复制代码
    复制代码
    复制代码
    复制代码
    代码
     1 IF EXISTS(SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID('sp_InsertSingleUser'AND OBJECTPROPERTY(id, N'IsProcedure'= 1)
     2 BEGIN
     3     DROP PROCEDURE dbo.sp_InsertSingleUser
     4 END
     5 GO
     6 CREATE PROCEDURE dbo.sp_InsertSingleUser
     7 (
     8     @User UserTable READONLY
     9 )
    10 AS
    11 
    12 SET XACT_ABORT ON
    13 BEGIN TRANSACTION
    14 
    15 INSERT INTO dbo.Users(UserName, UserPass, Sex, Age)
    16 SELECT UserName, UserPass, Sex, Age FROM @User
    17 
    18 COMMIT TRANSACTION
    19 SET XACT_ABORT OFF
    20 GO
    复制代码
    复制代码

    前台搭建好表单,后台主要是一个函数:

    代码
     1     public void fnInsertSingleUser(DataTable v_dt)
     2     {
     3         try
     4         {
     5             SqlConnection cn = new SqlConnection(CONN);
     6             SqlCommand cmd = cn.CreateCommand();
     7             cmd.CommandType = CommandType.StoredProcedure;
     8             cmd.CommandText = @"sp_InsertSingleUser";
     9             SqlParameter p = cmd.Parameters.AddWithValue("@User", v_dt);
    10 
    11             DataSet ds = new DataSet();
    12             SqlDataAdapter da = new SqlDataAdapter(cmd);
    13             da.Fill(ds);
    14         }
    15         catch (Exception ex)
    16         {
    17             throw ex;
    18         }
    19     }

      点击【添加】按钮时调用存储过程。测试是完成了

  • 相关阅读:
    C语言 · 9-1九宫格
    Lodop打印控件指定打印任务某几页
    Lodop打印控件不打印css背景图怎么办
    Lodop打印项对象类型属性区分
    Lodop打印如何隐藏table某一列
    Lodop打印控件 打印‘接下一页’‘以下空白’
    Lodop连续打印内容逐渐偏移怎么办
    C-Lodop打印服务没启动怎么办
    LODOP.FORMAT格式转换【回调和直接返回值】
    C-Lodop设置页面一加载就打印
  • 原文地址:https://www.cnblogs.com/dingdingmao/p/3146461.html
Copyright © 2011-2022 走看看