Skip to content
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

Backport negative string size (or size too big) fix for Rails 7.0 #7

Draft
wants to merge 1 commit into
base: master
Choose a base branch
from
Draft
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 9 additions & 9 deletions lib/odbc_adapter/schema_statements.rb
Original file line number Diff line number Diff line change
Expand Up @@ -10,18 +10,18 @@ def native_database_types
# Returns an array of table names, for database tables visible on the
# current connection.
def tables(_name = nil)
stmt = @connection.tables
result = stmt.fetch_all || []
stmt.drop

table_names = []
db_regex = name_regex(current_database)
schema_regex = name_regex(current_schema)
result.each_with_object([]) do |row, table_names|
next unless row[0] =~ db_regex && row[1] =~ schema_regex
schema_name, table_name, table_type = row[1..3]
next if respond_to?(:table_filtered?) && table_filtered?(schema_name, table_type)
table_names << format_case(table_name)
stmt = @connection.prepare("SHOW TABLES IN ACCOUNT")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm just mildly curious, executing this for my personal user in Snowflake returned a very large result. Does this work only because our snowflake connection user is more limited access wise so the table count is reasonable?

Copy link
Author

@douglas douglas Oct 28, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmmmmm, I didn't tried it yet, but according to the comment on this commit:

use SHOW TABLES query to address "size too big" errors for long table comments
This change fixes an issue with the `tables` call erroring out if attempting to
fetch any tables that have longer than 254 character comments on them. This fix
is based on the approach used by the patterninc fork of the gem, whose PR does
a great job of explaining the issue and idea behind the solution:

> The fetch_all function is using a bound 'remarks' column that is configured to
> have a max_length of 254 characters. That max length is not configurable and the
> column cannot be unbound. So when a table with a comment longer than 254 characters
> exists in the result set, we run into the negative string size (or size too big) error.

- patterninc#9

The primary difference here is that we're using `SHOW TABLES IN ACCOUNT` query,
which should return the same set of tables as `fetch_all` was returning before,
eliminating the need for an opt-in config flag.

Snowflake docs on the SHOW TABLES query:
https://docs.snowflake.com/en/sql-reference/sql/show-tables

So, I suppose @connection.prepare("SHOW TABLES IN ACCOUNT") would return the same as the previous stmt.fetch_all, of course, depending on the account being used.

stmt.execute.each_hash do |row|
next unless row["database_name"] =~ db_regex && row["schema_name"] =~ schema_regex
next if respond_to?(:table_filtered?) && table_filtered?(row["schema_name"], row["kind"])
table_names << format_case(row["name"])
end
table_names
ensure
stmt.drop
end

# Returns an array of view names defined in the database.
Expand Down