ADO.NET 帮助类 参数传递 存储过程 分页

SQLHelper

public class SqlHelper
    {
        private readonly string _constr = ConfigurationManager.ConnectionStrings["key"].ConnectionString;

        #region 增删改通用方法
        public int ExecuteNonQuery(string sql, CommandType type, params SqlParameter[] pms)
        {
            //创建链接对象
            //创建命令对象
            //打开链接
            //执行
            using (SqlConnection con = new SqlConnection(_constr))
            {
                using (SqlCommand cmd = new SqlCommand(sql, con))
                {
                    if (pms != null)
                    {
                        cmd.Parameters.AddRange(pms);
                    }
                    cmd.CommandType = type;
                    con.Open();
                    return cmd.ExecuteNonQuery();
                }
            }
        } 
        #endregion

        #region 返回单行单列

        public object ExecuteScalar(string sql, CommandType type, params SqlParameter[] pms)
        {
            using (SqlConnection con = new SqlConnection(_constr))
            {
                using (SqlCommand cmd = new SqlCommand(sql, con))
                {
                    if (pms != null)
                    {
                        cmd.Parameters.AddRange(pms);
                    }
                    cmd.CommandType = type;
                    con.Open();
                    return cmd.ExecuteScalar();
                }
            }
        }

        #endregion

        #region datatable查询
        public DataTable ExecuteTable(string sql, CommandType type, params SqlParameter[] pms)
        {
            DataTable dt = new DataTable();
            using (SqlConnection con = new SqlConnection(_constr))
            {
                using (SqlDataAdapter cmd = new SqlDataAdapter(sql, con))
                {
                    if (pms != null)
                    {
                        cmd.SelectCommand.Parameters.AddRange(pms);
                    }
                    cmd.SelectCommand.CommandType = type;
                    con.Open();
                    cmd.Fill(dt);
                }
            }
            return dt;
        } 
        #endregion

        #region Reader查询
        public SqlDataReader ExecuteReader(string sql, CommandType type, params SqlParameter[] pms)
        {
            SqlConnection con = new SqlConnection(_constr);
            SqlCommand cmd = new SqlCommand(sql, con);
            if (pms != null)
            {
                cmd.Parameters.AddRange(pms);
            }
            cmd.CommandType = type;
            try
            {
                con.Open();
                return cmd.ExecuteReader(CommandBehavior.CloseConnection);
            }
            catch (Exception)
            {
                cmd.Dispose();
                con.Close();
                con.Dispose();
                throw;
            }
        } 
        #endregion
    }

分页

public DataTable GetDataByPage(int start,int end)
        {
            string sql = "select * from(select *,num=ROW_NUMBER() over (order by id) from UserInfo) as t where t.num>@start and t.num<=@end";
            SqlParameter[] pms =
            {
                new SqlParameter("@start",start),
                new SqlParameter("@end",end), 
            };
            return helper.ExecuteTable(sql, CommandType.Text, pms);
        }

存储过程

private void LoadData(int index)
        {
            string sql = "usp_UserInfoPage";
            SqlParameter[] pms = {
                                     new SqlParameter("@pageIndex",index),
                                     new SqlParameter("@pageSize",PageSize),
                                     new SqlParameter("@pageCount",SqlDbType.Int){Direction=ParameterDirection.Output},
                                     new SqlParameter("@totalCount",SqlDbType.Int){Direction=ParameterDirection.Output}
                                 };

            DataTable dt = db.ExecuteTable(sql, CommandType.StoredProcedure, pms);
            List<ClassInfo> list = new List<ClassInfo>();
            foreach (DataRow item in dt.Rows)
            {
                ClassInfo model = new ClassInfo();
                model.Id = Convert.ToInt32(item["Id"]);
                model.name = item["name"].ToString();
                model.pwd = item["pwd"].ToString();
                list.Add(model);
            }
            dataGridView1.DataSource = list;
            pageCount = Convert.ToInt32(pms[2].Value);
            totalCounnt = Convert.ToInt32(pms[3].Value);
            label6.Text = string.Format("{0}/{1}", index, pageCount);
        }
create database UserDB
go
use UserDB
go
create table Userinfo(
    ID int primary key identity ,
    name varchar(20) not null,
    pwd varchar(20) not null
)
insert into Userinfo values('sasas','1231231')
insert into Userinfo values('sasas','1231231')
insert into Userinfo values('sasas','1231231')
insert into Userinfo values('admin','123456')
select id,name,pwd from userinfo
go
create proc usp_UserInfoPage
@pageIndex int,
@pageSize int,
@pageCount int output,
@totalCount int output
as
begin
    --查询总条数
    select @totalCount = COUNT(*) from UserInfo
    --查询总页数
    set @pageCount = CEILING(@totalCount*1.0/@pageSize)
    --查询语句
    select * from (select *,num=ROW_NUMBER() over(order by Id) from UserInfo) as t where t.num>(@pageIndex-1)*@pageSize and t.num<=@pageIndex*@pageSize
end
select * from (select *,num=row_number() over(order by id) from userInfo) as t where t.num>0 and t.num<=4

 

上一篇:Android系统启动流程


下一篇:discuz之——Table 'uc.uc_pms' doesn't exist,uc_pms不存在解决