InvoiceSqlDao.sql.stg

75 lines | 1.592 kB Blame History Raw Download
group InvoiceDao: EntitySqlDao;

tableName() ::= "invoices"

tableFields(prefix) ::= <<
  <prefix>account_id
, <prefix>invoice_date
, <prefix>target_date
, <prefix>currency
, <prefix>migrated
, <prefix>created_by
, <prefix>created_date
>>

tableValues() ::= <<
  :accountId
, :invoiceDate
, :targetDate
, :currency
, :migrated
, :createdBy
, :createdDate
>>

extraTableFieldsWithComma(prefix) ::= <<
, <prefix>record_id as invoice_number
>>

getInvoicesBySubscription() ::= <<
  SELECT <allTableFields("i.")>
  FROM <tableName()> i
  JOIN invoice_items ii ON i.id = ii.invoice_id
  WHERE ii.subscription_id = :subscriptionId AND i.migrated = '0'
  <AND_CHECK_TENANT("i.")>
  <AND_CHECK_TENANT("ii.")>
  ;
>>

searchQuery(prefix) ::= <<
     <idField(prefix)> = :searchKey
  or <prefix>account_id = :searchKey
  or <prefix>currency = :searchKey
>>

getInvoiceIdByPaymentId() ::= <<
  SELECT i.id
    FROM <tableName()> i, invoice_payments ip
   WHERE ip.invoice_id = i.id
     AND ip.payment_id = :paymentId
   <AND_CHECK_TENANT("i.")>
   <AND_CHECK_TENANT("ip.")>
>>

getInvoicesByParentAccount() ::= <<
  SELECT <allTableFields("i.")>
  FROM <tableName()> i
  JOIN accounts ac ON i.account_id = ac.id
  WHERE ac.parent_account_id = :parentAccountId
  <AND_CHECK_TENANT("i.")>
  <AND_CHECK_TENANT("ac.")>
  ;
>>

getInvoicesByParentAccountDateRange() ::= <<
  SELECT <allTableFields("i.")>
  FROM <tableName()> i
  JOIN accounts ac ON i.account_id = ac.id
  WHERE ac.parent_account_id = :parentAccountId
  and invoice_date >= :startDate
  and invoice_date \< :endDate
  <AND_CHECK_TENANT("i.")>
  <AND_CHECK_TENANT("ac.")>
  ;
>>