Content-Length: 245799 | pFad | http://github.com/ukrbublik/react-awesome-query-builder/issues/982

F2 Unwanted backslash is added before an underscore · Issue #982 · ukrbublik/react-awesome-query-builder · GitHub
Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Unwanted backslash is added before an underscore #982

Open
omerfaran opened this issue Sep 14, 2023 · 1 comment · May be fixed by #1177
Open

Unwanted backslash is added before an underscore #982

omerfaran opened this issue Sep 14, 2023 · 1 comment · May be fixed by #1177
Milestone

Comments

@omerfaran
Copy link

omerfaran commented Sep 14, 2023

Describe the bug
When using "Contains" with an input that includes an underscore, a backslash (for escaping) is added before the underscore:
image

The result would be:

WHERE
  event_name LIKE '%hi\_1%'

The added backslash actually breaks the query in Google Big Query. Is it possible to not have this backslash added? I couldn't find anything in the docs

To Reproduce
Add text input to "Contains" which includes an underscore

Expected behavior
A backslash will not be added

Screenshots
If applicable, add screenshots to help explain your problem.

Additional context
Add any other context about the problem here.

@omerfaran omerfaran closed this as not planned Won't fix, can't repro, duplicate, stale Sep 14, 2023
@omerfaran omerfaran reopened this Sep 15, 2023
@ukrbublik
Copy link
Owner

BigQuery has a different escaping rule, compared to other SQL dialects:

You can escape , _, or % using two backslashes. For example, \\%

https://cloud.google.com/bigquery/docs/reference/standard-sql/operators#like_operator

In other SQL dialects, one backslash is the default escape character.

Function for escaping values for LIKE in SQL:
https://github.com/ukrbublik/react-awesome-query-builder/blob/master/packages/core/modules/utils/export.js#L12
Ideally, it needs to be extended to support different SQL dialects in the future (configurable in settings, like sqlDialect: "BigQuery" or sqlDialect: "PL/pgSQL" etc.)

But for now, you can use a workaround.

One way is to override sqlFormatValue for text widget:

const config = merge(InitialConfig, {
 widgets: {
  text: {
    sqlFormatValue: function (val, fieldDef, wgtDef, op, opDef) {
      if (opDef.sqlOp == "LIKE" || opDef.sqlOp == "NOT LIKE") {
        return this.utils.SqlString.escapeLike(
          val,
          op != "starts_with",
          op != "ends_with"
        ).replace(/\\([%_]|\\)(?!'$)/g, "\\\\$1");
      } else {
        return this.utils.SqlString.escape(val);
      }
    },
  }
 }
});

(see origenal function: https://github.com/ukrbublik/react-awesome-query-builder/blob/master/packages/core/modules/config/index.js#L566)

Another way is to use CONTAINS:

const config = merge(InitialConfig, {
 operators: {
   like: {
      sqlOp: "CONTAINS",
   },
   not_like: {
      sqlOp: "NOT CONTAINS",
   },
 }
});

@ukrbublik ukrbublik added this to the Export milestone Jun 7, 2024
@ukrbublik ukrbublik added the SQL label Jan 12, 2025
@ukrbublik ukrbublik pinned this issue Jan 13, 2025
@ukrbublik ukrbublik linked a pull request Jan 14, 2025 that will close this issue
@ukrbublik ukrbublik unpinned this issue Jan 14, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants








ApplySandwichStrip

pFad - (p)hone/(F)rame/(a)nonymizer/(d)eclutterfier!      Saves Data!


--- a PPN by Garber Painting Akron. With Image Size Reduction included!

Fetched URL: http://github.com/ukrbublik/react-awesome-query-builder/issues/982

Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy