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

dolt 1.34.0 #162234

Merged
merged 2 commits into from
Feb 10, 2024
Merged

dolt 1.34.0 #162234

merged 2 commits into from
Feb 10, 2024

Conversation

BrewTestBot
Copy link
Member

Created by brew bump


Created with brew bump-formula-pr.

release notes
# Merged PRs

dolt

  • 7468: go/libraries/events: Restructure events collection so that we can send events while the dolt process is running.
    We make the GlobalCollector mutable.
    We give the Collector a sendingThread which can have an Emitter. When the Collector collects enough events, it forwards a batch of them to the sendingThread. If the sendingThread has an Emitter, it attempts to send its current batch on that Emitter.
    On shutdown, contexts get canceled, background threads get waited on, and then an accumulated un-emitted events are returned from the Collector, same as previously.
  • 7463: SELECT ... INTO OUTFILE ... tests
    This PR adds BATS tests for a SELECT ... INTO OUTFILE ... feature we're adding.
    Companion pr: support SELECT ... INTO OUTFILE/DUMPFILE ... dolthub/go-mysql-server#2317
  • 7457: Added storage capabilities for GMS Extended Types
    This adds the necessary scaffolding to support the new ExtendedType interface within GMS. This interface is primarily used by DoltgreSQL to implement PostgreSQL types.
    Related PRs:
  • 7424: Stats auto refresh
    Three new system variables to configure stats auto refresh, one for turning on, one for a timer of how often to check whether stats are fresh, and a third for a freshness threshold to trigger writing new stats. The system variables are global, and will apply to all databases in a server context. Adding or dropping databases, tables, and indexes are reflected by the statistics provider.
    Statistic updates now funnel through a process where we preserve buckets for pre-existing chunks and create new buckets specifically for new chunk ordinals. The auto-refresh threshold compares the number of new and deleted buckets compared the the existing bucket count. So inserts, updates, and deletes all create new chunks or delete chunks relative to the previously saved statistics, and the fraction of (new+deleted)/previous count is compared against the threshold.
    TODO:
    • how much logging is appropriate
    • go server tests
    • is stats dataset replication blocked by default?
      other:
    • ANALYZE table and auto-refresh concurrency, last write wins? as long as auto-refresh thread doesn't die
    • drop database/ANALYZE concurrency, error for writing stats to a deleted folder

go-mysql-server

  • 2323: SQLEXCEPTION proc handler
    We originally supported one type of procedure handler, NOT FOUND, which explicitly checked for an error when fetching from a cursor io.EOFs. The implementation for that handler would walk the entire BEGIN/END scope stack inside the Fetch call looking for a handler, execute the handler body, and then embed the scope height into a special return error. The error walked back up the callstack looking for the BEGIN/END block embedded in the error message.
    This PR:
    1. Refactors handlers to coordinate message passing in a centralized way. No metadata is embedded in FetchEOF, because each scope will explicitly compare its handlers to errors raised during execution within its BEGIN/END bounds. (FetchEOF is important because we differentiate between 3 different types of io.EOF in procedure loops).
    2. Add type/object support for representing specific signal handers.
    3. Add SQLEXCEPTION signal handling, which will trigger for any error type (other than io.EOF) that bubbles up during a BeginEndIter's execution.
      re: Add support for handlers dolthub/dolt#7454
      Another thing I noticed is that some of our tests return nil for empty stored procedures when mysql returns ERROR 1329 (02000): No data - zero rows fetched, selected, or processed. https://github.com/dolthub/dolt/issues/new
  • 2322: Allow InjectedExpr to handle name resolution
    Modifies the InjectedExpr handling to support additional expressions, such as those requiring name resolution.
    Related PRs:
  • 2317: support SELECT ... INTO OUTFILE/DUMPFILE ...
    This adds support for MySQL's SELECT ... INTO OUTFILE/DUMPFILE ... feature.
    It is the complement to LOAD DATA. There is no LOCAL option, so files created using this feature are on the server.
    This PR adds a custom TestSuite for testing these files, as it needs to write, read, and delete files.
    syntax: add syntax support for SELECT ... INTO OUTFILE ... options dolthub/vitess#311
    fixes Add support for "SELECT INTO" for files dolthub/dolt#7453
  • 2316: Allow primary keys with auto_increment columns to be dropped when an appropriate index exists
    MySQL allows a primary key with an auto_increment column to be dropped as long as there is a secondary index that includes the auto_increment column as the first column in the index. (MySQL Reference)
    This PR also enables dropping a primary key by referencing it by it's ID (PRIMARY), in order to match MySQL's behavior, e.g.
    DROP INDEX `PRIMARY` ON t;
    
    Related to Can't drop primary index.  dolthub/dolt#7456
  • 2312: Added the ExtendedType interface
    This adds the ExtendedType interface, which is used within DoltgreSQL to implement PostgreSQL types, as well as in Dolt to properly handle the new type and value serialization.
    Related PRs:
  • 2300: Fix External Index Creation
    Fixes regression introduced by 9b9301f8c4709d2d32982068322662643e02f231
    Currently
    CREATE INDEX foo USING driver table (column)
    creates a table scan if driver is not "", "btree" or "hash".
    The regression is caused by the change:
    -	outScope.node = plan.NewCreateIndex(
    +	createIndex := plan.NewCreateIndex(
    ddl.IndexSpec.ToName.String(),
    table,
    cols,
    ddl.IndexSpec.Using.Lowered(),
    config,
    )
    +	createIndex.Catalog = b.cat
    return

vitess

Closed Issues

  • 7453: Add support for "SELECT INTO" for files
  • 7456: Can't drop primary index.
  • 3921: Implement COM_RESET_CONNECTION

@github-actions github-actions bot added go Go use is a significant feature of the PR or issue bump-formula-pr PR was created using `brew bump-formula-pr` labels Feb 10, 2024
Copy link
Contributor

🤖 An automated task has requested bottles to be published to this PR.

@github-actions github-actions bot added the CI-published-bottle-commits The commits for the built bottles have been pushed to the PR branch. label Feb 10, 2024
@BrewTestBot BrewTestBot added this pull request to the merge queue Feb 10, 2024
Merged via the queue into Homebrew:master with commit a9cf5df Feb 10, 2024
12 checks passed
@BrewTestBot BrewTestBot deleted the bump-dolt-1.34.0 branch February 10, 2024 10:02
@github-actions github-actions bot added the outdated PR was locked due to age label Mar 12, 2024
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Mar 12, 2024
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
bump-formula-pr PR was created using `brew bump-formula-pr` CI-published-bottle-commits The commits for the built bottles have been pushed to the PR branch. go Go use is a significant feature of the PR or issue outdated PR was locked due to age
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants