-
-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Fixed a bug in the Oracle driver of the gf framework where lowercase table names were not supported. #4312
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
base: master
Are you sure you want to change the base?
Conversation
…Filter function caused lowercase table names to become unsupported.
…Filter function caused lowercase table names to become unsupported.
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.
Pull request overview
This PR fixes a bug in the Oracle driver where lowercase table names were not supported. The issue stemmed from the driver removing all double quotes from SQL statements, which prevented Oracle from preserving case-sensitive identifiers (Oracle uses double quotes to maintain case sensitivity; without them, identifiers are converted to uppercase).
Key Changes:
- Removed the code in
oracle_do_filter.gothat stripped all double quotes from SQL statements - Updated test utilities to use double-quoted table names to preserve case sensitivity
Reviewed changes
Copilot reviewed 2 out of 2 changed files in this pull request and generated no comments.
| File | Description |
|---|---|
| contrib/drivers/oracle/oracle_do_filter.go | Removed the regex replacement that deleted all double quotes from SQL statements, allowing case-sensitive table names to be preserved |
| contrib/drivers/oracle/oracle_z_unit_init_test.go | Updated table creation and dropping to use double-quoted table names; simplified dropTable function and removed unused strings import |
💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.
背景:在Oracle中,双引号用于标识区分大小写的标识符,包括表名。当表名用双引号括起来时,Oracle会保留其大小写,否则,Oracle会将标识符转换为大写
问题:oracle_do_filter.go文件DoFilter函数中newSql, err = gregex.ReplaceString(""", "", newSql)会将sql语句中“”全部删除,导致无法支持表名为小写的表。
解决:删除newSql, err = gregex.ReplaceString(""", "", newSql)