C#中调用存储过程能否用sqldataadapter????------waiting!!!!

dhdhdh 2003-09-11 03:56:50
我见到的都是用sqldatareader来做的,能否用SqlDataAdapter
的方法将结果放在dataset中?最好给些代码,谢谢!

还有,我如果用函数调用的方式,返回sqldatareader,但是我发现第一条记录就是不见了,请问如何通过这种方式得到完整的结果集呢???
...全文
59 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
mythutest 2003-09-11
  • 打赏
  • 举报
回复
给你我的代码

public DataSet GetProduct(int smallclassID)
{
SqlConnection myConnection = new SqlConnection(ConfigurationSettings.AppSettings["ConnectionString"]);
SqlDataAdapter myDataAdapter = new SqlDataAdapter("GetProduct",myConnection);
myDataAdapter.SelectCommand.CommandType = CommandType.StoredProcedure;
SqlParameter mySmallClassID = new SqlParameter("@smallclassID",SqlDbType.Int,4);
mySmallClassID.Value = smallclassID;
myDataAdapter.SelectCommand.Parameters.Add(mySmallClassID);
DataSet myProduct = new DataSet();
myDataAdapter.Fill(myProduct);
return myProduct;
}
dhdhdh 2003-09-11
  • 打赏
  • 举报
回复
visualcpu(Banaler) :
比如你要先用ExceuteQuery()这个方法,如果返回值大于0就用Read()这个方法!
-->
不懂,能否给个example!!!
CMIC 2003-09-11
  • 打赏
  • 举报
回复
可以:
DataTable cmicDt=new DataTable();
SqlCommand cmicCmd=new SqlCommand("GetDateMoney",tempCn);
cmicCmd.CommandType=CommandType.StoredProcedure;
cmicCmd.Parameters.Add(new SqlParameter("@StartTime",SqlDbType.DateTime));
cmicCmd.Parameters["@StartTime"].Value=tempStartTime;
cmicCmd.Parameters.Add(new SqlParameter("@EndTime",SqlDbType.DateTime));
cmicCmd.Parameters["@EndTime"].Value=tempEndTime;

SqlDataAdapter cmicDa=new SqlDataAdapter(cmicCmd);
cmicDa.Fill(cmicDt);
seesea125 2003-09-11
  • 打赏
  • 举报
回复
mydatareader = mycommand.ExecuteReader(CommandBehavior.CloseConnection);
这么写系统自动关闭
dhdhdh 2003-09-11
  • 打赏
  • 举报
回复
还有,我return sqldatareader,那么我如何关闭该connection呢,.net能自动关闭吗,如何
手动关闭呢???
dhdhdh 2003-09-11
  • 打赏
  • 举报
回复
ok,知道了,但是我如何判断是否为空呢(不用read)????
visualcpu 2003-09-11
  • 打赏
  • 举报
回复
比如你要先用ExceuteQuery()这个方法,如果返回值大于0就用Read()这个方法!
visualcpu 2003-09-11
  • 打赏
  • 举报
回复
不可以

你发现第一条记录不见了是不可能的

是你代码有问题!
你一定要先看看是不为空才能用Read()这个方法!
seesea125 2003-09-11
  • 打赏
  • 举报
回复
sqldatareader向前只读,如果判断if(my.read())时,指针就向前移动了一条了,不要判断或用dataset
树猫 2003-09-11
  • 打赏
  • 举报
回复
1 我想不能
2 你的代码贴出来看看
C#学生管理系统 主要代码: (1)自定义函数类代码: public class LinkDataBase { private string strSQL; //与SQL Server 的连接字符串设置 //与数据库的连接 private string connectionString = "server = .;database=stu_Manage;uid=sa;pwd=123"; private static SqlConnection con = new SqlConnection("server = .;database=stu_Manage;uid=sa;pwd=123"); private SqlConnection myConnection; private DataSet ds = new DataSet(); private SqlDataAdapter da; public DataSet SelectDataBase(string tempStrSQL, string tempTableName) //根据输入的SQL语句检索数据库数据 { this.strSQL = tempStrSQL; this.myConnection = new SqlConnection(connectionString); this.da = new SqlDataAdapter(this.strSQL, this.myConnection); this.ds.Clear(); this.da.Fill(ds, tempTableName); //返回填充了数据的DataSet,其数据表以tempTableName给出的字符串命名 return ds; } public DataTable SelectDataBase(string tempStrSQL) //检索数据库数据(传字符串直接操作数据库) { this.myConnection = new SqlConnection(connectionString); DataSet tempDataSet = new DataSet(); this.da = new SqlDataAdapter (tempStrSQL, this.myConnection); this.da.Fill(tempDataSet); return tempDataSet.Tables[0]; } public void deleteInfo(string strcmd)//删除信息 { SqlCommand cmd = new SqlCommand(strcmd, con); try { con.Open(); if (MessageBox.Show("确定要删除吗?", "警告", MessageBoxButtons.OKCancel, MessageBoxIcon.Warning) == DialogResult.OK) { cmd.ExecuteNonQuery(); MessageBox.Show("删除成功!"); } } catch (Exception ex) { MessageBox.Show(ex.Message); return; } finally { con.Close(); } } public void addInfo(string strcmd)//定义添加信息事件 { try { con.Open(); SqlCommand cmd = new SqlCommand(strcmd, con); cmd.ExecuteNonQuery(); MessageBox.Show("添加成功"); } catch (Exception ex) { MessageBox.Show(ex.Message); return; } finally { con.Close(); } } public void updateInfo(string strcmd)//自定义更新信息方法 { try { con.Open(); SqlCommand cmd = new SqlCommand(strcmd, con); cmd.ExecuteNonQuery(); MessageBox.Show("修改成功"); } catch (Exception ex) { MessageBox.Show(ex.Message); } finally { con.Close(); } } } . . . . . . . . . (2) > . . .
这个分页控件名为AspNetPager控件,是Asp.net上使用率最高的分页控件,想怎么分就怎么分.附带'超详细代码注释",好用请给评论. 基本步骤: 1.拖拽控件(存放到到Bin目录下,再拖入工具箱) 2.粘贴复制(已放出实例源码) 3.修改Sql语句,即可使用. 特性如下: 强大的各种属性,附带多种CSS,可自定义CSS,想怎么分就怎么分页! 上下页,1234分页,首尾分页,页面跳转,等等,统统一步搞定. 实例代码(包内也有): ___________________________________________________________________ Default.aspx页面↓↓ ___________________________________________________________________ <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> <%@ Register Assembly="AspNetPager" Namespace="Wuqi.Webdiyer" TagPrefix="webdiyer" %>
DataList ID="DataList1" runat="server"> <%# Eval("ID") %> DataList>
____________________________________________________________ Default.aspx.cs页面代码↓↓ ____________________________________________________________ using System; using System.Collections.Generic; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; //引用命名空间 using System.Data; using System.Data.SqlClient; public partial class _Default : System.Web.UI.Page { string connstring = "server=baiyi-js\\SQL2005;uid=sa;pwd=123456;database=xcbaiyi";//修改数据库连接字符串(必须改) protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { SqlConnection conn = null; try { conn = new SqlConnection(connstring); conn.Open(); SqlCommand Count = new SqlCommand(); Count.Connection = conn; Count.CommandText = "select count(*) from tuiguang_2"; //Sql查询语句(必修改) Pager1.RecordCount = (int)Count.ExecuteScalar(); //"Pager1"为分页控件ID.在工具箱拖拽添加控件,同时会在aspx页面顶部添加控件命名控件(无需修改) BindData(); } finally { conn.Close(); } } } //绑定数据-2_只修改Sql语句即可 public void BindData() { SqlConnection conn = new SqlConnection(connstring); string sql = "select * from tuiguang_2";//Sql查询语句(必修改) SqlDataAdapter da = new SqlDataAdapter(sql, conn); DataSet ds = new DataSet(); da.Fill(ds, Pager1.PageSize * (Pager1.CurrentPageIndex - 1), Pager1.PageSize, "temptbl"); DataTable dt = ds.Tables["temptbl"]; DataList1.DataSource = dt; DataList1.DataBind(); } //控件事件-每次重新绑定_不需修改 protected void AspNetPager1_PageChanged(object src, EventArgs e) { BindData(); } }

62,041

社区成员

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

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

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

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