using System;
using System.Data;
using System.Text;
using System.Data.SqlClient;
using YTSoft.DBUtility;
using YTSoft.BaseCallCenter.Model;
using System.Collections.Generic;
namespace YTSoft.BaseCallCenter.DAL
{
///
/// 数据访问类:T_RepositoryCategory
///
public partial class T_RepositoryCategory
{
public T_RepositoryCategory()
{}
#region BasicMethod
///
/// 得到最大ID
///
public int GetMaxId()
{
return DbHelperSQL.GetMaxID("F_CategoryId", "T_RepositoryCategory");
}
///
/// 是否存在该记录
///
public bool Exists(int F_CategoryId)
{
StringBuilder strSql=new StringBuilder();
strSql.Append("select count(1) from T_RepositoryCategory");
strSql.Append(" where F_CategoryId=@F_CategoryId");
SqlParameter[] parameters = {
new SqlParameter("@F_CategoryId", SqlDbType.Int,4)
};
parameters[0].Value = F_CategoryId;
return DbHelperSQL.Exists(strSql.ToString(),parameters);
}
///
/// 增加一条数据
///
public int Add(YTSoft.BaseCallCenter.Model.T_RepositoryCategory model)
{
StringBuilder strSql=new StringBuilder();
strSql.Append("insert into T_RepositoryCategory(");
strSql.Append("F_CategoryNumber,F_CategoryName,F_CategoryEName,F_Layer,F_ParentId,F_CategoryType,F_CanDelete,F_IsCommon,F_Sort,F_Expand1,F_Expand2,F_CreateOn,F_CreateBy,F_DeleteFlag,F_IsOrPrivate)");
strSql.Append(" values (");
strSql.Append("@F_CategoryNumber,@F_CategoryName,@F_CategoryEName,@F_Layer,@F_ParentId,@F_CategoryType,@F_CanDelete,@F_IsCommon,@F_Sort,@F_Expand1,@F_Expand2,@F_CreateOn,@F_CreateBy,@F_DeleteFlag,@F_IsOrPrivate)");
strSql.Append(";select @@IDENTITY");
SqlParameter[] parameters = {
new SqlParameter("@F_CategoryNumber", SqlDbType.NVarChar,200),
new SqlParameter("@F_CategoryName", SqlDbType.NVarChar,50),
new SqlParameter("@F_CategoryEName", SqlDbType.NVarChar,200),
new SqlParameter("@F_Layer", SqlDbType.Int,4),
new SqlParameter("@F_ParentId", SqlDbType.Int,4),
new SqlParameter("@F_CategoryType", SqlDbType.SmallInt,2),
new SqlParameter("@F_CanDelete", SqlDbType.SmallInt,2),
new SqlParameter("@F_IsCommon", SqlDbType.SmallInt,2),
new SqlParameter("@F_Sort", SqlDbType.Int,4),
new SqlParameter("@F_Expand1", SqlDbType.NVarChar,50),
new SqlParameter("@F_Expand2", SqlDbType.NVarChar,50),
new SqlParameter("@F_CreateOn", SqlDbType.DateTime),
new SqlParameter("@F_CreateBy", SqlDbType.Int,4),
new SqlParameter("@F_DeleteFlag", SqlDbType.SmallInt,2),
new SqlParameter("@F_IsOrPrivate", SqlDbType.Int,4)};
parameters[0].Value = model.F_CategoryNumber;
parameters[1].Value = model.F_CategoryName;
parameters[2].Value = model.F_CategoryEName;
parameters[3].Value = model.F_Layer;
parameters[4].Value = model.F_ParentId;
parameters[5].Value = model.F_CategoryType;
parameters[6].Value = model.F_CanDelete;
parameters[7].Value = model.F_IsCommon;
parameters[8].Value = model.F_Sort;
parameters[9].Value = model.F_Expand1;
parameters[10].Value = model.F_Expand2;
parameters[11].Value = model.F_CreateOn;
parameters[12].Value = model.F_CreateBy;
parameters[13].Value = model.F_DeleteFlag;
parameters[14].Value = model.F_IsOrPrivate;
object obj = DbHelperSQL.GetSingle(strSql.ToString(),parameters);
if (obj == null)
{
return 0;
}
else
{
return Convert.ToInt32(obj);
}
}
///
/// 更新一条数据
///
public bool Update(YTSoft.BaseCallCenter.Model.T_RepositoryCategory model)
{
StringBuilder strSql=new StringBuilder();
strSql.Append("update T_RepositoryCategory set ");
strSql.Append("F_CategoryNumber=@F_CategoryNumber,");
strSql.Append("F_CategoryName=@F_CategoryName,");
strSql.Append("F_CategoryEName=@F_CategoryEName,");
strSql.Append("F_Layer=@F_Layer,");
strSql.Append("F_ParentId=@F_ParentId,");
strSql.Append("F_CategoryType=@F_CategoryType,");
strSql.Append("F_CanDelete=@F_CanDelete,");
strSql.Append("F_IsCommon=@F_IsCommon,");
strSql.Append("F_Sort=@F_Sort,");
strSql.Append("F_Expand1=@F_Expand1,");
strSql.Append("F_Expand2=@F_Expand2,");
strSql.Append("F_CreateOn=@F_CreateOn,");
strSql.Append("F_CreateBy=@F_CreateBy,");
strSql.Append("F_DeleteFlag=@F_DeleteFlag,");
strSql.Append("F_IsOrPrivate=@F_IsOrPrivate");
strSql.Append(" where F_CategoryId=@F_CategoryId");
SqlParameter[] parameters = {
new SqlParameter("@F_CategoryNumber", SqlDbType.NVarChar,200),
new SqlParameter("@F_CategoryName", SqlDbType.NVarChar,50),
new SqlParameter("@F_CategoryEName", SqlDbType.NVarChar,200),
new SqlParameter("@F_Layer", SqlDbType.Int,4),
new SqlParameter("@F_ParentId", SqlDbType.Int,4),
new SqlParameter("@F_CategoryType", SqlDbType.SmallInt,2),
new SqlParameter("@F_CanDelete", SqlDbType.SmallInt,2),
new SqlParameter("@F_IsCommon", SqlDbType.SmallInt,2),
new SqlParameter("@F_Sort", SqlDbType.Int,4),
new SqlParameter("@F_Expand1", SqlDbType.NVarChar,50),
new SqlParameter("@F_Expand2", SqlDbType.NVarChar,50),
new SqlParameter("@F_CreateOn", SqlDbType.DateTime),
new SqlParameter("@F_CreateBy", SqlDbType.Int,4),
new SqlParameter("@F_DeleteFlag", SqlDbType.SmallInt,2),
new SqlParameter("@F_IsOrPrivate", SqlDbType.Int,4),
new SqlParameter("@F_CategoryId", SqlDbType.Int,4)
};
parameters[0].Value = model.F_CategoryNumber;
parameters[1].Value = model.F_CategoryName;
parameters[2].Value = model.F_CategoryEName;
parameters[3].Value = model.F_Layer;
parameters[4].Value = model.F_ParentId;
parameters[5].Value = model.F_CategoryType;
parameters[6].Value = model.F_CanDelete;
parameters[7].Value = model.F_IsCommon;
parameters[8].Value = model.F_Sort;
parameters[9].Value = model.F_Expand1;
parameters[10].Value = model.F_Expand2;
parameters[11].Value = model.F_CreateOn;
parameters[12].Value = model.F_CreateBy;
parameters[13].Value = model.F_DeleteFlag;
parameters[14].Value = model.F_IsOrPrivate;
parameters[15].Value = model.F_CategoryId;
int rows=DbHelperSQL.ExecuteSql(strSql.ToString(),parameters);
if (rows > 0)
{
return true;
}
else
{
return false;
}
}
///
/// 删除一条数据
///
public bool Delete(int F_CategoryId)
{
StringBuilder strSql=new StringBuilder();
//strSql.Append("delete from T_RepositoryCategory ");
strSql.Append("update T_RepositoryCategory set F_DeleteFlag=1");
strSql.Append(" where F_CategoryId=@F_CategoryId");
SqlParameter[] parameters = {
new SqlParameter("@F_CategoryId", SqlDbType.Int,4)
};
parameters[0].Value = F_CategoryId;
int rows=DbHelperSQL.ExecuteSql(strSql.ToString(),parameters);
if (rows > 0)
{
return true;
}
else
{
return false;
}
}
///
/// 批量删除数据
///
public bool DeleteList(string F_CategoryIdlist )
{
StringBuilder strSql=new StringBuilder();
strSql.Append("delete from T_RepositoryCategory ");
strSql.Append(" where F_CategoryId in ("+F_CategoryIdlist + ") ");
int rows=DbHelperSQL.ExecuteSql(strSql.ToString());
if (rows > 0)
{
return true;
}
else
{
return false;
}
}
///
/// 得到一个对象实体
///
public YTSoft.BaseCallCenter.Model.T_RepositoryCategory GetModel(int F_CategoryId)
{
StringBuilder strSql=new StringBuilder();
strSql.Append("select top 1 F_CategoryId,F_CategoryNumber,F_CategoryName,F_CategoryEName,F_Layer,F_ParentId,F_CategoryType,F_CanDelete,F_IsCommon,F_Sort,F_Expand1,F_Expand2,F_CreateOn,F_CreateBy,F_DeleteFlag,F_IsOrPrivate from T_RepositoryCategory ");
strSql.Append(" where F_CategoryId=@F_CategoryId");
SqlParameter[] parameters = {
new SqlParameter("@F_CategoryId", SqlDbType.Int,4)
};
parameters[0].Value = F_CategoryId;
YTSoft.BaseCallCenter.Model.T_RepositoryCategory model=new YTSoft.BaseCallCenter.Model.T_RepositoryCategory();
DataSet ds=DbHelperSQL.Query(strSql.ToString(),parameters);
if(ds.Tables[0].Rows.Count>0)
{
return DataRowToModel(ds.Tables[0].Rows[0]);
}
else
{
return null;
}
}
///
/// 得到一个对象实体
///
public YTSoft.BaseCallCenter.Model.T_RepositoryCategory DataRowToModel(DataRow row)
{
YTSoft.BaseCallCenter.Model.T_RepositoryCategory model=new YTSoft.BaseCallCenter.Model.T_RepositoryCategory();
if (row != null)
{
if(row["F_CategoryId"]!=null && row["F_CategoryId"].ToString()!="")
{
model.F_CategoryId=int.Parse(row["F_CategoryId"].ToString());
}
if(row["F_CategoryNumber"]!=null)
{
model.F_CategoryNumber=row["F_CategoryNumber"].ToString();
}
if(row["F_CategoryName"]!=null)
{
model.F_CategoryName=row["F_CategoryName"].ToString();
}
if(row["F_CategoryEName"]!=null)
{
model.F_CategoryEName=row["F_CategoryEName"].ToString();
}
if(row["F_Layer"]!=null && row["F_Layer"].ToString()!="")
{
model.F_Layer=int.Parse(row["F_Layer"].ToString());
}
if(row["F_ParentId"]!=null && row["F_ParentId"].ToString()!="")
{
model.F_ParentId=int.Parse(row["F_ParentId"].ToString());
}
if(row["F_CategoryType"]!=null && row["F_CategoryType"].ToString()!="")
{
model.F_CategoryType=int.Parse(row["F_CategoryType"].ToString());
}
if(row["F_CanDelete"]!=null && row["F_CanDelete"].ToString()!="")
{
model.F_CanDelete=int.Parse(row["F_CanDelete"].ToString());
}
if(row["F_IsCommon"]!=null && row["F_IsCommon"].ToString()!="")
{
model.F_IsCommon=int.Parse(row["F_IsCommon"].ToString());
}
if(row["F_Sort"]!=null && row["F_Sort"].ToString()!="")
{
model.F_Sort=int.Parse(row["F_Sort"].ToString());
}
if(row["F_Expand1"]!=null)
{
model.F_Expand1=row["F_Expand1"].ToString();
}
if(row["F_Expand2"]!=null)
{
model.F_Expand2=row["F_Expand2"].ToString();
}
if(row["F_CreateOn"]!=null && row["F_CreateOn"].ToString()!="")
{
model.F_CreateOn=DateTime.Parse(row["F_CreateOn"].ToString());
}
if(row["F_CreateBy"]!=null && row["F_CreateBy"].ToString()!="")
{
model.F_CreateBy=int.Parse(row["F_CreateBy"].ToString());
}
if(row["F_DeleteFlag"]!=null && row["F_DeleteFlag"].ToString()!="")
{
model.F_DeleteFlag=int.Parse(row["F_DeleteFlag"].ToString());
}
if (row["F_IsOrPrivate"] != null && row["F_IsOrPrivate"].ToString() != "")
{
model.F_IsOrPrivate = int.Parse(row["F_IsOrPrivate"].ToString());
}
}
return model;
}
///
/// 获得数据列表
///
public DataSet GetList(string strWhere)
{
StringBuilder strSql=new StringBuilder();
strSql.Append("select F_CategoryId,F_CategoryNumber,F_CategoryName,F_CategoryEName,F_Layer,F_ParentId,F_CategoryType,F_CanDelete,F_IsCommon,F_Sort,F_Expand1,F_Expand2,F_CreateOn,F_CreateBy,F_DeleteFlag,F_IsOrPrivate ");
strSql.Append(" FROM T_RepositoryCategory ");
if(strWhere.Trim()!="")
{
strSql.Append(" where "+strWhere);
}
return DbHelperSQL.Query(strSql.ToString());
}
///
/// 获得前几行数据
///
public DataSet GetList(int Top,string strWhere,string filedOrder)
{
StringBuilder strSql=new StringBuilder();
strSql.Append("select ");
if(Top>0)
{
strSql.Append(" top "+Top.ToString());
}
strSql.Append(" F_CategoryId,F_CategoryNumber,F_CategoryName,F_CategoryEName,F_Layer,F_ParentId,F_CategoryType,F_CanDelete,F_IsCommon,F_Sort,F_Expand1,F_Expand2,F_CreateOn,F_CreateBy,F_DeleteFlag,F_IsOrPrivate ");
strSql.Append(" FROM T_RepositoryCategory ");
if(strWhere.Trim()!="")
{
strSql.Append(" where "+strWhere);
}
strSql.Append(" order by " + filedOrder);
return DbHelperSQL.Query(strSql.ToString());
}
///
/// 获取记录总数
///
public int GetRecordCount(string strWhere)
{
StringBuilder strSql=new StringBuilder();
strSql.Append("select count(1) FROM T_RepositoryCategory ");
if(strWhere.Trim()!="")
{
strSql.Append(" where "+strWhere);
}
object obj = DbHelperSQL.GetSingle(strSql.ToString());
if (obj == null)
{
return 0;
}
else
{
return Convert.ToInt32(obj);
}
}
///
/// 分页获取数据列表
///
public DataSet GetListByPage(string strWhere, string orderby, int startIndex, int endIndex)
{
StringBuilder strSql=new StringBuilder();
strSql.Append("SELECT * FROM ( ");
strSql.Append(" SELECT ROW_NUMBER() OVER (");
if (!string.IsNullOrEmpty(orderby.Trim()))
{
strSql.Append("order by T." + orderby );
}
else
{
strSql.Append("order by T.F_CategoryId desc");
}
strSql.Append(")AS Row, T.* from T_RepositoryCategory T ");
if (!string.IsNullOrEmpty(strWhere.Trim()))
{
strSql.Append(" WHERE " + strWhere);
}
strSql.Append(" ) TT");
strSql.AppendFormat(" WHERE TT.Row between {0} and {1}", startIndex, endIndex);
return DbHelperSQL.Query(strSql.ToString());
}
/*
///
/// 分页获取数据列表
///
public DataSet GetList(int PageSize,int PageIndex,string strWhere)
{
SqlParameter[] parameters = {
new SqlParameter("@tblName", SqlDbType.VarChar, 255),
new SqlParameter("@fldName", SqlDbType.VarChar, 255),
new SqlParameter("@PageSize", SqlDbType.Int),
new SqlParameter("@PageIndex", SqlDbType.Int),
new SqlParameter("@IsReCount", SqlDbType.Bit),
new SqlParameter("@OrderType", SqlDbType.Bit),
new SqlParameter("@strWhere", SqlDbType.VarChar,1000),
};
parameters[0].Value = "T_RepositoryCategory";
parameters[1].Value = "F_CategoryId";
parameters[2].Value = PageSize;
parameters[3].Value = PageIndex;
parameters[4].Value = 0;
parameters[5].Value = 0;
parameters[6].Value = strWhere;
return DbHelperSQL.RunProcedure("UP_GetRecordByPage",parameters,"ds");
}*/
#endregion BasicMethod
#region 获取树结构
///
/// 获得当前节点下的所有子集以tree的格式
///
public TreeNodeModel GetRepositoryCategoryJsonModel(int parentId)
{
TreeNodeModel returnModel = new TreeNodeModel();
StringBuilder strSql = new StringBuilder();
strSql.Append("select * ");
strSql.Append(" FROM T_RepositoryCategory where F_DeleteFlag=0 order by F_Sort asc");
DataSet ds = DbHelperSQL.Query(strSql.ToString());
if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
{
DataRow[] rows = ds.Tables[0].Select("F_CategoryId=" + parentId);
if (rows != null && rows.Length > 0)
{
TreeNodeModel model = new TreeNodeModel();
List modelList = new List();
model.id = int.Parse(rows[0]["F_CategoryId"].ToString());
model.name = rows[0]["F_CategoryName"].ToString();
model.code = int.Parse(rows[0]["F_CategoryId"].ToString());
model.iconClose = "../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/1_close.png";
model.iconOpen = "../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/1_open.png";
model.open = "true";
model.children = modelList;
model.IsOrPrivate = rows[0]["F_IsOrPrivate"].ToInt32();
returnModel = GetTreeModel(ds.Tables[0], model);
}
}
return returnModel;
}
///
/// 获取chlid
///
/// 数据结合
/// 当前model
///
public TreeNodeModel GetTreeModel(DataTable table, TreeNodeModel model)
{
DataRow[] rows = table.Select("F_ParentId=" + model.code);
if (rows != null && rows.Length > 0)
{
foreach (DataRow row in rows)
{
List modelList = new List();
TreeNodeModel childModel = new TreeNodeModel();
childModel.id = int.Parse(row["F_CategoryId"].ToString());
childModel.name = row["F_CategoryName"].ToString();
childModel.code = int.Parse(row["F_CategoryId"].ToString());
childModel.iconClose = "../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/1_close.png";
childModel.iconOpen = "../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/1_open.png";
childModel.open = "true";
childModel.children = modelList;
model.children.Add(childModel);
GetTreeModel(table, childModel);
}
}
return model;
}
#endregion
}
}