/// <summary>
/// 기본코드를 트리구조로 표시하는 메인 함수
/// </summary>
/// <param name="tv">트리뷰 컨트롤</param>
/// <returns>데이터가 있으면 데이터의 개수, 그렇지않으면 0</returns>
static public int F_SNPCODE_TREE(TreeView tv, string strGroup="", string strCode="", string strCodeName="")
{
try
{
if (OpenDB() == false)
return 0;
Cursor.Current = Cursors.WaitCursor;
tv.Nodes.Clear();
List<BaseCodeItem> lstCode = new List<BaseCodeItem>();
SqlDataReader ds = null;
SqlCommand cmd = new SqlCommand();
cmd.Connection = m_dbConn;
cmd.CommandType = CommandType.StoredProcedure;
cmd.CommandText = "SP_GET_CODE_TREE";
cmd.Parameters.AddWithValue("@V_GROUP", strGroup);
cmd.Parameters.AddWithValue("@V_CODE", strCode);
cmd.Parameters.AddWithValue("@V_NAME", strCodeName);
//cmd.Parameters.AddWithValue("@V_ORDER", "[BASE_ID]");
ds = cmd.ExecuteReader();
if (ds.HasRows)
{ //HID, HidLevel,[PATH],[BASE_ID],[GROUP],GRPNAME,[NAME],C.[ENAME],C.[VALUE],C.[DESC],C.[ORDER],[YN],[YN_DATE],[REG_DATE],[CDATE]
while (ds.Read())
{
BaseCodeItem code = new BaseCodeItem();
int i = -1;
if (ds.IsDBNull(++i) == false)
code.hid = SqlHierarchyId.Parse(ds["HID"].ToString());
if (ds.IsDBNull(++i) == false)
code.level = Convert.ToInt32(ds[i].ToString());
if (ds.IsDBNull(++i) == false)
code.path = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.id = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.group = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.gname = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.name = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.ename = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.val = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.desc = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.order = Convert.ToInt32(ds[i].ToString());
if (ds.IsDBNull(++i) == false)
code.yn = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.yn_date = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.regdate = ds[i].ToString();
if (ds.IsDBNull(++i) == false)
code.cdate = ds[i].ToString();
lstCode.Add(code);
}
}
CloseDB();
LoadTreeBaseCodes(tv, lstCode);
tv.ExpandAll();
}
catch (Exception er)
{
Console.WriteLine(string.Format("[SNPSqlLib=>LoadData] {0}", er.Message));
}
finally
{
CloseDB();
}
Cursor.Current = Cursors.Default;
return 0;
}
/// <summary>
/// hierarchyid 데이터형을 가지고 트리를 구성한다.
/// </summary>
/// <param name="tv">트리뷰 컨트롤</param>
/// <param name="lstCode">List<BaseCodeItem></param>
static private void LoadTreeBaseCodes(TreeView tv, List<BaseCodeItem> lstCode)
{
try
{
tv.Nodes.Clear();
TreeNode node;
//Top Node
//SqlHierarchyId hid = new SqlHierarchyId();
IEnumerable<BaseCodeItem> rows = from order in lstCode.AsEnumerable()
where order.level == 1
select order;
foreach (BaseCodeItem it in rows)
{
node = new TreeNode(it.name);
node.Tag = it;
LoadNodeBaseCodes(node, lstCode);
tv.Nodes.Add(node);
}
}
catch (Exception er)
{
Console.WriteLine(string.Format("[SNPSqlLib=>LoadNodeBaseCodes] {0}", er.Message));
}
}
/// <summary>
/// hierarchyid 데이터형을 가지고 하위트리를 구성한다.
/// </summary>
/// <param name="parentNode">상위 트리노드</param>
/// <param name="lstCode">List<BaseCodeItem></param>
static private void LoadNodeBaseCodes(TreeNode parentNode, List<BaseCodeItem> lstCode)
{
try
{
parentNode.Nodes.Clear();
SqlHierarchyId hid = new SqlHierarchyId();
BaseCodeItem itParent = (BaseCodeItem)parentNode.Tag;
hid = (SqlHierarchyId)itParent.hid;
IEnumerable<BaseCodeItem> rows = from order in lstCode.AsEnumerable()
where order.hid.GetAncestor(1).Equals(hid)
select order;
foreach (BaseCodeItem it in rows)
{
TreeNode node = new TreeNode(it.name);
node.Tag = it;
LoadNodeBaseCodes(node, lstCode);
parentNode.Nodes.Add(node);
}
}
catch (Exception er)
{
Console.WriteLine(string.Format("[SNPSqlLib=>LoadNodeBaseCodes] {0}", er.Message));
}
}
출처: https://devdb.tistory.com/20 [DB 관련:티스토리]
'DB 관련' 카테고리의 다른 글
[MSSql] Excel 읽기, 불러오기 (0) | 2024.12.27 |
---|---|
[MSSql] varbinary 데이터를 파일로 저장하는 방법 (0) | 2024.12.27 |
[MsSql] DB의 모든 테이블의 모든 데이터 삭제하는 방법 (0) | 2024.12.27 |
[Firebird] 설치 및 데이타베이스 생성 (0) | 2024.12.27 |
[MsSql] 테이블의 필드값을 행에서 열로 표시한다.(PIVOT 함수 사용) (0) | 2024.12.27 |