SQL Server数据库存储过程中拼接字符串注意的问题
在SQL Server数据库中书写复杂的存储过程时,一般的做法是拼接字符串,最后使用EXEC sp_executesql '拼接的字符串' 查询出结果。
先看一段代码:
1 -- =============================================
2 -- Author: XXX
3 -- Create date: 2014-09-19
4 -- Description: 获取学生列表信息
5 -- =============================================
6 ALTER PROCEDURE [dbo].[Sp_GetStudentList]
7 @StudentId INT --主键id
8 AS
9 BEGIN
10
11 SET NOCOUNT ON;
12
13 DECLARE @SqlSelectResult NVARCHAR(MAX) = '';
14 SET @SqlSelectResult = 'SELECT * FROM Student AS s ';
15
16 IF (ISNULL(@StudentId, 0) > 0)
17 BEGIN
18 SET @SqlSelectResult = @SqlSelectResult + ' WHERE s.ClassId > ' + @StudentId;
19 END
20
21 PRINT (@SqlSelectResult);
22
23 EXEC sp_executesql @SqlSelectResult;
24
25 SET NOCOUNT OFF;
26 END
然后调用该存储过程:EXEC Sp_GetStudentList 1。结果如下:
运行失败。
仔细分析原因发现:存储过程参数@StudentId 类型为INT(整形)型;而自定义变量@SqlSelectResult是NVARCHAR(MAX)字符串类型。
在23行,EXEC sp_executesql @SqlSelectResult;执行拼接字符串时,报错,编译器尝试将字符串类型转换成int类型失败。
意思是:SQL Server中在拼接字符串时,所有的变量必须全部是字符串类型,才能正确拼接,否则报错。
解决方法1:将非字符串类型的变量转换为字符串类型,
将18行代码修改为:
SET @SqlSelectResult = @SqlSelectResult + ' WHERE s.ClassId > ' + convert(nvarchar(10),@StudentId);
解决方法2:在存储过程开始定义的时候,将参数定义为字符串类型
ALTER PROCEDURE [dbo].[Sp_GetStudentList] @StudentId NVARCHAR(10) --主键id AS
……
成在管理,败在经验;嬴在选择,输在不学! 贵在坚持!
个人作品
BIMFace.SDK.NET
开源地址:https://gitee.com/NAlps/BIMFace.SDK
系列博客:https://www.cnblogs.com/SavionZhang/p/11424431.html
系列视频:https://www.cnblogs.com/SavionZhang/p/14258393.html
技术栈
1、Visual Studio、.NET Core/.NET、MVC、Web API、RESTful API、gRPC、SignalR、Java、Python
2、jQuery、Vue.js、Bootstrap、ElementUI
3、数据库:分库分表、读写分离、SQLServer、MySQL、PostgreSQL、Redis、MongoDB、ElasticSearch、达梦DM
4、架构:DDD、ABP、SpringBoot、jFinal
5、环境:跨平台、Windows、Linux、Nginx
6、移动App:Android、IOS、HarmonyOS、微信小程序、钉钉、uni-app、MAUI
分布式、高并发、云原生、微服务、Docker、CI/CD、DevOps、K8S;Dapr、RabbitMQ、Kafka、RPC、Elasticsearch。
欢迎关注作者头条号 张传宁IT讲堂,获取更多IT文章、视频等优质内容。
出处:www.cnblogs.com/SavionZhang
作者:张传宁 技术顾问、培训讲师、微软MCP、系统架构设计师、系统集成项目管理工程师、科技部创新工程师。
专注于企业级通用开发平台、工作流引擎、自动化项目(代码)生成器、SOA 、DDD、 云原生(Docker、微服务、DevOps、CI/CD);PDF、CAD、BIM 审图等研究与应用。
多次参与电子政务、图书教育、生产制造等企业级大型项目研发与管理工作。
熟悉中小企业软件开发过程:可行调研、需求分析、架构设计、编码测试、实施部署、项目管理。通过技术与管理帮助中小企业实现互联网转型升级全流程解决方案。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
如有问题,可以通过邮件905442693@qq.com联系。共同交流、互相学习。
如果您觉得文章对您有帮助,请点击文章右下角【推荐】。您的鼓励是作者持续创作的最大动力!