为什么前段没有获取数据呢?

诸葛非卿 2011-10-10 10:32:43
//创建连接
string connectiosnString = @"Data Source=.\SQLEXPRESS;AttachDbFilename=F:\demo\MyWebSite\App_Data\myData.mdf;Integrated Security=True;User Instance=True";
SqlConnection conn = new SqlConnection(connectiosnString);
conn.Open();


//申明COMMAND并申明执行类型

SqlCommand cmd = new SqlCommand("StoredProcedure2", conn);
cmd.CommandType = CommandType.StoredProcedure;

//获取存储过程中传过来的值

cmd.Parameters.Add("@title", SqlDbType.NVarChar, 50);

cmd.Parameters["@title"].Direction = ParameterDirection.Output;

cmd.Parameters.Add("@webWords", SqlDbType.NVarChar, 50);

cmd.Parameters["@webWords"].Direction = ParameterDirection.Output;

cmd.Parameters.Add("@describ", SqlDbType.NVarChar,50) ;

cmd.Parameters["@describ"].Direction = ParameterDirection.Output;

cmd.Parameters.Add("@author", SqlDbType.NVarChar, 50);

cmd.Parameters["@author"].Direction = ParameterDirection.Output;

cmd.ExecuteNonQuery();
conn.Close();

//将获取的值传递给其它变量
cmd.Parameters["@title"].Value=getTitle ;
cmd.Parameters["@webWords"].Value=getWords;
cmd.Parameters["@describ"].Value=getDescrib;
cmd.Parameters["@author"].Value=getAuthor ;
代码没有报错,但是前端没有获取数据。
前端代码如下:
<head runat="server">
<title><%=getTitle %></title>

</head>

问题是数据库中有数据呀,还是我那里没有弄好呢?
...全文
74 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
Banianer 2011-10-11
  • 打赏
  • 举报
回复
他的代码错误百出。
楼主再好好学习一下SQL 吧。

ExecuteNonQuery(); 是非查询语句,怎么获取数据呢。 这个是用于 增删改的。
风骑士之怒 2011-10-11
  • 打赏
  • 举报
回复
getTitle赋值操作在哪里,

还有,先确定你从存储过程output的参数已经获取到,并能response.write出来
Banianer 2011-10-11
  • 打赏
  • 举报
回复
都没仔细看,你居然用了

cmd.ExecuteNonQuery(); 一般用于删除 添加 返回受影响的行。

 DataSet ds = new DataSet();
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds);
return ds;

要么使用
Banianer 2011-10-11
  • 打赏
  • 举报
回复
你的赋值怎么是倒着的?

cmd.Parameters["@title"].Value=getTitle ;
getTitle = cmd.Parameters["@title"].Value;
Banianer 2011-10-11
  • 打赏
  • 举报
回复
谁知道你的存储过程有没有问题呢,外面的代码也写的挺差的。
建议 SqlConnection 和 SqlCommand 都写成using
诸葛非卿 2011-10-11
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 banian_cn 的回复:]

他的代码错误百出。
楼主再好好学习一下SQL 吧。

ExecuteNonQuery(); 是非查询语句,怎么获取数据呢。 这个是用于 增删改的。
[/Quote]
这个语句是用来显示错误行的。。目前上面并没有抛出异常。。
诸葛非卿 2011-10-11
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 banian_cn 的回复:]

你的赋值怎么是倒着的?

cmd.Parameters["@title"].Value=getTitle ;
getTitle = cmd.Parameters["@title"].Value;
[/Quote]
兄弟,如果是让照你说的,那么就出现OBJECTG无法隐式的转化为string而且就算我转化成功。这种赋值方法虽然不是主流,但是也是没有问题的。。
诸葛非卿 2011-10-11
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 banian_cn 的回复:]

都没仔细看,你居然用了

cmd.ExecuteNonQuery(); 一般用于删除 添加 返回受影响的行。

C# code
DataSet ds = new DataSet();
SqlDataAdapter da = new SqlDataAdapter(cmd);
da.Fill(ds);
……
[/Quote]

这个没有问题。。
诸葛非卿 2011-10-10
  • 打赏
  • 举报
回复
已经测试过了,还是没有获得!!
黄瓜黄瓜 2011-10-10
  • 打赏
  • 举报
回复


cmd.ExecuteNonQuery();
cmd.Parameters["@title"].Value=getTitle ;
cmd.Parameters["@webWords"].Value=getWords;
cmd.Parameters["@describ"].Value=getDescrib;
cmd.Parameters["@author"].Value=getAuthor ;

conn.Close();


62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧