首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >存储过程在代码中返回所有内容,但在手动触发时返回一行

存储过程在代码中返回所有内容,但在手动触发时返回一行
EN

Stack Overflow用户
提问于 2015-01-27 07:23:40
回答 3查看 48关注 0票数 0

我从来没有使用过ADO.NET,我有一个存储的过程,如果我手动执行,它会接受一个学生编号并返回一个学生。

如果我在我的代码中执行它,它将返回全部6000名学生。在代码中执行有什么不同?

代码语言:javascript
复制
        DataTable dt = new DataTable();
        using (SqlConnection con = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["My_DB"].ConnectionString.ToString()))
        {
            using (SqlCommand cmd = new SqlCommand("sk.My_StoredProc", con))
            {
                using (SqlDataAdapter da = new SqlDataAdapter(cmd))
                {
                    cmd.CommandType = CommandType.StoredProcedure;

                    //Add Parameter values
                    cmd.Parameters.Add("@StudentNumber", SqlDbType.VarChar).Value = studentNumber;
                    cmd.Parameters.Add("@StudentNameFragment", SqlDbType.VarChar).Value = studentNameFragment;
                    cmd.Parameters.Add("@SchoolYear", SqlDbType.VarChar).Value = this.schoolYr;

                    con.Open();
                    cmd.ExecuteNonQuery();

                    da.Fill(dt);
                }
            }
        }
        return dt;
EN

Stack Overflow用户

发布于 2015-01-27 07:32:48

ExecuteNonQuery -实际上不应该与SELECT - only update,insert或delete一起使用。并且它不会将rows...according返回给MSDN -请参阅下面的链接

https://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlcommand.executenonquery%28v=vs.110%29.aspx

票数 -2
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28160623

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档