遞歸查詢樹,並綁定到界面控件

一、環境:VS2013 SQL Server2012數據庫

二、數據庫腳本: 數組

with CTE as    
(     
-->Begin 一個定位點成員     
 select Id,MenuName,ParentId,cast(MenuName as nvarchar(max)) as TE,OrderNum,
                --ROW_NUMBER()over(order by getdate()) as OrderID
                CAST( (CASE 
                WHEN OrderNum < 10 THEN '00'+LTRIM(OrderNum)
                ELSE '0'+LTRIM(OrderNum)
                END) AS VARCHAR(100)) AS numstr 
        --最關鍵是上面這個字段,要獲取排序字段,按字符串來排序。  
        --其中窗口函數必需要使用order by,可是不能用整型,那就用時間吧  
        from Main_Menu where ParentId = 0 
-->End      
union all     
-->Begin一個遞歸成員     
 select Main_Menu.ID, Main_Menu.MenuName,Main_Menu.ParentId,cast(replicate(' ',len(CTE.TE))+'|_'+Main_Menu.MenuName as nvarchar(MAX)) as TE,Main_Menu.OrderNum,  
        --CTE.OrderNum*100+Main_Menu.OrderNum as OrderNum
                --Main_Menu.OrderNum
                CAST( (CTE.numstr+
                CASE 
                WHEN Main_Menu.OrderNum < 10 THEN '00'+LTRIM(Main_Menu.OrderNum)
                ELSE '0'+LTRIM(Main_Menu.OrderNum)
                END) AS VARCHAR(100) ) AS numstr 
        from Main_Menu inner join CTE     
        on Main_Menu.ParentId=CTE.Id    
-->End     
)     
select * from CTE  
order by LTRIM(numstr) --最後將這個整型數據轉換爲字符串型的進行排序

三、C#代碼:函數

public class readexcel
    {
        #region Excel2003
        /// <summary>
        /// 將Excel文件中的數據讀出到DataTable中(xls)
        /// </summary>
        /// <param name="file"></param>
        /// <returns></returns>
        public static DataTable ExcelToTableForXLS(string file)
        {
            DataTable dt = new DataTable();
            using (FileStream fs = new FileStream(file, FileMode.Open, FileAccess.Read))
            {
                HSSFWorkbook hssfworkbook = new HSSFWorkbook(fs);
                ISheet sheet = hssfworkbook.GetSheetAt(0);

                //表頭
                IRow header = sheet.GetRow(sheet.FirstRowNum);
                List<int> columns = new List<int>();
                for (int i = 0; i < header.LastCellNum; i++)
                {
                    object obj = GetValueTypeForXLS(header.GetCell(i) as HSSFCell);
                    if (obj == null || obj.ToString() == string.Empty)
                    {
                        dt.Columns.Add(new DataColumn("Columns" + i.ToString()));
                        //continue;
                    }
                    else
                        dt.Columns.Add(new DataColumn(obj.ToString()));
                    columns.Add(i);
                }
                //數據
                for (int i = sheet.FirstRowNum + 1; i <= sheet.LastRowNum; i++)
                {
                    DataRow dr = dt.NewRow();
                    bool hasValue = false;
                    foreach (int j in columns)
                    {
                        if (sheet.GetRow(i)==null)
                        {
                            continue;
                        }
                        dr[j] = GetValueTypeForXLS(sheet.GetRow(i).GetCell(j) as HSSFCell);
                        if (dr[j] != null && dr[j].ToString() != string.Empty)
                        {
                            hasValue = true;
                        }
                    }
                    if (hasValue)
                    {
                        dt.Rows.Add(dr);
                    }
                }
            }
            return dt;
        }

        /// <summary>
        /// 將DataTable數據導出到Excel文件中(xls)
        /// </summary>
        /// <param name="dt"></param>
        /// <param name="file"></param>
        public static void TableToExcelForXLS(DataTable dt, string file)
        {
            HSSFWorkbook hssfworkbook = new HSSFWorkbook();
            ISheet sheet = hssfworkbook.CreateSheet("Test");

            //表頭
            IRow row = sheet.CreateRow(0);
            for (int i = 0; i < dt.Columns.Count; i++)
            {
                ICell cell = row.CreateCell(i);
                cell.SetCellValue(dt.Columns[i].ColumnName);
            }

            //數據
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                IRow row1 = sheet.CreateRow(i + 1);
                for (int j = 0; j < dt.Columns.Count; j++)
                {
                    ICell cell = row1.CreateCell(j);
                    cell.SetCellValue(dt.Rows[i][j].ToString());
                }
            }

            //轉爲字節數組
            MemoryStream stream = new MemoryStream();
            hssfworkbook.Write(stream);
            var buf = stream.ToArray();

            //保存爲Excel文件
            using (FileStream fs = new FileStream(file, FileMode.Create, FileAccess.Write))
            {
                fs.Write(buf, 0, buf.Length);
                fs.Flush();
            }
        }

        /// <summary>
        /// 獲取單元格類型(xls)
        /// </summary>
        /// <param name="cell"></param>
        /// <returns></returns>
        private static object GetValueTypeForXLS(HSSFCell cell)
        {
            if (cell == null)
                return null;
            switch (cell.CellType)
            {
                case CellType.Blank: //BLANK:
                    return null;
                case CellType.Boolean: //BOOLEAN:
                    return cell.BooleanCellValue;
                case CellType.Numeric: //NUMERIC:
                    return cell.NumericCellValue;
                case CellType.String: //STRING:
                    return cell.StringCellValue;
                case CellType.Error: //ERROR:
                    return cell.ErrorCellValue;
                case CellType.Formula: //FORMULA:
                default:
                    return "=" + cell.CellFormula;
            }
        }
        #endregion
    }
相關文章
相關標籤/搜索