博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
反射实体列表
阅读量:6232 次
发布时间:2019-06-21

本文共 4081 字,大约阅读时间需要 13 分钟。

        /// <summary>
        /// 获取单条数据
        /// </summary>
        /// <param name="Id">Id</param>
        /// <returns></returns>
        public LinksEntity GetLinksEntity(Int64 Id)
        {
            LinksEntity LinksEntity = null;
            SqlParameter[] Para = new SqlParameter[1];
            Para[0] = new SqlParameter("@Id", Id);
            DataSet Set = SqlHelper.ExecuteDataSet(CommandType.StoredProcedure, procedurePrefixes + "Links_GetInfoById", Para);
            if (Set.Tables[0].Rows.Count > 0)
            {
                LinksEntity = new LinksEntity();
                DataRow dr = Set.Tables[0].Rows[0];
                foreach (DataColumn dc in dr.Table.Columns)
                {
                    PropertyInfo pi = LinksEntity.GetType().GetProperty(dc.ColumnName);
                    if (pi != null)
                    {
                        if (dr[dc.ColumnName] != DBNull.Value)
                        {
                            if (pi.PropertyType.IsEnum)
                            {
                                pi.SetValue(LinksEntity, Enum.ToObject(pi.PropertyType, dr[dc.ColumnName]), null);
                            }
                            else
                            {
                                pi.SetValue(LinksEntity, dr[dc.ColumnName], null);
                            }
                        }
                        else
                        {
                            pi.SetValue(LinksEntity, null, null);
                        }
                    }
                }
            }
            return LinksEntity;
        }
        /// <summary>
        /// 按条件选择数据
        /// </summary>
        /// <param name="condition">Chaige.Pagination.Condition</param>
        /// <returns></returns>
        public IList<LinksEntity> GetLinksList(Chaige.Pagination.Condition condition)
        {
            IList<LinksEntity> list = new List<LinksEntity>();
            if (condition.TableName == "")
                condition.TableName = tablePrefixes + "Links";
            SqlParameter[] Para = new SqlParameter[5];
            Para[0] = new SqlParameter("@TableName", condition.TableName);
            Para[1] = new SqlParameter("@TopNum", condition.TopNum);
            Para[2] = new SqlParameter("@FieldList", condition.FieldList);
            Para[3] = new SqlParameter("@Conditions", condition.Conditions);
            Para[4] = new SqlParameter("@OrderBy", condition.OrderBy);
            DataSet Set = SqlHelper.ExecuteDataSet(CommandType.StoredProcedure, procedurePrefixes + "Condition", Para);
            foreach (DataRow dr in Set.Tables[0].Rows)
            {
                LinksEntity LinksEntity = new LinksEntity();
                foreach (DataColumn dc in dr.Table.Columns)
                {
                    PropertyInfo pi = LinksEntity.GetType().GetProperty(dc.ColumnName);
                    if (pi != null)
                    {
                        if (dr[dc.ColumnName] != DBNull.Value)
                        {
                            if (pi.PropertyType.IsEnum)
                            {
                                pi.SetValue(LinksEntity, Enum.ToObject(pi.PropertyType, dr[dc.ColumnName]), null);
                            }
                            else
                            {
                                pi.SetValue(LinksEntity, dr[dc.ColumnName], null);
                            }
                        }
                        else
                        {
                            pi.SetValue(LinksEntity, null, null);
                        }
                    }
                }
                list.Add(LinksEntity);
            }
            return list;
        }
        /// <summary>
        /// 分页数据
        /// </summary>
        /// <param name="pagination">Chaige.Pagination.Pagination</param>
        /// <returns></returns>
        public IList<LinksEntity> GetLinksList(Chaige.Pagination.Pagination pagination)
        {
            IList<LinksEntity> list = new List<LinksEntity>();
            if (pagination.TableName == "")
                pagination.TableName = tablePrefixes + "Links";
            SqlParameter[] Para = new SqlParameter[10];
            Para[0] = new SqlParameter("@TableName", pagination.TableName);
            Para[1] = new SqlParameter("@PKey", pagination.PKey);
            Para[2] = new SqlParameter("@FieldList", pagination.FieldList);
            Para[3] = new SqlParameter("@Condition", pagination.Condition);
            Para[4] = new SqlParameter("@OrderBy", pagination.OrderBy);
            Para[5] = new SqlParameter("@Sql", pagination.Sql);
            Para[6] = new SqlParameter("@SqlGetRC", pagination.SqlGetRC);
            Para[7] = new SqlParameter("@CurrPage", pagination.CurrPage);
            Para[8] = new SqlParameter("@PageSize", pagination.PageSize);
            Para[9] = new SqlParameter("@RecordCount", pagination.RecordCount);
            DataSet Set = SqlHelper.ExecuteDataSet(CommandType.StoredProcedure, procedurePrefixes + "Pagination", Para);
            recordcount = int.Parse(Set.Tables[1].Rows[0]["RecordCount"].ToString());
            pagecount = int.Parse(Set.Tables[1].Rows[0]["PageCount"].ToString());
            foreach (DataRow dr in Set.Tables[0].Rows)
            {
                LinksEntity LinksEntity = new LinksEntity();
                foreach (DataColumn dc in dr.Table.Columns)
                {
                    PropertyInfo pi = LinksEntity.GetType().GetProperty(dc.ColumnName);
                    if (pi != null)
                    {
                        if (dr[dc.ColumnName] != DBNull.Value)
                        {
                            if (pi.PropertyType.IsEnum)
                            {
                                pi.SetValue(LinksEntity, Enum.ToObject(pi.PropertyType, dr[dc.ColumnName]), null);
                            }
                            else
                            {
                                pi.SetValue(LinksEntity, dr[dc.ColumnName], null);
                            }
                        }
                        else
                        {
                            pi.SetValue(LinksEntity, null, null);
                        }
                    }
                }
                list.Add(LinksEntity);
            }
            return list;
        }
    }

转载于:https://www.cnblogs.com/jazzka702/archive/2012/10/15/2724345.html

你可能感兴趣的文章
Bacula笔记
查看>>
我的友情链接
查看>>
svn merge以及Unknown action received: skipped conflicted path冲突解决
查看>>
CSS: the different of using CSS between @import and link
查看>>
f2fs 系列之七:page cache相关操作和接口
查看>>
马士兵教学语录
查看>>
ubuntu server 13.10修改引导等待时间与配置更新源
查看>>
leetCode 121. Best Time to Buy and Sell Stock 数组
查看>>
Jquery学习笔记-过滤选择器
查看>>
Android 一个apk多个ICON执行入口
查看>>
我的友情链接
查看>>
nginx安装
查看>>
一个backup exec 2012的真实故障案例,服务无法启动1068
查看>>
我的友情链接
查看>>
Linux基础
查看>>
hadoop+hive环境搭建(centos6.5)-01
查看>>
点到点子接口的帧中继配置
查看>>
计算机网络与Internet应用
查看>>
python md5
查看>>
强制转换与内存
查看>>