You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

214 lines
7.6 KiB
C#

10 months ago
using System;
using System.Data;
using System.Data.Common;
using System.Collections.Generic;
using System.Text;
using DSWeb.Areas.TruckMng.Models.Card;
using DSWeb.Areas.OA.Models.Comm;
using Microsoft.Practices.EnterpriseLibrary.Data;
using HcUtility.Comm;
using DSWeb.Areas.CommMng.DAL;
namespace DSWeb.Areas.TruckMng.DAL.Card
{
public partial class CardDAL
{
#region 充值卡列表
//卡列表
static public List<CardHeadmb> GetDataList ( string strCondition )
{
var strSql = new StringBuilder();
strSql.Append(" select *,(select sum(isnull(innum,0))-sum(isnull(outnum,0)) from tcard_use u where U.cardgid=tSavings_card.gid ) remain from tSavings_card where 1=1 ");
if (!string.IsNullOrEmpty(strCondition))
{
strSql.Append(" and " + strCondition);
}
return SetData(strSql);
}
static public CardHeadmb GetData ( string condition )
{
var list = GetDataList(condition);
if (list.Count > 0)
return list[0];
return new CardHeadmb();
}
private static List<CardHeadmb> SetData ( StringBuilder strSql )
{
var headList = new List<CardHeadmb>();
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
CardHeadmb data = new CardHeadmb();
#region Set DB data to Object
data.GID = Convert.ToString(reader["GID"]);
data.CARDNO = Convert.ToString(reader["CARDNO"]);
data.CARDTYPE = Convert.ToString(reader["CARDTYPE"]);
data.OP = Convert.ToString(reader["OP"]);
data.OWNGID = Convert.ToString(reader["OWNGID"]);
data.ISDELETE = Convert.ToString(reader["ISDELETE"]);
data.REMAIN = Convert.ToString(reader["REMAIN"]);
#endregion
headList.Add(data);
}
reader.Close();
}
return headList;
}
#endregion
#region 充值卡的使用
internal static string DealCard(string BILLNO, string OWNID, string CARDTYPE, string Operate, string Innum, string Outnum)
{
var strSql = new StringBuilder();
strSql.Append(" delete from tCard_Use where billno='" + BILLNO + "' and cardgid= (select gid from tsavings_card where CARDTYPE='" + CARDTYPE + "' and owngid='" + OWNID + "') ");
if (double.Parse(Innum) != 0 || double.Parse(Outnum) != 0)
{
strSql.Append(" insert into tCard_Use (GID,CARDNO,BILLNO,OPERATE,INNUM,OUTNUM,OPTIME,REMARK,CARDGID) values ");
strSql.Append(" (newid(),(select cardno from tsavings_card t where t.CARDTYPE='" + CARDTYPE + "' and t.owngid='" + OWNID + "') ");
strSql.Append(" ,'" + BILLNO + "','" + Operate + "'," + Innum + "," + Outnum + ",getdate(),'',(select gid from tsavings_card where CARDTYPE='" + CARDTYPE + "' and owngid='" + OWNID + "') ) ");
}
var sql = strSql.ToString();
Database db = DatabaseFactory.CreateDatabase();
var _count = db.ExecuteNonQuery(CommandType.Text, strSql.ToString());
return _count.ToString();
}
#endregion
#region 充值卡充值/使用列表
static public List<CardUsemb> GetUseList ( string strCondition )
{
var strSql = new StringBuilder();
strSql.Append(" select * from tCard_Use where 1=1 ");
if (!string.IsNullOrEmpty(strCondition))
{
strSql.Append(" and " + strCondition);
}
strSql.Append(" order by optime " );
return SetUseData(strSql);
}
private static List<CardUsemb> SetUseData ( StringBuilder strSql )
{
var headList = new List<CardUsemb>();
Database db = DatabaseFactory.CreateDatabase();
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
CardUsemb data = new CardUsemb();
#region Set DB data to Object
data.GID = Convert.ToString(reader["GID"]);
data.CARDNO = Convert.ToString(reader["CARDNO"]);
data.CARDGID = Convert.ToString(reader["CARDGID"]);
data.BILLNO = Convert.ToString(reader["BILLNO"]);
data.OPERATE = Convert.ToString(reader["OPERATE"]);
data.INNUM = Convert.ToString(reader["INNUM"]);
data.OUTNUM = Convert.ToString(reader["OUTNUM"]);
data.OPTIME = Convert.ToString(reader["OPTIME"]);
data.REMARK = Convert.ToString(reader["REMARK"]);
#endregion
headList.Add(data);
}
reader.Close();
}
return headList;
}
#endregion
static public string GetCardRemain(string OWNID, string CARDTYPE)
{ //获取剩余数量
var strSql = new StringBuilder();
strSql.Append(" select sum(isnull(innum,0))-sum(isnull(outnum,0)) Remain from tCard_Use ");
strSql.Append(" where cardgid= (select gid from tsavings_card where CARDTYPE='" + CARDTYPE + "' and owngid='" + OWNID + "') ");
Database db = DatabaseFactory.CreateDatabase();
var Remain = "";
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
#region Set DB data to Object
Remain = Convert.ToString(reader["Remain"]);
#endregion
}
reader.Close();
}
return Remain;
}
static public string SearchCardUse ( string condition )
{ //获取卡片的使用明细数量
var strSql = new StringBuilder();
strSql.Append(" select count(*) _count from tcard_use " + condition );
Database db = DatabaseFactory.CreateDatabase();
var _count = "0";
using (IDataReader reader = db.ExecuteReader(CommandType.Text, strSql.ToString()))
{
while (reader.Read())
{
#region Set DB data to Object
_count = Convert.ToString(reader["_count"]);
#endregion
}
reader.Close();
}
return _count;
}
static public int DeleteCard ( string GID )
{
var strSql = new StringBuilder();
strSql.Append(" delete from tSavings_card where gid= '" + GID + "'");
var _count = 0;
Database db = DatabaseFactory.CreateDatabase();
_count = db.ExecuteNonQuery(CommandType.Text, strSql.ToString());
return _count;
}
static public int DeleteCardUse ( string GID )
{
var strSql = new StringBuilder();
strSql.Append(" delete from tcard_Use where gid= '" + GID + "'");
var _count = 0;
Database db = DatabaseFactory.CreateDatabase();
_count = db.ExecuteNonQuery(CommandType.Text, strSql.ToString());
return _count;
}
}
}