DatabaseSchema_mysql::fieldExists() does not escape the column name

Created on 30 October 2023, over 1 year ago
Updated 17 April 2024, 12 months ago

Problem/Motivation

DatabaseSchema_mysql::fieldExists() does not escape the column name. This means that some column names can never be altered by the database API because verifying the field exists returns false.

Steps to reproduce

Create a table with a column name that would need to be escaped with back-ticks to functions properly, for example 'trigger'.
Try to change the field definition using db_change_field().
See an error that the definition could not be altered because the column does not exist.

Proposed resolution

Escape the column name with back-ticks like it is in other methods on the same class.

🐛 Bug report
Status

Needs review

Version

7.0 ⚰️

Component
MySQL driver 

Last updated 4 days ago

Created by

🇬🇧United Kingdom rlmumford Manchester

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Production build 0.71.5 2024