c# mysql executenonquery_C#与数据库访问技术总结(八)之ExecuteNonQuery方法

c# mysql executenonquery_C#与数据库访问技术总结(八)之ExecuteNonQuery方法ExecuteNonQuery方法ExecuteNonQuery方法主要用来更新数据。通常使用它来执行Update、Insert和Delete语句。该方法返回值意义如下:对于Update、Insert和Delete语句,返回值为该命令所影响的行数。对于所有其他类型的语句,返回值为-1。Command对象通过ExecuteNonQuery方法更新数据库的过程非常简单,需要进行的步骤如下:(1)创建数…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

ExecuteNonQuery方法

ExecuteNonQuery方法主要用来更新数据

通常使用它来执行Update、Insert和Delete语句。

该方法返回值意义如下:

对于Update、Insert和Delete语句,返回值为该命令所影响的行数。

对于所有其他类型的语句,返回值为-1。

Command对象通过ExecuteNonQuery方法更新数据库的过程非常简单,需要进行的步骤如下:

(1)创建数据库连接。

(2)创建Command对象,并指定一个SQL Insert、Update、Delete查询或存储过程。

(3)把Command对象依附到数据库连接上。

(4)调用ExecuteNonQuery方法。

(5)关闭连接。

下面依次看一看更新、添加和删除操作。

更新记录

下面的代码显示了一个简单的数据库更新操作,其作用是修改学号为“20013150“的学生信息:

string updateQuery=”Update studentInfo set sName=‘小李‘”+”Where ID=‘200131500145‘”;//新建连接

SqlConnection conn=newSqlConnection();

conn.Connectionstring=connectionString;//新建命令对象

SqlCommand cmd=newSqlCommand(updateQuery,conn);//调用命令对象的ExecuteNonQuery方法

conn.Open();int RecordsAffected=cmd. ExecuteNonQuery();

conn.Close();

代码本身非常简单。

但需要注意的是ExecuteNonQuery方法的返回值,这个方法返回命令影响的记录数量。

例如,如果命令是SQL UPDATE语句,则将返回被更新记录的数量。

相似的,当执行INSERT命令时返回插入到数据库的记录的数量。

如果期望命令更新记录,但是ExecuteNonQuery方法返回的值为0,则说明更新操作失败了。

(1)字符串拼接方式

也许读者已经注意到了在上面的代码中updateQuery是在程序中定义的,其操作固定在了程序中,用户无法和应用程序交互,

而在实际中命令应该根据用户输入的信息进行处理,比如用户在文本框中输入了新的用户信息以后单击更新,

然后程序将用户输入的数据更新到数据库。

要达到这个目的,就必须依据用户输入的数据来构造命令。构造命令可以有多种形式。

假设现在已经将用户输入的数据保存到了变量中:

String userName=”小李”;

String userId=”200131500145″;

此时userName和user id变量分别保存了学生姓名和学号,命名可以通过如下拼接命令字符串的形式构造:

string updateQuery=”Update student Set sName=‘ “+username+” ‘ “+”Where ID=‘ “+user id+” ‘ “

这种拼接字符串构造命令的方式是最直接最简单的,但也是最不安全的。

可以采用参数化来实现相同的功能。

(2)参数化方式

SQL Server.NET数据提供程序和OLE DB.NET数据提供程序在指定参数时区别非常大,下面分别介绍。

①在SQL Server .NET数据提供程序中指定参数

SQL Server .NET数据提供程序支持指定的参数。

当命令文本在指定具体命令时,必须指出哪一部分是在运行时进行设置的,也就是必须指出哪部分是参数。

那些可变的部分即参数,它们都必须有一个@前缀。

Update student set sName=@userName where ID=@userid

这个命令中,@userName和@userid为参数,它们的值在运行时是可变的。

当命令中带参数时,构造Command对象的方法和前面的并没有任何不同:

string updateQuery=”Update student Set sName=@username”+”Where ID=@userid” ;

SqlConnection conn=new SqlConnection(connectionString);

SqlCommand cmd=new SqlCommand(updateQuery, conn);

现在就有了包含参数的Command对象。

目前需要做的就是为命令中的每一个参数创建一个Parameter对象。

SqlCommand类提供了一个Parameters集合属性,用以为命令保存所有的参数。

通过调用Parameters集合的Add方法,在集合中添加一个新的参数。

crud. Parameters.Add (” @userName”, userName);

cmd. Parameters.Add(“@userid”, userid);

上面Add方法中的第一个参数为命令中的参数名,后面的userName则是用于定义的变量,保存了用户输入的信息。

除此之外,可以用其他方法创建Parameter对象,然后添加到集合中。

SqlParameter paramUserName= new SqlParameter(“@userName”,SqlDbType.NVarChar,50);

paramUserName.Value=userName;

cmd. Parameters.Add(paramUserName) ;

上面的代码

首先新建了一个SqlParameter对象,命名为paramUserName,该对象对应于命令中的@userName参数,在SqlParameter的构造函数中为参数指定了类型为SqlDbType.NVarChar,长度为50。

接着为paramUserName指定了Value属性,表示在运行时将用这个值代替命令中的@userName。

最后是调用Add方法将参数添加到命令的参数集合中,这一步很容易被初学者忽略,要格外注意。

带参数的命令设置好以后可以和往常一样执行ExecuteNonQuery方法,这并没有任何不同。

除了直接使用SQL语句作为命令以外,还可以使用存储过程作为命令内容。

为了ADO.NET应用程序中执行存储过程,需要把存储过程的名称赋给命令文本,同时将命令的CommandType属性设置为存储过程。

如果存储过程返回值,或者有一些参数,还必须创建参数,并把创建的参数添加到命令的Parameters集合中。

在数据库Student添加如下名为UpdateStudentInfo的存储过程,

代码如下:

CREATE PROCEDUREUpdateStudentInfo

(@userName nvarchar(20),@user id nvarchar(20);

)AS

UpdatestudentInfoSet sName=@userName Where ID=@useridGO

为了执行该存储过程,必须创建一个Command对象并将存储过程的名称传入它的构造函数。

SqlConnection

conn=new SqlConnection(connectionString);

SqlCommand

cmd=new SqlCommand(“UpdateStudentInfo”, conn);

接下来要把命令的CommandType属性设置为StoredProcedure。

cmd.CommandType=CommandType.StoredProcedure;

后续步骤和参数化命令是相同的,先设置参数然后执行对应命令。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/194866.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 网学天地考研资料分享_零极区块链怎么赚钱

    网学天地考研资料分享_零极区块链怎么赚钱孤荷凌寒自学第189天区块链103天Dapp058【主要内容】今天继续学习实战,终于完全实现一个波菜类的猜大小的智能合约,并开始准备了解erc721合约标准。共耗时26分钟。(此外整理作笔记花费

  • 单片机C语言视频教程转让「建议收藏」

    单片机C语言视频教程转让「建议收藏」单片机的C语言视频教程转让,本套光盘购于天祥电子,花了我200大元,如今我以60元(包快递)的价格转让。有意者请与我联系。QQ:247964971 电话:13982129248讲座从最基本电路知识开始讲起,非常详细的讲解KEIL编译器的使用,课程全部用单片机的C语言讲解,从C语言的第一个主函数MAIN讲起,一步步讲解每一个语法,每条指令的意思,即使对单片机一巧不能,对C语言一无所知,通过

  • redis:Could not connect to Redis at 127.0.0.1:6379: Connection refused错误解析「建议收藏」

    redis:Could not connect to Redis at 127.0.0.1:6379: Connection refused错误解析「建议收藏」1.错误信息思考:根据错误信息的字面意思,可以知道,redis-cli客户端程序,通过ip127.0.0.1,端口6379与redis服务器建立连接失败。说明当我们调用redis-cli时,默认是用本地回环地址去与服务器端建立连接。2.解决问题思路:服务器程序会在监听一个套接字(IP+端口号),等待客户端的连接。一般运行服务器程序的时候,都会加载一个配置文件。redis服务器也会读取一个配置文件。如果不知道配置文件在哪里,可以使用:whichredis.conf#或者whe

  • XXE初探

    XXE初探最近经常看到XXE出没,以为是最近才出现的一种类型,后来发现14年,乌云上面就有好多的案例,实在是我太lo了~@Time:2018/11/15在jarvisoj上面有着一道xxe的练习题,感兴趣的大佬可以去玩玩https://www.jarvisoj.com/challenges在写题之前,我们先科普一下,什么是xxe?xxe是xml外部实体注入,这里有一段xml的解释XM…

  • python贪吃蛇代码-Python编写简单的贪吃蛇核心代码[通俗易懂]

    python贪吃蛇代码-Python编写简单的贪吃蛇核心代码[通俗易懂]时间:2018-11-14概述:贪吃蛇Python贪吃蛇完整代码,代码注释比较多,可学习一下Python编写游戏的一些基本技巧,代码分享如下:#coding=utf-8importcursesimportthreadingimportrandom#importmsvcrt#fromcursesimporttextpad#!!!addch(y,x,ch)stdscr=curses….

  • 内网渗透神器_内网渗透什么意思

    内网渗透神器_内网渗透什么意思内网渗透-常用工具免杀Mimikatz免杀Mimikatz其实并不只有抓取口令这个功能,它还能够创建票证、票证传递、hash传递、甚至伪造域管理凭证令牌等诸多功能。由于mimikatz的使用说明网上资料很多,这里就不多加介绍了,随着这两年hw行动越来越多,企事业单位也都开始注重内网安全,有预算的会上全套的终端安全、企业版杀软或者EDR,就算没有预算的也会装个360全家桶或者主机卫士之类的,这也导致很多时候你的mimikatz可能都没法拷贝过去或者没有加载执行,拿了台服务器却横向移不动就尴尬了。因为这款工

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号