怎么使用DataTable作为存储过程的参数

61次阅读
没有评论

共计 2189 个字符,预计需要花费 6 分钟才能阅读完成。

自动写代码机器人,免费开通

丸趣 TV 小编给大家分享一下怎么使用 DataTable 作为存储过程的参数,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

因为 SQL Server 2000 中没有内置类似于 split 的函数,只好自己处理,将前台数据集中的一列用逗号拆分存到一个 List 中,再转化为字符串传给存储过程,很是麻烦。下面丸趣 TV 丸趣 TV 小编来讲解下如何使用 DataTable 作为存储过程的参数?

如何使用 DataTable 作为存储过程的参数

一、测试环境

1、Windows Server 2008 R2 DataCenter

2、Visual Studio 2008 Team System With SP1

3、SQL Server 2008 Enterprise Edition With SP1

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

二、测试概述

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

三、准备数据

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

IF NOT EXISTS(SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID( Users) AND OBJECTPROPERTY(id, N IsUserTable) = 1)
  BEGIN
  CREATE TABLE dbo.Users
  ( UserID INT IDENTITY(-1, -1) NOT NULL,
  UserName VARCHAR(20) NOT NULL,
  UserPass VARCHAR(20) NOT NULL,
  Sex BIT NULL,
 Age SMALLINT NULL,
  CONSTRAINT PK_Users_UserID PRIMARY KEY(UserID)
  )
  IF NOT EXISTS(SELECT * FROM sys.table_types WHERE name =  UserTable  AND is_user_defined = 1)
  BEGIN
  CREATE TYPE UserTable AS TABLE
  ( UserName VARCHAR(20) NOT NULL,
  UserPass VARCHAR(20) NOT NULL,
  Sex BIT NULL,
  Age SMALLINT NULL
  )
  END
  GO

如何使用 DataTable 作为存储过程的参数

IF EXISTS(SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID( sp_InsertSingleUser) AND OBJECTPROPERTY(id, N IsProcedure) = 1)
  BEGIN
  DROP PROCEDURE dbo.sp_InsertSingleUser
  END
  GO
  CREATE PROCEDURE dbo.sp_InsertSingleUser
  (
  @User UserTable READONLY
  )
  AS
  SET XACT_ABORT ON
  BEGIN TRANSACTION
  INSERT INTO dbo.Users(UserName, UserPass, Sex, Age)
  SELECT UserName, UserPass, Sex, Age FROM @User
  COMMIT TRANSACTION
  SET XACT_ABORT OFF
  GO

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

public void fnInsertSingleUser(DataTable v_dt)
  {
  try
  { SqlConnection cn = new SqlConnection(CONN);
  SqlCommand cmd = cn.CreateCommand();
  cmd.CommandType = CommandType.StoredProcedure;
  cmd.CommandText = @ sp_InsertSingleUser 
  SqlParameter p = cmd.Parameters.AddWithValue(@User , v_dt);
  DataSet ds = new DataSet();
  SqlDataAdapter da = new SqlDataAdapter(cmd);
  da.Fill(ds);
  }
  catch (Exception ex)
  {
  throw ex;
  }
  }

点击【添加】按钮时调用存储过程。测试是完成了,也很简单,传递一个 DataTable 做参数确实很方便吧,能够轻松完成原先需要很多编码的工作。关于 表变量还是有些道道的,如创建时判断其是否存在的语句,删除表变量前需要先删除引用表变量的存储过程等。一般开发我大多会选择用临时表,处理起来比较方 便,表变量可以作为存储过程参数确实是一个独特的优势,希望在 SQL Server 的未来版本中能够继续增强对表变量和临时表的支持,尤其是早日支持临时表调试。

以上是“怎么使用 DataTable 作为存储过程的参数”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注丸趣 TV 行业资讯频道!

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计2189字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)