using System;
using System.Data;
using System.Data.SqlClient;
using System.Collections;
using AIMSModel;
using AIMSObjectQuery;
using System.Collections.Generic;
namespace AIMSDAL
{
    internal partial class DMenu
	{
	    #region 插入实体操作部份
	    /// 
        /// 插入
        /// 
		/// Command对象
        /// 实体类对象
        /// 标识列值或影响的记录行数
		internal static int Insert(SqlCommand cmd, Menu menu)
		{
		    cmd.Parameters.Clear();
			cmd.CommandText = "insert into Menu (Name,Path,ParentId,IsValid,MenuOrder,IsAloneOpen,ImgPath,OperatorNo,OperatorName,OperateDate) values (@Name,@Path,@ParentId,@IsValid,@MenuOrder,@IsAloneOpen,@ImgPath,@OperatorNo,@OperatorName,@OperateDate);select @@identity";
			//从实体中取出值放入Command的参数列表
			cmd.Parameters.Add(new SqlParameter("@Name",menu.Name==null?(object)DBNull.Value:(object)menu.Name));
			cmd.Parameters.Add(new SqlParameter("@Path",menu.Path==null?(object)DBNull.Value:(object)menu.Path));
			cmd.Parameters.Add(new SqlParameter("@ParentId",menu.ParentId.HasValue?(object)menu.ParentId.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@IsValid",menu.IsValid.HasValue?(object)menu.IsValid.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@MenuOrder",menu.MenuOrder.HasValue?(object)menu.MenuOrder.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@IsAloneOpen",menu.IsAloneOpen.HasValue?(object)menu.IsAloneOpen.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@ImgPath",menu.ImgPath==null?(object)DBNull.Value:(object)menu.ImgPath));
			cmd.Parameters.Add(new SqlParameter("@OperatorNo",menu.OperatorNo==null?(object)DBNull.Value:(object)menu.OperatorNo));
			cmd.Parameters.Add(new SqlParameter("@OperatorName",menu.OperatorName==null?(object)DBNull.Value:(object)menu.OperatorName));
			cmd.Parameters.Add(new SqlParameter("@OperateDate",menu.OperateDate.HasValue?(object)menu.OperateDate.Value:(object)DBNull.Value));
			return Convert.ToInt32(cmd.ExecuteScalar());
		}
	    /// 
        /// 不使用事务的插入方法
        /// 
        /// 实体类对象
        /// 标识列值或影响的记录行数
	    internal static int Insert(Menu menu)
		{
			using(SqlConnection conn=new SqlConnection(Connection.ConnectionString))
			{
				conn.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                    return Insert(cmd, menu);
                }
			}
		}
		
		/// 
        /// 使用事务的插入方法
        /// 
        /// 实现共享Connection的对象
        /// 实体类对象
        /// 标识列值或影响的记录行数
        internal static int Insert(Connection connection,Menu menu)
        {
            return Insert(connection.Command, menu);
        }
		#endregion
		
		#region 删除实体操作
		
		/// 
        /// 删除
        /// 
		/// Command对象
        /// 实体类对象
        /// 影响的记录行数
		internal static int ExcuteDeleteCommand(SqlCommand cmd, Menu menu)
        {
			cmd.Parameters.Clear();
            cmd.CommandText = "delete from Menu where Id=@Id";
            //从实体中取出值放入Command的参数列表
		    cmd.Parameters.Add(new SqlParameter("@Id", menu.Id));
            return cmd.ExecuteNonQuery();
        }
		/// 
        /// 不使用事务的删除方法
        /// 
        /// 实体类对象
        /// 影响的记录行数
        internal static int Delete(Menu menu)
        {
            using (SqlConnection conn = new SqlConnection(Connection.ConnectionString))
            {
                conn.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                    return ExcuteDeleteCommand(cmd, menu);
                }
            }
        }
		/// 
        /// 使用事务的删除方法
        /// 
        /// 实现共享Connection的对象
        /// 实体类对象
        /// 影响的记录行数
        internal static int Delete(Connection connection,Menu menu)
        {
            return  ExcuteDeleteCommand(connection.Command, menu);
		}
		
		/// 
        /// 执行删除命令
        /// 
        /// Command对象
        /// 对象查询语句
        /// 参数列表
        /// 影响的记录行数
        internal static int ExcuteDeleteCommand(SqlCommand cmd, string oql, ParameterList parameters)
        {
            //解析过滤部份Sql语句
            string filterString = SyntaxAnalyzer.ParseSql(oql, new MenuMap());
            if (filterString != string.Empty)
            {
                filterString = " where " + filterString;
            }
            cmd.Parameters.Clear();
            cmd.CommandText = "delete from Menu " + filterString;
            //添加参数
            if (parameters != null)
            {
                foreach (string key in parameters.Keys)
                {
                    cmd.Parameters.Add(new SqlParameter(key, parameters[key]));
                }
            }
            return cmd.ExecuteNonQuery();
        }
		
		/// 
        /// 不使用事务的删除方法
        /// 
        /// 对象查询语句
        /// 参数列表
        /// 影响的记录行数
        internal static int Delete(string oql, ParameterList parameters)
        {
            using (SqlConnection conn = new SqlConnection(Connection.ConnectionString))
            {
                conn.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                    return ExcuteDeleteCommand(cmd, oql, parameters);
                }
            }
        }
		
		/// 
        /// 使用事务的删除方法
        /// 
        /// 实现共享Connection的对象
        /// 对象查询语句
        /// 参数列表
        /// 影响的记录行数
        internal static int Delete(Connection connection, string oql, ParameterList parameters)
        {
            return ExcuteDeleteCommand(connection.Command, oql, parameters);
        }
		
		#endregion
		
		#region 更新实体操作
		
		/// 
        /// 更新
        /// 
		/// Command对象
        /// 实体类对象
        /// 影响的记录行数
		internal static int ExcuteUpdateCommand(SqlCommand cmd, Menu menu)
		{
		    cmd.CommandText = "update Menu set Name=@Name,Path=@Path,ParentId=@ParentId,IsValid=@IsValid,MenuOrder=@MenuOrder,IsAloneOpen=@IsAloneOpen,ImgPath=@ImgPath,OperatorNo=@OperatorNo,OperatorName=@OperatorName,OperateDate=@OperateDate where Id=@Id";
			//从实体中取出值放入Command的参数列表
			cmd.Parameters.Add(new SqlParameter("@Name",menu.Name==null?(object)DBNull.Value:(object)menu.Name));
			cmd.Parameters.Add(new SqlParameter("@Path",menu.Path==null?(object)DBNull.Value:(object)menu.Path));
			cmd.Parameters.Add(new SqlParameter("@ParentId",menu.ParentId.HasValue?(object)menu.ParentId.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@IsValid",menu.IsValid.HasValue?(object)menu.IsValid.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@MenuOrder",menu.MenuOrder.HasValue?(object)menu.MenuOrder.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@IsAloneOpen",menu.IsAloneOpen.HasValue?(object)menu.IsAloneOpen.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@ImgPath",menu.ImgPath==null?(object)DBNull.Value:(object)menu.ImgPath));
			cmd.Parameters.Add(new SqlParameter("@OperatorNo",menu.OperatorNo==null?(object)DBNull.Value:(object)menu.OperatorNo));
			cmd.Parameters.Add(new SqlParameter("@OperatorName",menu.OperatorName==null?(object)DBNull.Value:(object)menu.OperatorName));
			cmd.Parameters.Add(new SqlParameter("@OperateDate",menu.OperateDate.HasValue?(object)menu.OperateDate.Value:(object)DBNull.Value));
			cmd.Parameters.Add(new SqlParameter("@Id", menu.Id));
            return cmd.ExecuteNonQuery();
		}
		
		/// 
        /// 不使用事务的更新方法
        /// 
        /// 实体类对象
        /// 影响的记录行数
	    internal static int Update(Menu menu)
		{
			using(SqlConnection conn=new SqlConnection(Connection.ConnectionString))
			{
				conn.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                    return ExcuteUpdateCommand(cmd, menu);
                }
			}
		}
		/// 
        /// 使用事务的更新方法
        /// 
        /// 实现共享Connection的对象
        /// 实体类对象
        /// 影响的记录行数
        internal static int Update(Connection connection,Menu menu)
        {
            return ExcuteUpdateCommand(connection.Command, menu);
		}
		/// 
        /// 执行更新命令
        /// 
        /// Command对象
        /// 对象查询语句
        /// 参数列表
        /// 影响的记录行数
        internal static int ExcuteUpdateCommand(SqlCommand cmd, string oql, ParameterList parameters)
        {
            //解析过滤部份Sql语句
            string updateString = SyntaxAnalyzer.ParseSql(oql, new MenuMap());
            cmd.CommandText = "update Menu set " + updateString;
			cmd.Parameters.Clear();
            //添加参数
            if (parameters != null)
            {
                foreach (string key in parameters.Keys)
                {
                    cmd.Parameters.Add(new SqlParameter(key, parameters[key]));
                }
            }
            return cmd.ExecuteNonQuery();
        }
		
		/// 
        /// 不使用事务的更新方法
        /// 
        /// 对象查询语句
        /// 参数列表
        /// 影响的记录行数
        internal static int Update(string oql, ParameterList parameters)
        {
            using (SqlConnection conn = new SqlConnection(Connection.ConnectionString))
            {
                conn.Open();
                using (SqlCommand cmd = conn.CreateCommand())
                {
                    return ExcuteUpdateCommand(cmd, oql, parameters);
                }
            }
        }
		
		/// 
        /// 使用事务的更新方法
        /// 
        /// 实现共享Connection的对象
        /// 对象查询语句
        /// 参数列表
        /// 影响的记录行数
        internal static int Update(Connection connection, string oql, ParameterList parameters)
        {
            return ExcuteUpdateCommand(connection.Command, oql, parameters);
        }
		#endregion
		
		#region 查询实体集合
		/// 
        /// 执行Command获取对象列表
        /// 
        /// Command对象
		/// 递归类型
        /// 递归深度
        /// 实体类对象列表
        internal static List