110,534
社区成员
发帖
与我相关
我的任务
分享
public static void ConvertToModel<T>(T t, OracleDataReader dr)
{
if (dr.Read())
{
Type type = typeof(T);
for (int i = 0; i < dr.FieldCount; i++)
{
object tempValue = null;
if (dr.IsDBNull(i))
{
if (type.GetProperty(dr.GetName(i)) != null)
{
string typeFullName = type.GetProperty(dr.GetName(i)).PropertyType.FullName;
//这里是字段的值为空的话,获取该字段的类型,根据字段类型初始化一个默认值
tempValue = CheckMethods.GetDefaultValue(typeFullName);
}
}
else
{
tempValue = dr.GetValue(i);
}
if (type.GetProperty(dr.GetName(i)) != null)
{
type.GetProperty(dr.GetName(i)).SetValue(t, Convert.ChangeType(tempValue, type.GetProperty(dr.GetName(i)).PropertyType), null);
}
}
}
dr.Close();
}
public M.Advance400Model GetAdv400ById(string sId)
{
string strSql = "select * from advance400 where id=1";
M.Advance400Model adv400 = new M.Advance400Model();
DBHelp.OracleDBHelper.ConvertToModel<M.Advance400Model>(adv400, DBHelp.OracleDBHelper.GetDataReaderBySql(strSql));
return adv400;
}
DataSet ds= SqlHelper.GetPage(SqlHelper.dbACYY, table, pageSize, pageIndex, fields, sbWhere.ToString(), order, out recordCount);
DataTable dt = ds.Tables[0];
List<Model.AdminNavigation> list = new List<Model.AdminNavigation>();
foreach (DataRow item in dt.Rows)
{
Model.AdminNavigation model = new Model.AdminNavigation();
model.NavID = item["NavID"] is DBNull ? 0 : Convert.ToInt32(item["NavID"]);
model.NavName = item["NavName"] is DBNull ? string.Empty : Convert.ToString(item["NavName"]);
model.ParentID = item["ParentID"] is DBNull ? 0 : Convert.ToInt32(item["ParentID"]);
model.IsNav = item["IsNav"] is DBNull ? false : Convert.ToBoolean(item["IsNav"]);
model.NavUrl = item["NavUrl"] is DBNull ? string.Empty : Convert.ToString(item["NavUrl"]);
model.Sort = item["Sort"] is DBNull ? 0 : Convert.ToInt32(item["Sort"]);
model.Remark = item["Remark"] is DBNull ? string.Empty : Convert.ToString(item["Remark"]);
model.PermissionCode = item["PermissionCode"] is DBNull ? 0 : Convert.ToInt32(item["PermissionCode"]);
model.PermissionFile = item["PermissionFile"] is DBNull ? string.Empty : Convert.ToString(item["PermissionFile"]);
list.Add(model);
}