知识管理系列---3.程序实现

系列引导:

知识管理系列----1.原型设计

知识管理系列----2.数据库设计

  本项目的ORM框架采用LINQ的核心。所有的增删改查均基于LINQ语法实现。

  按照ORM基本的三层框架:

 

  SQL底层核心:   

        /// <summary>
        /// 查询SQL语句,并将查询结果实例化
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <param name="sql"></param>
        /// <param name="func"></param>
        /// <param name="param"></param>
        /// <returns></returns>
        public static IEnumerable<T> SelectReader<T>(string sql, Func<System.Data.Common.DbDataReader, T> func, params System.Data.Common.DbParameter[] param)
            where T:class
        {
            using (SqlConnection con = new SqlConnection(connectionString))
            {
                SqlCommand cmd = new SqlCommand(sql, con);
                cmd.Connection.Open();
                cmd.Parameters.Clear();
                if (param != null && param.Length > 0)
                {
                     cmd.Parameters.AddRange(param);
                }
                SqlDataReader dr = cmd.ExecuteReader();

                var list = new List<T>();
                while (dr.Read())
                {
                    T t = func(dr);
                    if (t != null)
                        list.Add(t);
                }
                dr.Close();
                return list;
            }
        }
View Code

        Model层:(以g_Node为例)             

using System;
using JackCSoft.DAL;
namespace JackCSoft.Model
{
    /// <summary>
    /// g_Node:实体类(属性说明自动提取数据库字段的描述信息)
    /// </summary>
    [Serializable]
    [SelectContext]
    [ExecuteContext]
    public partial class g_Node
    {
        public g_Node()
        { }
        #region Model
        private int _id = 10000;
        private string _nodename;
        private int _nodetype = 0;
        private int? _create_user;
        private string _create_ymd;
        private string _create_hms;
        private int? _update_user;
        private string _update_ymd;
        private string _update_hms;
        private string _guid = "newid";
        /// <summary>
        /// 
        /// </summary>
        public int ID
        {
            set { _id = value; }
            get { return _id; }
        }
        /// <summary>
        /// 
        /// </summary>
        public string NodeName
        {
            set { _nodename = value; }
            get { return _nodename; }
        }
        /// <summary>
        /// 
        /// </summary>
        public int NodeType
        {
            set { _nodetype = value; }
            get { return _nodetype; }
        }
        /// <summary>
        /// 
        /// </summary>
        public int? create_user
        {
            set { _create_user = value; }
            get { return _create_user; }
        }
        /// <summary>
        /// 
        /// </summary>
        public string create_ymd
        {
            set { _create_ymd = value ; }
            get { return _create_ymd; }
        }
        /// <summary>
        /// 
        /// </summary>
        public string create_hms
        {
            set { _create_hms = value; }
            get { return _create_hms; }
        }
        /// <summary>
        /// 
        /// </summary>
        public int? update_user
        {
            set { _update_user = value; }
            get { return _update_user; }
        }
        /// <summary>
        /// 
        /// </summary>
        public string update_ymd
        {
            set { _update_ymd = value; }
            get { return _update_ymd; }
        }
        /// <summary>
        /// 
        /// </summary>
        public string update_hms
        {
            set { _update_hms = value; }
            get { return _update_hms; }
        }
        /// <summary>
        /// 
        /// </summary>
        public string guid
        {
            set { _guid = value; }
            get { return _guid; }
        }
        #endregion Model

    }
}
View Code

        BLL层:          

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Collections;

using JackCSoft.Model;
using JackCSoft.DAL;
using JackCSoft.CommonLib;
using System.Linq.Expressions;
using System.Data.SqlClient;
using JackCSoft.DBUtility;

namespace JackCSoft.BLL
{
    public class BLL_NodeManager
    {
        CommonLib.TypePropertyOperation typeProperOperation=new TypePropertyOperation();
        BLL_g_Node instance_Node = BLL_g_Node.handler;
        BLL_g_NodeOrder instance_NodeOrder = BLL_g_NodeOrder.handler;

        #region 查询 select
        /// <summary>
        /// 获取顶层node的信息
        /// </summary>
        /// <returns></returns>
        public IEnumerable<g_Node> GetTopNodeInfo()
        {
            var obj = new JackCSoft.Model.g_Node();
            var where = new JackCSoft.Model.g_Node()
            {
                ID = 0,
                NodeType = Convert.ToInt16(NodeTypeEnumer.TopNode)   //顶层Node类型
            };
            return instance_Node.Select(obj, s => s, where, b => new { b.ID, b.NodeType });
        }
        /// <summary>
        /// 获取顶层node的信息
        /// </summary>
        /// <returns></returns>
        public IEnumerable<TResult> GetTopNodeInfo<TResult>(Func<g_Node,TResult> func) 
            where TResult:class
        {
            var obj = new JackCSoft.Model.g_Node();
            var where = new JackCSoft.Model.g_Node()
            {
                ID = 0,
                NodeType = Convert.ToInt16(NodeTypeEnumer.TopNode)   //顶层Node类型
            };
            return instance_Node.Select(obj, s => func(s), where, b => new { b.ID, b.NodeType });
        }

        /// <summary>
        /// 根据指定条件查询Node信息
        /// </summary>
        /// <returns></returns>
        public IEnumerable<TResult> GetNodeInfoByWhere<TResult,TWhere>(Func<g_Node, TResult> func,g_Node entity,Func<g_Node,TWhere> funcWhere)
            where TResult : class
            where TWhere:class
        {
            var obj = new JackCSoft.Model.g_Node();
            return instance_Node.Select(obj, s => func(s),entity,p=>funcWhere(p));
        }

        /// <summary>
        /// 根据GUID查询node信息
        /// </summary>
        /// <param name="guid"></param>
        /// <returns></returns>
        public IEnumerable<g_Node> GetNodeInfoByGUID(string guid)
        {
            var obj = new JackCSoft.Model.g_Node();
            var where = new JackCSoft.Model.g_Node()
            {
                guid=guid
            };
            return instance_Node.Select(obj, s => s, where, p => new { p.guid});
        }

        /// <summary>
        /// 查询该节点类型的最大值
        /// </summary>
        /// <param name="enumer"></param>
        /// <returns></returns>
        public g_Node GetMaxNodeIDByNodeType(int enumer)
        {
            var obj = new JackCSoft.Model.g_Node();
            var where = new JackCSoft.Model.g_Node()
            {
                NodeType=enumer
            };
            IEnumerable<g_Node> result=instance_Node.Select(obj, s => s, where, p => new { p.NodeType }).OrderByDescending(m=>m.ID);
            return (result != null && result.Count() > 0) ? result.ToArray()[0] : null;
        }

        /// <summary>
        /// 查询max id
        /// </summary>
        /// <param name="enumer"></param>
        /// <returns></returns>
        public g_Node GetMaxNodeID()
        {
            var obj = new JackCSoft.Model.g_Node();
            IEnumerable<g_Node> result = instance_Node.Select(s=>s).OrderByDescending(m => m.ID);

            return (result != null && result.Count() > 0) ? result.ToArray()[0] : null;
        }

        public DataTable GetHtmlContentByID(int id)
        {
            return DAL_Node.GetHtmlContentByID(id);
        }
        #endregion

        #region 插入 insert
        /// <summary>
        /// 往g_Node插入节点信息,并在g_NodeOrder表插入节点顺序信息
        /// </summary>
        /// <returns></returns>
        public bool InsertNode<TNode>(g_Node t,Func<g_Node,TNode> func,int parentNodeID) where TNode:class
        {
            //插入g_Node子信息
            bool _insertOk = instance_Node.Insert(t, s => func(s));

            if (_insertOk)
            {
                //查询已经插入的子节点信息 在插入g_NodeOrder表
                Expression<Func<g_Node,object>> selectEntity=s=>new {s.guid,s.ID};
                g_Node obj = new g_Node();

                IEnumerable<object> _resultList = instance_Node.Select(obj, s => selectEntity.Compile()(s), t, p => func(p));
                if (_resultList != null&&_resultList.ToArray().Count()>0)
                {
                    //插入g_NodeOrder数据表数据
                    g_NodeOrder nodeOrder = new g_NodeOrder
                    {
                        //g_NodeOrder的DBNode_GUID对应g_Node的GUID
                        DBNode_GUID = Convert.ToString(typeProperOperation.GetPropertyByNameType("guid",_resultList.ToArray()[0])),
                        //本节点的的ID编号 对应的是g_Node的ID字段
                        NodeOrderLoacte=Convert.ToInt32(typeProperOperation.GetPropertyByNameType("ID", _resultList.ToArray()[0])),
                        //父级节点表g_Node 的ID字段         
                        ParentNodeID=parentNodeID            
                    };
                    _insertOk = false;

                    Func<g_NodeOrder,object> fun=s=>new {s.DBNode_GUID,s.NodeOrderLoacte,s.ParentNodeID};
                    _insertOk=instance_NodeOrder.Insert(nodeOrder, s => fun(s));
                    return _insertOk == true ? true : false;
                }
                else
                {
                    return false;
                }
            }
            else
            {
                return false;
            }
        }

        /// <summary>
        /// 往g_Node插入节点信息,并在g_NodeOrder表插入节点顺序信息
        /// </summary>
        /// <returns></returns>
        public bool InsertNode<TNode>(g_Node t, Func<g_Node, TNode> func, int parentNodeID,out string guid) where TNode : class
        {
            //插入g_Node子信息
            bool _insertOk = instance_Node.Insert(t, s => func(s));

            if (_insertOk)
            {
                //查询已经插入的子节点信息 在插入g_NodeOrder表
                Expression<Func<g_Node, object>> selectEntity = s => new { s.guid, s.ID };
                g_Node obj = new g_Node();

                IEnumerable<object> _resultList = instance_Node.Select(obj, s => selectEntity.Compile()(s), t, p => func(p));
                if (_resultList != null && _resultList.ToArray().Count() > 0)
                {
                    //插入g_NodeOrder数据表数据
                    g_NodeOrder nodeOrder = new g_NodeOrder
                    {
                        //g_NodeOrder的DBNode_GUID对应g_Node的GUID
                        DBNode_GUID = Convert.ToString(typeProperOperation.GetPropertyByNameType("guid", _resultList.ToArray()[0])),
                        //本节点的的ID编号 对应的是g_Node的ID字段
                        NodeOrderLoacte = Convert.ToInt32(typeProperOperation.GetPropertyByNameType("ID", _resultList.ToArray()[0])),
                        //父级节点表g_Node 的ID字段         
                        ParentNodeID = parentNodeID
                    };
                    _insertOk = false;

                    Func<g_NodeOrder, object> fun = s => new { s.DBNode_GUID, s.NodeOrderLoacte, s.ParentNodeID };
                    _insertOk = instance_NodeOrder.Insert(nodeOrder, s => fun(s));
                    //返回执行结果
                    guid = Convert.ToString(typeProperOperation.GetPropertyByNameType("guid", _resultList.ToArray()[0]));
                    return _insertOk == true ? true : false;
                }
                else
                {
                    guid = "";
                    return false;
                }
            }
            else
            {
                guid = "";
                return false;
            }
        }
        #endregion

        #region 更新 update
        public bool UpdateNode(string nodeName,string guid)
        {
            g_Node node = new g_Node
            {
                NodeName=nodeName
            };
            g_Node where=new g_Node
            {
                guid=guid
            };
            return instance_Node.Update(node, s => new { s.NodeName }, where, p => new { p.guid});
        }
        #endregion

        #region 删除 delete
        public void DeleteTreeViewNodeByID(int id)
        {
            DataTable idDt = DAL_NodeOrder.SelectIDByParentID(id);
            if (idDt != null && idDt.Rows.Count > 0)
            {
                bool _deleteOK = true;
                //查询是否存在html等文件信息
                DataTable dt = DAL_AddressUrl.GetAddressByParentID(id);
                if (dt != null && dt.Rows.Count > 0)     //存在HTML文件
                {
                    //g_AddressUrl删除信息 g_Content删除信息
                    if (DAL_AddressUrl.DeleteAddressByParentID(id) && DAL_Content.DeleteContentByParentID(id) && DAL_Node.DeleteNodeByID(id))
                    {
                        _deleteOK = true;
                    }
                    else
                    {
                        _deleteOK = false;
                    }
                }
                //删除节点信息
                if (_deleteOK)
                {
                    if (DAL_Node.DeleteNodeByID(id) && DAL_NodeOrder.DeleteNodeOrderByID(id))
                    {
                        for (int i = 0; i < idDt.Rows.Count; i++)
                        {
                            DeleteTreeViewNodeByID(Convert.ToInt32(idDt.Rows[i]["ID"]));
                        }
                    }
                }
            }
            else
            {
                DAL_Node.DeleteNodeAndChildByID(id);
                if (DAL_NodeOrder.SelectIDByCurrentNodeID(id) != null)
                {
                    DAL_NodeOrder.DeleteNodeOrderAndChildByID(id);
                }
            }
            //return false;
        }
        #endregion
    }
}
View Code

 

    程序源代码:程序源代码

 

posted @ 2018-03-28 14:18  小王子的博客  阅读(356)  评论(0编辑  收藏  举报