/**  版本信息模板在安装目录下,可自行修改。
* electricity_data.cs
*
* 功 能: N/A
* 类 名: electricity_data
*
* Ver    变更日期             负责人  变更内容
* ───────────────────────────────────
* V0.01  2024/1/31 10:29:15   N/A    初版
*
* Copyright (c) 2012 Maticsoft Corporation. All rights reserved.
*┌──────────────────────────────────┐
*│ 此技术信息为本公司机密信息,未经本公司书面同意禁止向第三方披露. │
*│ 版权所有:动软卓越(北京)科技有限公司              │
*└──────────────────────────────────┘
*/
using System;
using System.Data;
using System.Collections.Generic;
using Maticsoft.Common;
using DataService.Model;
using Maticsoft.DBUtility;
using MySql.Data.MySqlClient;
using System.Text;

namespace DataService.BLL
{
	/// <summary>
	/// electricity_data
	/// </summary>
	public partial class electricity_data
	{
		private readonly DataService.DAL.electricity_data dal=new DataService.DAL.electricity_data();
		public electricity_data()
		{}
		#region  BasicMethod
		/// <summary>
		/// 是否存在该记录
		/// </summary>
		public bool Exists(string ElectricityId)
		{
			return dal.Exists(ElectricityId);
		}

		/// <summary>
		/// 增加一条数据
		/// </summary>
		public bool Add(DataService.Model.electricity_data model)
		{
			return dal.Add(model);
		}

		/// <summary>
		/// 更新一条数据
		/// </summary>
		public bool Update(DataService.Model.electricity_data model)
		{
			return dal.Update(model);
		}

		/// <summary>
		/// 删除一条数据
		/// </summary>
		public bool Delete(string ElectricityId)
		{
			
			return dal.Delete(ElectricityId);
		}
		/// <summary>
		/// 删除一条数据
		/// </summary>
		public bool DeleteList(string ElectricityIdlist )
		{
			return dal.DeleteList(ElectricityIdlist );
		}

		/// <summary>
		/// 得到一个对象实体
		/// </summary>
		public DataService.Model.electricity_data GetModel(string ElectricityId)
		{
			
			return dal.GetModel(ElectricityId);
		}

		/// <summary>
		/// 得到一个对象实体,从缓存中
		/// </summary>
		public DataService.Model.electricity_data GetModelByCache(string ElectricityId)
		{
			
			string CacheKey = "electricity_dataModel-" + ElectricityId;
			object objModel = Maticsoft.Common.DataCache.GetCache(CacheKey);
			if (objModel == null)
			{
				try
				{
					objModel = dal.GetModel(ElectricityId);
					if (objModel != null)
					{
						int ModelCache = Maticsoft.Common.ConfigHelper.GetConfigInt("ModelCache");
						Maticsoft.Common.DataCache.SetCache(CacheKey, objModel, DateTime.Now.AddMinutes(ModelCache), TimeSpan.Zero);
					}
				}
				catch{}
			}
			return (DataService.Model.electricity_data)objModel;
		}

		/// <summary>
		/// 获得数据列表
		/// </summary>
		public DataSet GetList(string strWhere)
		{
			return dal.GetList(strWhere);
		}
		/// <summary>
		/// 获得数据列表
		/// </summary>
		public List<DataService.Model.electricity_data> GetModelList(string strWhere)
		{
			DataSet ds = dal.GetList(strWhere);
			return DataTableToList(ds.Tables[0]);
		}
		/// <summary>
		/// 获得数据列表
		/// </summary>
		public List<DataService.Model.electricity_data> DataTableToList(DataTable dt)
		{
			List<DataService.Model.electricity_data> modelList = new List<DataService.Model.electricity_data>();
			int rowsCount = dt.Rows.Count;
			if (rowsCount > 0)
			{
				DataService.Model.electricity_data model;
				for (int n = 0; n < rowsCount; n++)
				{
					model = dal.DataRowToModel(dt.Rows[n]);
					if (model != null)
					{
						modelList.Add(model);
					}
				}
			}
			return modelList;
		}

		/// <summary>
		/// 获得数据列表
		/// </summary>
		public DataSet GetAllList()
		{
			return GetList("");
		}

		/// <summary>
		/// 分页获取数据列表
		/// </summary>
		public int GetRecordCount(string strWhere)
		{
			return dal.GetRecordCount(strWhere);
		}
		/// <summary>
		/// 分页获取数据列表
		/// </summary>
		public DataSet GetListByPage(string strWhere, string orderby, int startIndex, int endIndex)
		{
			return dal.GetListByPage( strWhere,  orderby,  startIndex,  endIndex);
		}
        /// <summary>
        /// 分页获取数据列表
        /// </summary>
        //public DataSet GetList(int PageSize,int PageIndex,string strWhere)
        //{
        //return dal.GetList(PageSize,PageIndex,strWhere);
        //}

        #endregion  BasicMethod
        #region  ExtensionMethod
        /// <summary>
        /// 表是否存在
        /// </summary>
        /// <param name="dbName">数据库名</param>
        /// <param name="tableName">表名 格式:表名_yyyyMMdd</param>
        /// <returns></returns>
        public bool IsExistsTable(string dbName, string tableName)
        {
            return dal.IsExistsTable(dbName, tableName);
        }

        /// <summary>
        /// 增加一条数据
        /// </summary>
        public bool AddDate(DataService.Model.electricity_data model, string date)
        {
            return dal.AddDate(model, date);
        }

        /// <summary>
        /// 添加表
        /// </summary>
        /// <param name="date">日期 格式:yyyyMMdd</param>
        /// <returns></returns>
        public void CreateTable(string date)
        {
            dal.CreateTable(date);
        }

        /// <summary>
        /// 获得数据列表
        /// </summary>
        public List<DataService.Model.electricity_data> GetModelListDate(string strWhere, string date)
        {
            DataSet ds = dal.GetListDate(strWhere, date);
            return DataTableToList(ds.Tables[0]);
        }

        /// <summary>
        /// 获取数据
        /// </summary>
        /// <param name="source">数据来源</param>
        /// <param name="strWhere">条件</param>
        /// <param name="timeField">时间字段</param>
        /// <returns></returns>
        public List<DataService.Model.electricity_data> GetList(string source, string strWhere, string timeField)
        {
            DataSet ds = dal.GetList(source, strWhere, timeField);
            return DataTableToList(ds.Tables[0]);
        }

        /// <summary>
		/// 获取数据
		/// </summary>
		/// <param name="source">数据来源</param>
		/// <param name="strWhere">条件</param>
		/// <param name="sum_name">求和字段</param>
		/// <returns></returns>
		public decimal GetSum(string source, string strWhere, string sum_name)
        {
            return dal.GetSum(source, strWhere, sum_name);
        }
        #endregion  ExtensionMethod

    }
}