如何处理C#向SQL Server中插入记录时的单引号问题
发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,这篇文章主要介绍了如何处理C#向SQL Server中插入记录时的单引号问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。asp.ne
千家信息网最后更新 2025年02月02日如何处理C#向SQL Server中插入记录时的单引号问题
这篇文章主要介绍了如何处理C#向SQL Server中插入记录时的单引号问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
asp.net中使用c#, 向coredb.mybbs表中插入记录值(title, content)【文章的标题和内容】,由于content, title中可能包含单引号,直接使用sql的insert命令会报错,对此有两种处理方法,一种将单引号替换成两个单引号,第2种方法是使用存储过程。
表mybbs的格式定义如下:
create table [dbo].[mybbs] ( [id] [bigint] identity (1, 1) not null , [title] [char] (160) collate chinese_prc_ci_as null , [author] [char] (20) collate chinese_prc_ci_as null , [date_of_created] [datetime] null , [abstract] [char] (480) collate chinese_prc_ci_as null , [content] [ntext] collate chinese_prc_ci_as not null ) on [primary] textimage_on [primary]
1、C#向Sql Server中插入记录时单引好问题处理方法之一:将单引号用两个单引号替换:
sqlconnection coredb=new sqlconnection(); coredb.connectionstring= "workstation id=\"gqa-eric-lv\";packet size=4096;integrated security=sspi;" + "data source=\"gqa-eric-lv\";persist security info=false;initial catalog=coredb"; //单引号用""替换,以插入到sql server中; string title=textbox1.text.replace("",""); string content=textbox2.text.replace("",""); if(title.trim()==""||content.trim()=="")return; string insertcmd =@"insert into mybbs (title,content) values("+ title + "," +content+")"; sqlcommand mycommand = new sqlcommand(insertcmd,coredb); coredb.open(); sqldatareader myreader = mycommand.executereader(); myreader.close(); coredb.close();
2、C#向Sql Server中插入记录时单引好问题处理方法之二:使用存储过程来插入
1) 创建存储过程:
create proc insertmybbsproc(@title char(160), @author char(20), @content ntext) as insert into mybbs(title,author,content) values(@title, @author, @content)
2) 查询分析器中测试存储过程:
declare @title char(160) declare @author char(20) declare @content char(600) set @title=test title 3 set @author=david euler 3 set @content=it is the content 3 exec insertmybbsproc @title, @author, @content
3) c#中通过sqlcommand执行存储过程:
sqlconnection coredb=new sqlconnection(); coredb.connectionstring= "workstation id=\"gqa-eric-lv\";packet size=4096;integrated security=sspi;" + "data source=\"gqa-eric-lv\";persist security info=false;initial catalog=coredb"; string title=textbox1.text; string content=textbox2.text; if(title.trim()==""||content.trim()=="")return; //insertmybbsproc是向mybbs中插入数据的procedure: sqlcommand insertcmd = new sqlcommand("insertmybbsproc",coredb); insertcmd.commandtype=commandtype.storedprocedure;//命令类型为存储过程;下面定义参数对象: sqlparameter prm1=new sqlparameter("@title", sqldbtype.char,160); sqlparameter prm2=new sqlparameter("@author", sqldbtype.char,20); sqlparameter prm3=new sqlparameter("@content",sqldbtype.ntext,1073741823); prm1.direction=parameterdirection.input; prm2.direction=parameterdirection.input; prm3.direction=parameterdirection.input; //为insertcmd添加sql参数: insertcmd.parameters.add(prm1); insertcmd.parameters.add(prm2); insertcmd.parameters.add(prm3); //为sql参数赋值: prm1.value=title; prm2.value="david euler"; prm3.value=content; coredb.open(); int recordsaffected=insertcmd.executenonquery(); if(recordsaffected==1)response.write("< script>alert("+ "插入成功" +");< /script>"); coredb.close();
感谢你能够认真阅读完这篇文章,希望小编分享的"如何处理C#向SQL Server中插入记录时的单引号问题"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
引号
过程
存储
问题
C#
方法
篇文章
参数
处理
两个
命令
成功
价值
兴趣
内容
分析器
同时
对此
对象
数据
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
河南惠普服务器虚拟化定制云主机
王者荣耀游戏服务器等级
武汉学网络技术
松江区个人软件开发统计
移动端软件开发教学大纲
母乳数据库 作用
splatoon2一个服务器
数据库设置服务器属性
网页图表数据存在服务器哪里
学校网络安全手抄报图片大全
网络安全事件有
网络安全政策和网络攻击防范
广西智慧团建软件开发公司
校园网络安全的利与弊
条形码数据库下载地址
销售数据库查询语句
网络安全白热化
bs 连接数据库
山东曲阜网络安全保卫大队
江西企业软件开发管理
提供VR技术的服务器
2020年是第几个网络安全
小米无法连接到服务器
修改数据库的
数据库跑在nas存储上
定制软件开发推荐咨询
中科国产服务器
软件开发和ui设计工资
软件开发动态模型
权限管理数据库如何设计