A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 翟盼盼 高级黑马   /  2013-3-13 15:04  /  1545 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

关于SQL的存储过程(代参数),怎么样给参数赋值?

评分

参与人数 1技术分 +1 收起 理由
张文 + 1

查看全部评分

4 个回复

倒序浏览
分在哪里使用存储过程:
1.在数据库中使用存储过程,则直接使用exec 存储过程名称 参数1名=参数1值[,参数2名=参数2值,out 输出参数变量名]

如果在.net中使用 则可用SqlCommand 对象的comm.Parameters.AddRange(SqlParameter[] pars);
添加参数数组

评分

参与人数 1技术分 +1 收起 理由
张文 + 1

查看全部评分

回复 使用道具 举报
下面是调用插入带参数存储过程的语句
string constr = "Data Source=liu;Initial Catalog=itcastcn;Integrated Security=True";
            using (SqlConnection con = new SqlConnection(constr))
            {               
                string spname = "usp_tbClass_insert";
                using (SqlCommand cmd = new SqlCommand(spname, con))
                {     
                    //不能忘               
                    cmd.CommandType = CommandType.StoredProcedure;
                    SqlParameter[] pms = new SqlParameter[] {
                    new SqlParameter("@clsName",txtname.Text),
                    new SqlParameter("@clsDesc",txtdesc.Text)
                    };
                    cmd.Parameters.AddRange(pms);
                    con.Open();
                    int res = cmd.ExecuteNonQuery();
                    con.Close();                  
                }
            }
和正常的掉用带参数的语句没有太大的区别的 只是多了cmd.CommandType = CommandType.StoredProcedure; 不知是你想要的结果与否

评分

参与人数 1技术分 +1 收起 理由
张文 + 1

查看全部评分

回复 使用道具 举报
存储过程:albumInfo
ALTER PROCEDURE dbo.albumInfo --获得相册的详细信息        (
        @aid int
        )
AS
select am_uid,am_title,am_depict,am_time,am_count,am_t,u_name from album,dbo.[user] where am_id=@aid and am_uid=u_id
        RETURN

C#代码 传参:
            SqlParameter[] ps = new SqlParameter[] { new SqlParameter("@aid", albumID) };
            DataTable dt = core.getDt("albumInfo", CommandType.StoredProcedure, ps);
回复 使用道具 举报
给你一个我写好的吧,你看看。。。有疑问的话留言探讨。。。共同进步
带参还包括了输出参数

存储过程
ALTER PROCEDURE [dbo].[GetLinkPageOutRowPageCount]
(
        @PageIndex int =1,--当前页数
        @PageSize int =4,--当前页大小
        @RowCount int output,--总行数(传出参数)
        @PageCount int output--总页数(传出参数)
)

AS
begin
        DECLARE @sql NVARCHAR(max),@sqlCount NVARCHAR(225)
        select @RowCount =COUNT(FId),@PageCount=CEILING((COUNT(FId)+0.0)/@PageSize) FROM TLinks
        SET @sql='SELECT TOP '+LTRIM(str(@PageSize))+' * FROM TLinks  where  FId not in(select top '+LTRIM(str((@PageIndex-1)*@PageSize))+' FId from TLinks  order by FSortId DESC , FAddTime ASC)order by FSortId DESC , FAddTime ASC'
        print @sql
        EXEC(@sql)
end

c#中调用赋值和接收输出参数的值
#region 友情链接执行简单先根据自定义int字段排序再时间进行排序查询分页存储过程
        /// <summary>
        /// 友情链接执行简单先根据自定义int字段排序再时间进行排序查询分页存储过程
        /// </summary>
        /// <param name="pageIndex">页码</param>
        /// <param name="pageSize">页容量</param>
        /// <param name="rowCount">总行数-输出</param>
        /// <param name="pageCount">总页数-输出</param>
        /// <returns></returns>
        public DataTable ExecProSimplePageList(int pageIndex, int pageSize, out int rowCount, out int pageCount)
        {
            rowCount = 1;
            pageCount = 1;
            SqlParameter[] parameters = {
                new SqlParameter("@PageIndex", SqlDbType.Int,4),
                new SqlParameter("@PageSize", SqlDbType.Int,4),
                                new SqlParameter("@RowCount", SqlDbType.Int,4),
                new SqlParameter("@PageCount", SqlDbType.Int,4)};
            parameters[0].Value = pageIndex;
            parameters[1].Value = pageSize;
            parameters[2].Value = rowCount;
            parameters[2].Direction = ParameterDirection.Output;
            parameters[3].Value = pageCount;
            parameters[3].Direction = ParameterDirection.Output;
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = Conn;
            cmd.CommandText = "GetLinkPageOutRowPageCount";
            cmd.CommandType = CommandType.StoredProcedure;
            cmd.Parameters.AddRange(parameters);
            SqlDataAdapter da = new SqlDataAdapter(cmd);
            DataTable dt = new DataTable();
            da.Fill(dt);
            rowCount = Convert.ToInt32(parameters[2].Value);
            pageCount = Convert.ToInt32(parameters[3].Value);
            return dt;
        }
        #endregion
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马