- 
                Notifications
    You must be signed in to change notification settings 
- Fork 328
          Use longer identifier for DatabaseLimits when using Oracle 12.2 or higher
          #2128
        
          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
498c5d9    to
    ce00caa      
    Compare
  
    …higher Follow rsim#1703. Oracle enhanced adapter supports longer identifier by rsim#1703. I encountered the following error when using `rename_table` in Oracle 12c. ```console New table name 'identifier_of_thirty_bytes_or_more' is too long; the limit is 30 characters ``` Because `IDENTIFIER_MAX_LENGTH` constant was fixed to 30 bytes. This PR will use `max_identifier_length` method instead of the constant and accept longer identifier (max 128 bytes) when using Oracle 12.2 or higher. I encountered the error in Rails 6.0. So I'd like to backport to 6.1 and 6.0 stable branches.
ce00caa    to
    e605c2a      
    Compare
  
    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 for the pull request. I'm not sure if supports_longer_identifier or supports_longer_identifier? are good argument names yet. At least this argument name looks long.
Let me have some more time to consider that.
|  | ||
| # To allow private method called from `JDBCConnection` | ||
| def describe(name) | ||
| def describe(name, supports_longer_identifier) | 
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.
Do you mean supports_longer_identifier?
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.
Yes. It takes the result of ActiveRecord::ConnectionAdapters::OracleEnhancedAdapter#supports_longer_identifier? as argument. Unfortunately no better name has come up yet.
| I found that there will probably be breaking change in this PR. Please wait for a while due to I will investigate it. | 
| Sure. Although I have not checked this pull request in detail yet, In general, I prefer not to change method signature/arity for this requirement. Because the Oracle database version never changes per database connection. Also, I especially prefer not to change the method signature if it requires to backport to the older versions of Oracle enhanced adapter. Let's have some discussion if you have questions. Thank you. | 
| Any updates on this? | 
| This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions. | 
| Is there any work that needs to be completed on this? If so, I'd be happy to help. I am eager to see this in a release! | 
| @mattalat, the biggest complaint I see is changing of the method signatures. Since identifiers are same for the whole connection, I think that probably detecting their length within the connection and then accessing that value wherever needed would resolve that. Also my suggestion would be to have a method that returns length of identifiers instead of  | 
| Any updates on this? | 
| Another issue I see is that once the identifiers are switched to a different length, the table sequences for auto-incrementing primary keys may change names for long table names. At least previously when tables were created with an auto-increment primary key (the default), a sequence was created with name  With the new implementation it will have the full name. This difference will cause  So a migration PATH must be developed to update all necessary sequence names or somehow regenerate all sequences, idk. All said, it would be awesome to finally have long identifiers by default. So thank you for your contribution. | 
Follow #1703.
Oracle enhanced adapter supports longer identifier by #1703.
I encountered the following error when using
rename_tablein Oracle 12c.New table name 'identifier_of_thirty_bytes_or_more' is too long; the limit is 30 charactersBecause
IDENTIFIER_MAX_LENGTHconstant was fixed to 30 bytes.This PR will use
max_identifier_lengthmethod instead of the constant and accept longer identifier (max 128 bytes) when using Oracle 12.2 or higher.I encountered the error in Rails 6.0. So I'd like to backport to 6.1 and 6.0 stable branches.