> ## Documentation Index
> Fetch the complete documentation index at: https://docs.blnkfinance.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Reconciliation Strategy

> Learn about different reconciliation strategies and how to use them.

export const CtaCallout = props => {
  const {title, buttonLabel, href, trackingEvent, buttonTarget, rel = "noopener noreferrer", children} = props;
  const handleCtaClick = () => {
    if (typeof window === "undefined" || !trackingEvent) {
      return;
    }
    try {
      window.dispatchEvent(new CustomEvent("blnk:docs-cta", {
        detail: {
          name: trackingEvent,
          href
        }
      }));
    } catch {}
    try {
      window.posthog?.capture?.(trackingEvent, {
        href
      });
    } catch {}
    const gaPayload = {
      cta_href: href
    };
    try {
      window.gtag?.("event", trackingEvent, gaPayload);
    } catch {}
    try {
      window.dataLayer = window.dataLayer || [];
      window.dataLayer.push({
        event: trackingEvent,
        ...gaPayload
      });
    } catch {}
  };
  const isExternal = typeof href === "string" && (/^https?:\/\//i).test(href);
  const target = buttonTarget ?? (isExternal ? "_blank" : undefined);
  const linkRel = isExternal ? rel : undefined;
  return <section className="cta-callout not-prose relative my-8 w-full min-w-0 overflow-hidden rounded-xl border border-zinc-200 p-5 dark:border-white/10">
      <div className="cta-callout-noise" aria-hidden="true" />
      <div className="cta-callout-layout">
        {title ? <div className="cta-callout-title-row">
            <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 28 28" width="14" height="14" className="cta-callout-icon shrink-0 text-zinc-800 dark:text-zinc-200" aria-hidden="true">
              <g fill="none" fillRule="nonzero">
                <path d="M28 0v28H0V0h28ZM14.691833333333335 27.134333333333334l-0.012833333333333334 0.0023333333333333335 -0.08283333333333333 0.04083333333333334 -0.023333333333333334 0.004666666666666667 -0.016333333333333335 -0.004666666666666667 -0.08283333333333333 -0.04083333333333334c-0.011666666666666667 -0.004666666666666667 -0.022166666666666668 -0.0011666666666666668 -0.028000000000000004 0.005833333333333334l-0.004666666666666667 0.011666666666666667 -0.019833333333333335 0.49933333333333335 0.005833333333333334 0.023333333333333334 0.011666666666666667 0.015166666666666667 0.12133333333333333 0.08633333333333333 0.0175 0.004666666666666667 0.014000000000000002 -0.004666666666666667 0.12133333333333333 -0.08633333333333333 0.014000000000000002 -0.018666666666666668 0.004666666666666667 -0.019833333333333335 -0.019833333333333335 -0.4981666666666667c-0.0023333333333333335 -0.011666666666666667 -0.0105 -0.019833333333333335 -0.019833333333333335 -0.021Zm0.3091666666666667 -0.13183333333333336 -0.015166666666666667 0.0023333333333333335 -0.21583333333333335 0.1085 -0.011666666666666667 0.011666666666666667 -0.0035000000000000005 0.012833333333333334 0.021 0.5016666666666667 0.005833333333333334 0.014000000000000002 0.009333333333333334 0.008166666666666668 0.23450000000000004 0.1085c0.014000000000000002 0.004666666666666667 0.026833333333333334 0 0.03383333333333334 -0.009333333333333334l0.004666666666666667 -0.016333333333333335 -0.03966666666666667 -0.7163333333333334c-0.0035000000000000005 -0.014000000000000002 -0.011666666666666667 -0.023333333333333334 -0.023333333333333334 -0.025666666666666667Zm-0.8341666666666667 0.0023333333333333335a0.026833333333333334 0.026833333333334334 0 0 0 -0.0315 0.007000000000000001l-0.007000000000000001 0.016333333333333335 -0.03966666666666667 0.7163333333333334c0 0.014000000000000002 0.008166666666666668 0.023333333333333334 0.019833333333333335 0.028000000000000004l0.0175 -0.0023333333333333335 0.23450000000000004 -0.1085 0.011666666666666667 -0.009333333333333334 0.004666666666666667 -0.012833333333333334 0.019833333333333335 -0.5016666666666667 -0.0035000000000000005 -0.014000000000000002 -0.011666666666666667 -0.011666666666666667 -0.21466666666666667 -0.10733333333333334Z" strokeWidth="1.1667" />
                <path fill="currentColor" d="M14 2.916666666666667A1.75 1.75 0 0 1 15.750000000000002 4.666666666666667v6.302333333333334L21.207666666666668 7.816666666666667a1.75 1.75 0 0 1 1.75 3.031L17.5 14l5.457666666666667 3.151166666666667a1.75 1.75 0 0 1 -1.75 3.031l-5.457666666666667 -3.1500000000000004V23.333333333333336a1.75 1.75 0 0 1 -3.5 0v-6.302333333333334L6.792333333333334 20.183333333333337a1.75 1.75 0 1 1 -1.75 -3.031L10.5 14 5.042333333333334 10.848833333333333a1.75 1.75 0 0 1 1.75 -3.031l5.457666666666667 3.1500000000000004V4.666666666666667A1.75 1.75 0 0 1 14 2.916666666666667Z" strokeWidth="1.1667" />
              </g>
            </svg>
            <p className="cta-callout-title min-w-0 font-semibold text-zinc-800 dark:text-zinc-200">
              {title}
            </p>
          </div> : null}
        <div className={`cta-callout-body text-sm leading-normal text-zinc-800 dark:text-zinc-200${title ? " cta-callout-body--indented" : ""}`}>
          {children}
        </div>
        <a href={href} target={target} rel={linkRel} onClick={handleCtaClick} data-docs-cta={trackingEvent || undefined} className="cta-callout-button inline-flex items-center justify-center gap-1 rounded-full bg-white px-3 py-1.5 text-sm font-semibold transition hover:bg-zinc-100 focus-visible:outline focus-visible:outline-2 focus-visible:outline-offset-2 focus-visible:outline-white/50 dark:bg-white dark:hover:bg-zinc-200">
          {buttonLabel}
          <span className="cta-callout-button-arrow" aria-hidden="true">
            →
          </span>
        </a>
      </div>
    </section>;
};

Your reconciliation strategy specifies how transactions are distributed between the two sets of records. This is important because it affects how Blnk matches the records and how you interpret the results.

Blnk supports three strategies:

1. **One-to-one:** Each external transaction is matched with exactly one internal transaction.
2. **One-to-many:** Each external transaction is matched with one or more internal transactions.
3. **Many-to-one:** One or more external transactions are matched with exactly one internal transaction.

***

## Choosing a strategy

Pick the strategy that best reflects how money groups or splits between your ledger and your external source.

1. If nothing is split or combines, **use one-to-one**, e.g. a customer pays \$25 with their card; your ledger records a \$25 transaction and your processor statement also shows a single \$25 charge.
2. If one record on the external side triggers multiple records on the internal side, use **one-to-many**, e.g. A payment processor reports a single \$100 charge, but your ledger records it as separate entries for the gross amount, the processing fee, and the net amount deposited.
3. If multiple records on the external side and combined into one record on the internal side, use **many-to-one**, e.g. a processor reports a transaction in multiple parts, for example fee breakdowns or split authorizations, but your ledger stores it as a single \$120 charge.

<Tip>**Simply ask**, does this transaction split, combine or stay the same between the two sides? The answer will guide your choice.</Tip>

***

## Applying your strategy

To apply your strategy, select it from the `Strategy` dropdown field when creating a new reconciliation run.

<img src="https://mintcdn.com/blnk/49wSMfUCPj0chMr2/cloud/img/reconciliation/recon-strategy.png?fit=max&auto=format&n=49wSMfUCPj0chMr2&q=85&s=bd7e17c730a8b054abd6071a39e90ec1" alt="Select strategy" className="rounded-lg" width="3386" height="2018" data-path="cloud/img/reconciliation/recon-strategy.png" />

Next, you'll need to select a `grouping criteria`.

This field determines how Blnk groups the records on the `many` side for reconciliation. Here are the available grouping options for each strategy:

1. **One-to-many**:

   | Grouping criteria    | What it does                                                        |
   | :------------------- | :------------------------------------------------------------------ |
   | `transaction_id`     | Groups internal records that share the same transaction ID.         |
   | `parent_transaction` | Groups internal records that belong to the same parent transaction. |
   | `source`             | Groups internal records with the same source balance.               |
   | `destination`        | Groups internal records with the same destination balance.          |
   | `reference`          | Groups internal records that share the same reference.              |
   | `currency`           | Groups internal records by currency.                                |
   | `status`             | Groups internal records by status.                                  |
   | `created_at`         | Groups internal records created at the same time or date.           |

2. **Many-to-one**:

   | Grouping criteria | What it does                                           |
   | :---------------- | :----------------------------------------------------- |
   | `id`              | Groups external records by their ID.                   |
   | `amount`          | Groups external records that share the same amount.    |
   | `currency`        | Groups external records by currency.                   |
   | `reference`       | Groups external records that share the same reference. |
   | `description`     | Groups external records by description.                |
   | `date`            | Groups external records by their date.                 |

<Note>Grouping criteria is not required for one-to-one strategy.</Note>

***

## Need help?

We are very happy to help you make the most of Blnk, regardless of whether it is your first time or you are switching from another tool.

To ask questions or discuss issues, please [contact us](mailto:support@blnkfinance.com) or [join our Discord community](https://discord.gg/7WNv94zPpx).

<CtaCallout title="Need help with your product?" href="https://blnkfinance.com/contact/us?utm_source=blnk_docs&utm_medium=documentation&utm_campaign=home%2Finstall" buttonLabel="Speak with us" trackingEvent="clicked_pro_support">
  Get dedicated support for architecture reviews, integration planning, ledger workflows, and production deployment.
</CtaCallout>
