using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using ZXDT.DBUtility;
using System.Data;
using System.Data.SqlClient;
using ZXDT.CallCenter.Model;
namespace ZXDT.CallCenter.DAL
{
///
/// 数据访问类:T_Sys_Department
///
public partial class T_Sys_Department
{
public T_Sys_Department()
{ }
#region BasicMethod
///
/// 是否存在该记录
///
public bool Exists(int F_DeptId)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select count(1) from T_Sys_Department");
strSql.Append(" where F_DeptId=@F_DeptId");
SqlParameter[] parameters = {
new SqlParameter("@F_DeptId", SqlDbType.Int,4)
};
parameters[0].Value = F_DeptId;
return DbHelperSQL.Exists(strSql.ToString(), parameters);
}
///
/// 增加一条数据
///
public int Add(ZXDT.CallCenter.Model.T_Sys_Department model)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("insert into T_Sys_Department(");
strSql.Append("F_DeptCode,F_ParentName,F_ParentId,F_ParentCode,F_DeptName,F_State,F_Layer,F_Type,F_Sort,F_Remark,F_Telephone,F_Mobile,F_OtherPhone,F_Email,F_Header)");
strSql.Append(" values (");
strSql.Append("@F_DeptCode,@F_ParentName,@F_ParentId,@F_ParentCode,@F_DeptName,@F_State,@F_Layer,@F_Type,@F_Sort,@F_Remark,@F_Telephone,@F_Mobile,@F_OtherPhone,@F_Email,@F_Header)");
strSql.Append(";select @@IDENTITY");
SqlParameter[] parameters = {
new SqlParameter("@F_DeptCode", SqlDbType.VarChar,50),
new SqlParameter("@F_ParentName", SqlDbType.VarChar,50),
new SqlParameter("@F_ParentId", SqlDbType.Int,4),
new SqlParameter("@F_ParentCode", SqlDbType.VarChar,50),
new SqlParameter("@F_DeptName", SqlDbType.VarChar,60),
new SqlParameter("@F_State", SqlDbType.Int,4),
new SqlParameter("@F_Layer", SqlDbType.Int,4),
new SqlParameter("@F_Type", SqlDbType.Int,4),
new SqlParameter("@F_Sort", SqlDbType.Int,4),
new SqlParameter("@F_Remark", SqlDbType.VarChar,200),
new SqlParameter("@F_Telephone", SqlDbType.VarChar,50),
new SqlParameter("@F_Mobile", SqlDbType.VarChar,50),
new SqlParameter("@F_OtherPhone", SqlDbType.VarChar,50),
new SqlParameter("@F_Email", SqlDbType.VarChar,50),
new SqlParameter("@F_Header", SqlDbType.Int,4)};
parameters[0].Value = model.F_DeptCode;
parameters[1].Value = model.F_ParentName;
parameters[2].Value = model.F_ParentId;
parameters[3].Value = model.F_ParentCode;
parameters[4].Value = model.F_DeptName;
parameters[5].Value = model.F_State;
parameters[6].Value = model.F_Layer;
parameters[7].Value = model.F_Type;
parameters[8].Value = model.F_Sort;
parameters[9].Value = model.F_Remark;
parameters[10].Value = model.F_Telephone;
parameters[11].Value = model.F_Mobile;
parameters[12].Value = model.F_OtherPhone;
parameters[13].Value = model.F_Email;
parameters[14].Value = model.F_Header;
object obj = DbHelperSQL.GetSingle(strSql.ToString(), parameters);
if (obj == null)
{
return 0;
}
else
{
return Convert.ToInt32(obj);
}
}
///
/// 更新一条数据
///
public bool Update(ZXDT.CallCenter.Model.T_Sys_Department model)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("update T_Sys_Department set ");
strSql.Append("F_DeptCode=@F_DeptCode,");
strSql.Append("F_ParentName=@F_ParentName,");
strSql.Append("F_ParentId=@F_ParentId,");
strSql.Append("F_ParentCode=@F_ParentCode,");
strSql.Append("F_DeptName=@F_DeptName,");
strSql.Append("F_State=@F_State,");
strSql.Append("F_Layer=@F_Layer,");
strSql.Append("F_Type=@F_Type,");
strSql.Append("F_Sort=@F_Sort,");
strSql.Append("F_Remark=@F_Remark,");
strSql.Append("F_Telephone=@F_Telephone,");
strSql.Append("F_Mobile=@F_Mobile,");
strSql.Append("F_OtherPhone=@F_OtherPhone,");
strSql.Append("F_Email=@F_Email,");
strSql.Append("F_Header=@F_Header");
strSql.Append(" where F_DeptId=@F_DeptId");
SqlParameter[] parameters = {
new SqlParameter("@F_DeptCode", SqlDbType.VarChar,50),
new SqlParameter("@F_ParentName", SqlDbType.VarChar,50),
new SqlParameter("@F_ParentId", SqlDbType.Int,4),
new SqlParameter("@F_ParentCode", SqlDbType.VarChar,50),
new SqlParameter("@F_DeptName", SqlDbType.VarChar,60),
new SqlParameter("@F_State", SqlDbType.Int,4),
new SqlParameter("@F_Layer", SqlDbType.Int,4),
new SqlParameter("@F_Type", SqlDbType.Int,4),
new SqlParameter("@F_Sort", SqlDbType.Int,4),
new SqlParameter("@F_Remark", SqlDbType.VarChar,200),
new SqlParameter("@F_Telephone", SqlDbType.VarChar,50),
new SqlParameter("@F_Mobile", SqlDbType.VarChar,50),
new SqlParameter("@F_OtherPhone", SqlDbType.VarChar,50),
new SqlParameter("@F_Email", SqlDbType.VarChar,50),
new SqlParameter("@F_Header", SqlDbType.Int,4),
new SqlParameter("@F_DeptId", SqlDbType.Int,4)};
parameters[0].Value = model.F_DeptCode;
parameters[1].Value = model.F_ParentName;
parameters[2].Value = model.F_ParentId;
parameters[3].Value = model.F_ParentCode;
parameters[4].Value = model.F_DeptName;
parameters[5].Value = model.F_State;
parameters[6].Value = model.F_Layer;
parameters[7].Value = model.F_Type;
parameters[8].Value = model.F_Sort;
parameters[9].Value = model.F_Remark;
parameters[10].Value = model.F_Telephone;
parameters[11].Value = model.F_Mobile;
parameters[12].Value = model.F_OtherPhone;
parameters[13].Value = model.F_Email;
parameters[14].Value = model.F_Header;
parameters[15].Value = model.F_DeptId;
int rows = DbHelperSQL.ExecuteSql(strSql.ToString(), parameters);
if (rows > 0)
{
return true;
}
else
{
return false;
}
}
///
/// 删除一条数据
///
public bool Delete(int F_DeptId)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("delete from T_Sys_Department ");
strSql.Append(" where F_DeptId=@F_DeptId");
SqlParameter[] parameters = {
new SqlParameter("@F_DeptId", SqlDbType.Int,4)
};
parameters[0].Value = F_DeptId;
int rows = DbHelperSQL.ExecuteSql(strSql.ToString(), parameters);
if (rows > 0)
{
return true;
}
else
{
return false;
}
}
///
/// 批量删除数据
///
public bool DeleteList(string F_DeptIdlist)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("delete from T_Sys_Department ");
strSql.Append(" where F_DeptId in (" + F_DeptIdlist + ") ");
int rows = DbHelperSQL.ExecuteSql(strSql.ToString());
if (rows > 0)
{
return true;
}
else
{
return false;
}
}
///
/// 得到一个对象实体
///
public ZXDT.CallCenter.Model.T_Sys_Department GetModel(int F_DeptId)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select top 1 F_DeptId,F_DeptCode,F_ParentName,F_ParentId,F_ParentCode,F_DeptName,F_State,F_Layer,F_Type,F_Sort,F_Remark,F_Telephone,F_Mobile,F_OtherPhone,F_Email,F_Header from T_Sys_Department ");
strSql.Append(" where F_DeptId=@F_DeptId");
SqlParameter[] parameters = {
new SqlParameter("@F_DeptId", SqlDbType.Int,4)
};
parameters[0].Value = F_DeptId;
ZXDT.CallCenter.Model.T_Sys_Department model = new ZXDT.CallCenter.Model.T_Sys_Department();
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 ZXDT.CallCenter.Model.T_Sys_Department GetModel(string where)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select top 1 F_DeptId,F_DeptCode,F_ParentName,F_ParentId,F_ParentCode,F_DeptName,F_State,F_Layer,F_Type,F_Sort,F_Remark,F_Telephone,F_Mobile,F_OtherPhone,F_Email,F_Header from T_Sys_Department ");
strSql.Append(" where "+ where);
ZXDT.CallCenter.Model.T_Sys_Department model = new ZXDT.CallCenter.Model.T_Sys_Department();
DataSet ds = DbHelperSQL.Query(strSql.ToString());
if (ds.Tables[0].Rows.Count > 0)
{
return DataRowToModel(ds.Tables[0].Rows[0]);
}
else
{
return null;
}
}
///
/// 得到一个对象实体
///
public ZXDT.CallCenter.Model.T_Sys_Department DataRowToModel(DataRow row)
{
ZXDT.CallCenter.Model.T_Sys_Department model = new ZXDT.CallCenter.Model.T_Sys_Department();
if (row != null)
{
if (row["F_DeptId"] != null && row["F_DeptId"].ToString() != "")
{
model.F_DeptId = int.Parse(row["F_DeptId"].ToString());
}
if (row["F_DeptCode"] != null)
{
model.F_DeptCode = row["F_DeptCode"].ToString();
}
if (row["F_ParentName"] != null)
{
model.F_ParentName = row["F_ParentName"].ToString();
}
if (row["F_ParentId"] != null && row["F_ParentId"].ToString() != "")
{
model.F_ParentId = int.Parse(row["F_ParentId"].ToString());
}
if (row["F_ParentCode"] != null)
{
model.F_ParentCode = row["F_ParentCode"].ToString();
}
if (row["F_DeptName"] != null)
{
model.F_DeptName = row["F_DeptName"].ToString();
}
if (row["F_State"] != null && row["F_State"].ToString() != "")
{
model.F_State = int.Parse(row["F_State"].ToString());
}
if (row["F_Layer"] != null && row["F_Layer"].ToString() != "")
{
model.F_Layer = int.Parse(row["F_Layer"].ToString());
}
if (row["F_Type"] != null && row["F_Type"].ToString() != "")
{
model.F_Type = int.Parse(row["F_Type"].ToString());
}
if (row["F_Sort"] != null && row["F_Sort"].ToString() != "")
{
model.F_Sort = int.Parse(row["F_Sort"].ToString());
}
if (row["F_Remark"] != null)
{
model.F_Remark = row["F_Remark"].ToString();
}
if (row["F_Telephone"] != null)
{
model.F_Telephone = row["F_Telephone"].ToString();
}
if (row["F_Mobile"] != null)
{
model.F_Mobile = row["F_Mobile"].ToString();
}
if (row["F_OtherPhone"] != null)
{
model.F_OtherPhone = row["F_OtherPhone"].ToString();
}
if (row["F_Email"] != null)
{
model.F_Email = row["F_Email"].ToString();
}
if (row["F_Header"] != null && row["F_Header"].ToString() != "")
{
model.F_Header = int.Parse(row["F_Header"].ToString());
}
}
return model;
}
///
/// 获得数据列表
///
public DataSet GetList(string strWhere)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select F_DeptId,F_DeptCode,F_ParentName,F_ParentId,F_ParentCode,F_DeptName,F_State,F_Layer,F_Type,F_Sort,F_Remark,F_Telephone,F_Mobile,F_OtherPhone,F_Email,F_Header ");
strSql.Append(" FROM T_Sys_Department ");
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_DeptId,F_DeptCode,F_ParentName,F_ParentId,F_ParentCode,F_DeptName,F_State,F_Layer,F_Type,F_Sort,F_Remark,F_Telephone,F_Mobile,F_OtherPhone,F_Email,F_Header ");
strSql.Append(" FROM T_Sys_Department ");
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_Sys_Department ");
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_DeptId desc");
}
strSql.Append(")AS Row, T.* from T_Sys_Department 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());
}
#endregion BasicMethod
#region ExtensionMethod
#endregion ExtensionMethod
#region 获取树结构
///
/// 获得当前节点下的所有子集以tree的格式
///
public TreeNodeModel GetDepartmentJsonModel(int parentId,bool AddUser=false)
{
TreeNodeModel returnModel = new TreeNodeModel();
StringBuilder strSql = new StringBuilder();
strSql.Append("select * ");
strSql.Append(" FROM T_Sys_Department order by F_Sort asc");
DataSet ds = DbHelperSQL.Query(strSql.ToString());
if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
{
TreeNodeModel model = new TreeNodeModel();
if (!false)
{
List modelList = new List();
model.id = 0;
model.name = "郑许地铁";
model.code = 0;
model.iconClose = "../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/1_dclose.png";
model.iconOpen = "../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/1_dopen.png";
model.open = "true";
model.children = modelList;
}
returnModel = GetTreeModel(ds.Tables[0], model, AddUser);
}
return returnModel;
}
///
/// 获取chlid
///
/// 数据结合
/// 当前model
///
public TreeNodeModel GetTreeModel(DataTable table, TreeNodeModel model, bool AddUser,int level=2)
{
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_DeptId"].ToString());
childModel.name = row["F_DeptName"].ToString();
childModel.code = int.Parse(row["F_DeptId"].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.iconClose = string.Format("../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/{0}_dclose.png", level);
childModel.iconOpen = string.Format("../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/{0}_dopen.png", level);
//childModel.iconClose = row["F_Header"].ToMyString();
//childModel.iconOpen = childModel.iconClose + ".png";
childModel.open = "true";
childModel.children = modelList;
model.children.Add(childModel);
GetTreeModel(table, childModel, AddUser, level+1);
}
}
else if(AddUser)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select * ");
strSql.Append(" FROM T_Sys_UserAccount where F_DeptId="+ model.code);
DataSet ds = DbHelperSQL.Query(strSql.ToString());
if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
{
foreach (DataRow row in ds.Tables[0].Rows)
{
List modelList = new List();
TreeNodeModel childModel = new TreeNodeModel();
childModel.id = int.Parse(row["F_UserId"].ToString());
childModel.name = row["F_UserName"].ToString();
childModel.code = int.Parse(row["F_UserId"].ToString());
childModel.iconClose = string.Format("../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/{0}_dclose.png", level);
childModel.iconOpen = string.Format("../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/{0}_dopen.png", level);
childModel.open = "false";
childModel.IsOrPrivate = 1;
childModel.children = modelList;
model.children.Add(childModel);
}
}
}
return model;
}
///
/// 获得当前节点下的所有子集以tree的格式
///
public TreeNodeModel GetDepartmentJsonModelTurn(int parentId, string key = "")
{
TreeNodeModel returnModel = new TreeNodeModel();
StringBuilder strSql = new StringBuilder();
strSql.Append("SELECT * FROM T_Sys_Department ");
if (!string.IsNullOrEmpty(key))
{
strSql.AppendFormat("WHERE (F_DeptName LIKE '%{0}%' OR F_DeptId IN(SELECT F_DeptId FROM dbo.T_Sys_UserAccount WHERE F_UserName LIKE '%{0}%'))", key);
}
strSql.Append(" order by F_Sort asc");
DataSet ds = DbHelperSQL.Query(strSql.ToString());
if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0&& !string.IsNullOrEmpty(key))
{
string strlist = "0";
foreach (DataRow row in ds.Tables[0].Rows)
{
strlist += ",";
strlist += row["F_DeptId"];
strlist += ",";
strlist += row["F_ParentId"];
}
strSql.Clear();
strSql.Append("SELECT * FROM T_Sys_Department ");
strSql.AppendFormat("WHERE F_DeptId IN({0})", strlist);
strSql.Append(" order by F_Sort asc");
ds = DbHelperSQL.Query(strSql.ToString());
}
if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
{
TreeNodeModel model = new TreeNodeModel();
if (!false)
{
List modelList = new List();
model.id = 0;
model.name = "郑州地铁";
model.code = 0;
model.iconClose = "../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/1_dclose.png";
model.iconOpen = "../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/1_dopen.png";
model.open = "true";
model.children = modelList;
}
returnModel = GetTreeModelTurnDept(ds.Tables[0], model, key);
}
return returnModel;
}
///
/// 获取chlid
///
/// 数据结合
/// 当前model
///
public TreeNodeModel GetTreeModelTurnDept(DataTable table, TreeNodeModel model, string key = "", int level = 2)
{
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_DeptId"].ToString());
childModel.name = row["F_DeptName"].ToString();
childModel.code = int.Parse(row["F_DeptId"].ToString());
childModel.iconClose = string.Format("../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/{0}_dclose.png", level);
childModel.iconOpen = string.Format("../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/{0}_dopen.png", level);
//childModel.iconClose = row["F_Header"].ToMyString();
//childModel.iconOpen = childModel.iconClose + ".png";
//if (row["F_DeptName"].ToString() == "郑州地铁" || row["F_DeptName"].ToString() == "运营分公司")
//{
childModel.open = "true";
//}
//else {
// childModel.open = "false";
//}
childModel.children = modelList;
model.children.Add(childModel);
GetTreeModelTurnDept(table, childModel, key,level+1);
}
}
else if (model.name.Contains(key) || string.IsNullOrEmpty(key))
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select * ");
strSql.Append(" FROM T_Sys_UserAccount where F_DeptId=" + model.code);
DataSet ds = DbHelperSQL.Query(strSql.ToString());
if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
{
foreach (DataRow row in ds.Tables[0].Rows)
{
List modelList = new List();
TreeNodeModel childModel = new TreeNodeModel();
childModel.id = int.Parse(row["F_UserId"].ToString());
childModel.name = row["F_UserName"].ToString();
childModel.code = int.Parse(row["F_UserId"].ToString());
childModel.iconClose = string.Format("../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/{0}_dclose.png", level);
childModel.iconOpen = string.Format("../../Content/layui/zTree/v3/css/zTreeStyle/img/diy/{0}_dopen.png", level);
childModel.open = "false";
childModel.IsOrPrivate = 1;
childModel.children = modelList;
model.children.Add(childModel);
}
}
}
else
{
StringBuilder strSql = new StringBuilder();
strSql.Append("select * ");
strSql.AppendFormat(" FROM T_Sys_UserAccount where F_DeptId={0} AND F_UserName LIKE '%{1}%'", model.code,key);
DataSet ds = DbHelperSQL.Query(strSql.ToString());
if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0)
{
foreach (DataRow row in ds.Tables[0].Rows)
{
List modelList = new List();
TreeNodeModel childModel = new TreeNodeModel();
childModel.id = int.Parse(row["F_UserId"].ToString());
childModel.name = row["F_UserName"].ToString();
childModel.code = int.Parse(row["F_UserId"].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 = "false";
childModel.IsOrPrivate = 1;
childModel.children = modelList;
model.children.Add(childModel);
}
}
}
return model;
}
#endregion
}
}