-
Notifications
You must be signed in to change notification settings - Fork 823
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
Allow setting sql_mode via config #9721
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This seems fair enough - though I'm not sure that changing the mode is the right way to fix issues where more specific SQL is required.
SQL mode ANSI was necessary for double-quoted column names to work when it was first introduced. If SQL mode isn't ANSI does the ORM still work properly? We should probably run the test suite with this setting. If this is basically the "5.7 support" flag then it might make sense to document as such and include a 5.7 build in our CI matrix. |
@sminnee I think the issue is that For modules/code that doesn't provider a fully qualified
As with issue #5451 - it's really an issue with query construction (and maybe we could have a bit more "magic" in our query builders to add the table prefix to the |
My main concern here is that the ORM relies on the SQL mode, so on the face of it proving an open-ended SQL mode selector seems like a "maybe this breaks the ORM" button. So if there's a different SQL mode that is necessary to get 5.7 to work, we should focus on defining and allowing that. |
Alternatively we could find a SQL mode that works in both 5.6 My concern with this config option is that we'll end up with many different SQL modes in the wild and effectively sign up for supporting each of them. I naively suspect that there is, in fact, "one right answer" here. ;-) |
As far as I'm aware I don't think this a requirement for 5.7 - as this is mainly in the scenario that you're using custom queries (eg the fluent issue above) but I could be wrong. As far as having the option - we allow configuring almost all the other options for the connection but this one is hard-coded. It feels a little prescriptive to hard code this as we can't really foresee how things might change or others' use cases. I don't think this implies support of any old sql mode. Allowing people to set options is the kind of flexibility we encourage with other parts of the system why is this one different? Defaulting to having FULL_GROUP_BY seems reasonable and encourages more deterministic SQL so would seem a good thing to keep. But given 5.6 is EOL in feb, I can foresee a bunch of people running into issues with this when they upgrade. The option to dial it back would likely reduce support issues. |
Improving the build matrix will help with that.
Perhaps. But even if we do have this option I wouldn't want it to be a necessary part of solving the problem you're experiencing right now ;-) key modules shouldn't require hacks to deal with 5.6's EOL. So while we may add set mode as an @internal "danger zone" API, I think we do need to reconsider the default value we have in place. |
I think my concern is that I want to make it impossible to turn off ANSI_QUOTES, and maybe some other setting without which the ORM would be bricked. So perhaps this config setting is more like an array argument of flags and some minimal flags are enforced by the connector. Then I'd have in the CI matrix a config that includes only those minimal flags to confirm that framework does not require any others. |
OK so having had a look at this:
So I think we should:
When setting the default value note that an array without keys is a pain to modify in yml config so I'd probably set it up like this: /**
* @var array
* Set the SQL modes to apply to the connection.
* ANSI_QUOTES is mandatory
* The keys are not used; they are to provide support for clearing values in yml config.
*/
private static $sql_mode = [
'ANSI_QUOTES' => 'ANSI_QUOTES',
'REAL_AS_FLOAT' => 'REAL_AS_FLOAT',
'PIPES_AS_CONCAT' => 'PIPES_AS_CONCAT',
'IGNORE_SPACE' => 'IGNORE_SPACE',
]; And then use this to get the value: array_filter(array_values(static::config()->get(sql_mode)); Which lets you do this to clear a default mode Bla\MySQLDatabase:
sql_mode:
REAL_AS_FLOAT: null |
@silverstripe/core-team but particularly @dhensby keen to get your view on whether removing ONLY_FULL_GROUP_BY to preserve 5.6/5.7 continuity is appropriate. Notably, there are no SQL queries that require ONLY_FULL_GROUP_BY - it's a flag that adds strictness rather than taking it away. |
I don't really mind making this change, but I do think it's unnecessary because there's nothing in the ORM breaking by having these settings. As I understand it, developers need to be implementing their own It just feels a bit like PHP My order of preference is probably:
Having said that, I won't object too strongly because I do believe flexibility and configure-ability is a good thing and if developers want to make changes that break the ORM, that's not really our problem; if there are modules having to implement brittle "hacks" (like fluent) then I'd rather provide them an official API surface to do it for the cases it's needed. PS: I understand this is a bit contradictory - I've approved this change but I'm saying I'd prefer just to tell people to live with it as is - that's because whilst I might have an idealistic preference, I accept that's not much comfort to people who feel they need this change |
I'm with Dan on this. Unless our highlevel ORM API produces this issue, I don't think there's a good reason why we should invite this laziness in custom queries by default, and further increase the complexity of our API through Sam's proposal. But I'm also with Bernie. Making In terms of build matrix, we've been testing exclusively on MySQL 5.7 for a while (since xenial). At least in Travis, it looks like you can't mix different dists, which would be required to test on different MySQL versions. We could test different mariadb versions though. |
5.6 is going EOL which means we're going to need to force 5.7 on a bunch of users. I'm not sure why "small API change to reduce the pain there" is a bad idea. This is not about "encouraging laziness" this is about "retaining consistent behaviour". I could see why we might not want to change the default, but at a minimum, I'd introduce the new API and provide instructions for changing the setting for those who upgrade to MySQL 5.7 and hit this issue. |
If you want to make sql_mode configured as a string as this patch provides, can we please ensure that the docblock clearly says "you must includes ANSI_QUOTES or your site will be completely non-functional". It would also be worth including in the docblock the recommendation of "REAL_AS_FLOAT, PIPES_AS_CONCAT, ANSI_QUOTES, IGNORE_SPACE" if you have upgraded from 5.6 to 5.7 and are hitting issues. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since there seems to be agreement that this PR should proceed (retaining the current default but making it configurable), let's get this merged in time for 4.7.
Per the discussion above, I've suggested an expanded description for the config itself. I'd recommend adding a note to the documentation - perhaps in the DB section of Server Requirements - about the situational adjustments when running 5.7, and linking to this in the provisional 4.7.0 changelog (and possibly within the docblock too.)
@blueo Will you have time to make these additions within the next few days? If not, we can organise this within the CMS Squad.
👍 Should be able to get onto this in the next couple of days @Cheddam |
Co-authored-by: Garion Herman <garion@silverstripe.com>
a2f3d26
to
f0459fc
Compare
@Cheddam I've added some doc updates in addition to your suggestions. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks @blueo! A couple of minor language tweaks, otherwise I'm happy with this 👍
Co-authored-by: Garion Herman <garion@silverstripe.com>
Co-authored-by: Garion Herman <garion@silverstripe.com>
From pull request silverstripe#9721
MYSQL >=5.7.5 introduced a change to the
ANSI
alias for thesql_mode
setting. Namely, it now includesONLY_FULL_GROUP_BY
. While this may be more correct SQL it can cause problems eg:Projects built to 5.6 will have a few surprises when upgrading to 5.7 as there is no warning on the current behaviour.
And there have been a few attempts to fix it outside of framework eg:
So i'm proposing we make this a config option and those who need to/know what they're after can change the connection mode.