001// -------------------------------------------------------------------------------- 002// Copyright 2002-2025 Echo Three, LLC 003// 004// Licensed under the Apache License, Version 2.0 (the "License"); 005// you may not use this file except in compliance with the License. 006// You may obtain a copy of the License at 007// 008// http://www.apache.org/licenses/LICENSE-2.0 009// 010// Unless required by applicable law or agreed to in writing, software 011// distributed under the License is distributed on an "AS IS" BASIS, 012// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013// See the License for the specific language governing permissions and 014// limitations under the License. 015// -------------------------------------------------------------------------------- 016 017package com.echothree.model.control.accounting.server.database; 018 019import com.echothree.model.control.accounting.server.database.TransactionBalancedResult; 020import com.echothree.model.data.accounting.server.entity.Transaction; 021import com.echothree.util.server.persistence.BaseDatabaseQuery; 022import com.echothree.util.server.persistence.EntityPermission; 023import com.echothree.util.server.persistence.Session; 024import java.util.List; 025 026public class TransactionBalancedQuery 027 extends BaseDatabaseQuery<TransactionBalancedResult> { 028 029 public TransactionBalancedQuery() { 030 super(""" 031 SELECT SUM(trxglent_originalcredit) - SUM(trxglent_originaldebit) AS OriginalDifference, 032 SUM(trxglent_credit) - SUM(trxglent_debit) AS Difference 033 FROM transactionglentries 034 WHERE trxglent_trx_transactionid = ? 035 AND trxglent_thrutime = ? 036 """, EntityPermission.READ_ONLY); 037 } 038 039 public List<TransactionBalancedResult> execute(final Transaction transaction) { 040 return super.execute(transaction, Session.MAX_TIME_LONG); 041 } 042 043}