12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using Models;
- using System.Data.SqlClient;
- using System.Data;
- namespace DAL
- {
- /// <summary>
- /// 酒店预订费用多表联查数据访问类 - 用于Excel
- /// </summary>
- public class ViewHotelPayService
- {
- /// <summary>
- /// 查询所有
- /// </summary>
- /// <param name="sql">sql语句</param>
- /// <param name="param">可变参数数组</param>
- /// <returns>返回集合</returns>
- List<ViewHotelPay> excuteSql(string sql, params SqlParameter[] param)
- {
- return ServiceBase<ViewHotelPay>.excuteSql(new ViewHotelPay(), "ViewHotelPay", sql, CommandType.Text, param);
- }
- /// <summary>
- /// 获取单个对象
- /// </summary>
- /// <param name="sql">sql语句</param>
- /// <param name="param">可变参数数组</param>
- /// <returns>返回空或者单个对象</returns>
- ViewHotelPay excuteType(string sql, params SqlParameter[] param)
- {
- //查询结果放入对象集合
- List<ViewHotelPay> ctggdList = excuteSql(sql, param);
- //判断集合是否为空
- if (ctggdList == null || ctggdList.Count == 0)
- //返回null
- return null;
- //返回单个对象
- return ctggdList[0];
- }
- /// <summary>
- /// 根据编号查询对象信息
- /// </summary>
- /// <param name="id">对象编号</param>
- /// <returns>返回空或者单个对象信息</returns>
- public ViewHotelPay GetViewHotelPayByID(int id)
- {
- //调用获取单个对象的方法
- return excuteType("select * from ViewHotelPay where Id = @id and IsDel = 0", new SqlParameter("@id", id));
- }
- /// <summary>
- /// 获取全部
- /// </summary>
- /// <returns></returns>
- public List<ViewHotelPay> GetAll()
- {
- return excuteSql("select * from ViewHotelPay where IsDel = 0");
- }
- /// <summary>
- /// 根据编号查询对象信息
- /// </summary>
- /// <param name="id">对象编号</param>
- /// <returns>返回空或者对象信息</returns>
- public List<ViewHotelPay> GetByDIId(int DIId)
- {
- //调用获取单个对象的方法
- //return excuteSql("select hr.CheckInDate,hr.CheckOutDate,hr.OperatorDate,hr.City,hr.HotelName,sd.[Name],hr.SingleRoomPrice,hr.SingleRoomCount,hr.DoubleRoomPrice,hr.DoubleRoomCount,hr.SuiteRoomPrice,hr.SuiteRoomCount,hr.OtherRoomPrice,hr.OtherRoomCount,hr.Commission,hr.Budget,ccp.PayMoney,(hr.Budget - (hr.SingleRoomPrice * hr.SingleRoomCount + hr.DoubleRoomPrice * hr.DoubleRoomCount + hr.SuiteRoomPrice * hr.SuiteRoomCount + hr.OtherRoomPrice * hr.OtherRoomCount + hr.Commission)) as Spread,((hr.SingleRoomPrice * hr.SingleRoomCount + hr.DoubleRoomPrice * hr.DoubleRoomCount + hr.SuiteRoomPrice * hr.SuiteRoomCount + hr.OtherRoomPrice * hr.OtherRoomCount + hr.Commission)*(datediff(dd,checkindate,checkoutdate))) as moneys,ccp.DayRate from HotelReservations hr join CreditCardPayment ccp on ccp.Diid = hr.Diid and ccp.Cid = hr.Id join SetData sd on sd.Id =ccp.PaymentCurrency where hr.DIID = @DIID and hr.IsDel = 0 and ccp.CTable=76 and ccp.IsPay = 1 order by checkindate ASC", new SqlParameter("@DIId", DIId));
- //去除ispay=1
- //return excuteSql("select ccp.Operator,sd1.name as PaydName,ccp.OrbitalPrivateTransfer,ccp.PayDid,ccp.payee,ccp.ispay,hr.CheckInDate,hr.CheckOutDate,hr.OperatorDate,hr.City,hr.HotelName,sd.[Name],hr.SingleRoomPrice,hr.SingleRoomCount,hr.DoubleRoomPrice,hr.DoubleRoomCount,hr.SuiteRoomPrice,hr.SuiteRoomCount,hr.OtherRoomPrice,hr.OtherRoomCount,hr.Commission,hr.Budget,(ccp.PayMoney * ccp.DayRate) as PayMoney,(hr.Budget - (hr.SingleRoomPrice * hr.SingleRoomCount + hr.DoubleRoomPrice * hr.DoubleRoomCount + hr.SuiteRoomPrice * hr.SuiteRoomCount + hr.OtherRoomPrice * hr.OtherRoomCount + hr.Commission)) as Spread,((hr.SingleRoomPrice * hr.SingleRoomCount + hr.DoubleRoomPrice * hr.DoubleRoomCount + hr.SuiteRoomPrice * hr.SuiteRoomCount + hr.OtherRoomPrice * hr.OtherRoomCount + hr.Commission)*(datediff(dd,checkindate,checkoutdate))) as moneys,ccp.DayRate from HotelReservations hr join CreditCardPayment ccp on ccp.Diid = hr.Diid and ccp.Cid = hr.Id join SetData sd on sd.Id =ccp.PaymentCurrency join setdata sd1 on sd1.id=ccp.PayDid where hr.DIID = @DIID and hr.IsDel = 0 and ccp.CTable=76 and ccp.IsAuditGM <> 2 and ccp.isDel=0 order by checkindate ASC", new SqlParameter("@DIId", DIId));
- return excuteSql("select (select Name from SetData where Id=ccp.CTDId)as CarType,hr.CheckType, ccp.IsMatchCreditCard,ccp.Operator,sd1.name as PaydName," +
- "ccp.OrbitalPrivateTransfer,ccp.PayDid,ccp.payee,ccp.ispay,hr.CheckInDate,hr.CheckOutDate,hr.OperatorDate,hr.City,hr.HotelName,sd.[Name]," +
- "hr.SingleRoomPrice,hr.SingleRoomCount,hr.GovernmentRent,hr.CityTax,hr.DoubleRoomPrice,hr.DoubleRoomCount,hr.SuiteRoomPrice,hr.SuiteRoomCount," +
- "hr.OtherRoomPrice,hr.OtherRoomCount,hr.Commission,hr.Budget,((ccp.PayMoney * ccp.DayRate) +hr.breakfastPrice) as PayMoney,(hr.Budget - " +
- "(hr.SingleRoomPrice * hr.SingleRoomCount + hr.DoubleRoomPrice * hr.DoubleRoomCount + hr.SuiteRoomPrice * hr.SuiteRoomCount + hr.OtherRoomPrice " +
- "* hr.OtherRoomCount + hr.Commission)) as Spread,(ccp.PayMoney+hr.breakfastPrice) as moneys,ccp.DayRate,hr.breakfastPrice as breakfasePrice " +
- "from HotelReservations hr join CreditCardPayment ccp on ccp.Diid = hr.Diid and ccp.Cid = hr.Id join SetData sd on sd.Id =ccp.PaymentCurrency " +
- "join setdata sd1 on sd1.id=ccp.PayDid where hr.DIID = @DIId and hr.IsDel = 0 and ccp.CTable=76 and ccp.IsAuditGM =1 or ccp.IsAuditGM=3 and ccp.IsPay=1 and ccp.isDel=0 and " +
- "hr.operator is not null and hr.operator > 0 order by checkindate ASC", new SqlParameter("@DIId", DIId));
- }
- }
- }
|