Skip to content

Commit

Permalink
Update RESTORE behaviour for LIKE operator for CS_AI collation (#3207)
Browse files Browse the repository at this point in the history
(cherry picked from commit 3fe245b)
  • Loading branch information
ahmed-shameem committed Dec 21, 2024
1 parent 0eac028 commit b2d3324
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 1 deletion.
19 changes: 19 additions & 0 deletions contrib/babelfishpg_common/src/collation.c
Original file line number Diff line number Diff line change
Expand Up @@ -1282,6 +1282,24 @@ has_ilike_node(Node *expr)
return false;
}

bool
has_like_node(Node *expr)
{
OpExpr *op;

Assert(IsA(expr, OpExpr));

op = (OpExpr *) expr;
for (int i = 0; i < TOTAL_LIKE_OP_COUNT; i++)
{
if (strcmp(get_opname(op->opno), like_ilike_table[i].like_op_name) == 0)
{
return true;
}
}
return false;
}

Datum
is_collated_ci_as_internal(PG_FUNCTION_ARGS)
{
Expand Down Expand Up @@ -1531,6 +1549,7 @@ get_collation_callbacks(void)
collation_callbacks_var.find_cs_as_collation_internal = &find_cs_as_collation;
collation_callbacks_var.find_collation_internal = &find_collation;
collation_callbacks_var.has_ilike_node = &has_ilike_node;
collation_callbacks_var.has_like_node = &has_like_node;
collation_callbacks_var.translate_bbf_collation_to_tsql_collation = &translate_bbf_collation_to_tsql_collation;
}
return &collation_callbacks_var;
Expand Down
3 changes: 3 additions & 0 deletions contrib/babelfishpg_common/src/collation.h
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,8 @@ typedef struct collation_callbacks

bool (*has_ilike_node) (Node *expr);

bool (*has_like_node) (Node *expr);

const char *(*translate_bbf_collation_to_tsql_collation) (const char *collname);

} collation_callbacks;
Expand Down Expand Up @@ -139,6 +141,7 @@ extern int find_collation(const char *collation_name);
extern const char *translate_bbf_collation_to_tsql_collation(const char *collname);
Oid get_oid_from_collidx(int collidx);
extern bool has_ilike_node(Node *expr);
extern bool has_like_node(Node *expr);
extern Oid babelfish_define_type_default_collation(Oid typeNamespace);

extern collation_callbacks *get_collation_callbacks(void);
Expand Down
14 changes: 13 additions & 1 deletion contrib/babelfishpg_tsql/src/collation.c
Original file line number Diff line number Diff line change
Expand Up @@ -918,9 +918,14 @@ transform_likenode(Node *node)
* by a user. So, it is safe to go ahead with replacing the ci_as
* collation with a corresponding cs_as one if an ILIKE node is found
* during dump and restore.
* For CS_AI collation, we keep the LIKE operator but convert it to
* CS_AS by adding a call to remove_accents_internal*. During restore,
* it will take the same code path and will try to add a new call to
* remove_accents_internal* on top of current node. So, we take care
* of that case here.
*/
init_and_check_collation_callbacks();
if ((*collation_callbacks_ptr->has_ilike_node) (node) && babelfish_dump_restore)
if (babelfish_dump_restore && ((*collation_callbacks_ptr->has_ilike_node) (node) || (*collation_callbacks_ptr->has_like_node) (node)))
{
int collidx_of_cs_as;

Expand All @@ -941,6 +946,13 @@ transform_likenode(Node *node)
/* If a collation is not specified, use the default one */
op->inputcollid = DEFAULT_COLLATION_OID;
}

/*
* If this has a like node, then it is CS collation
* So we can return from here directly
*/
if ((*collation_callbacks_ptr->has_like_node) (node))
return node;
}

if (OidIsValid(like_entry.like_oid) &&
Expand Down
2 changes: 2 additions & 0 deletions contrib/babelfishpg_tsql/src/collation.h
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,8 @@ typedef struct collation_callbacks

bool (*has_ilike_node) (Node *expr);

bool (*has_like_node) (Node *expr);

const char *(*translate_bbf_collation_to_tsql_collation) (const char *collname);

} collation_callbacks;
Expand Down

0 comments on commit b2d3324

Please sign in to comment.