Make WordPress Core

Opened 11 years ago

Closed 11 years ago

Last modified 10 years ago

#12021 closed defect (bug) (fixed)

Default database create SQL makes invalid assumptions about primary key values

Reported by: wpmuguru Owned by:
Milestone: 3.0 Priority: normal
Severity: normal Version:
Component: Multisite Keywords:
Focuses: Cc:


MU Trac Ticket: http://trac.mu.wordpress.org/ticket/1123

See http://mu.wordpress.org/forums/topic/14691

We're hosting our WPMU install on an internal cluster of machines, and the dev DB server we're testing this on used to be part of a Master-Master setup, so its autoincrement values were set to increment in 10s, starting with 2.

Since the blog and site creation SQL sends a NULL value to the ID field (a reasonable thing to do on an insert), the autoincrement value gets set to whatever the server thinks it should be. However, the source of this particular problem is because the successive inserts assume this value will be 1 on a fresh install.

While this is a strange case, it's certainly not out of the realm of other setups, and could easily be addressed by doing a select on the id of the first site and blog created, instead of assuming values of 1.

*I've attached a patch to remedy the situation.*

Another related bug is the fact that wp-admin/includes/schema.php is include_once()'d (via upgrade.php) in index-install.php immediately after step2(). Then immediately after, during step3(), when the value of the $wpdb->xxxx table names should contain the right blog id, it's include_once()'d again to get the right CREATE statements. However, since it had already been include_once()'d, it is ignored the second time, making its inclusion at that point useless.

I've put this code into a function that may be called at will to repopulate the $wp_queries global variable with the correct values for table names.

Change History (3)

#1 @wpmuguru
11 years ago

Related ticket #11816

#2 @wpmuguru
11 years ago

  • Resolution set to fixed
  • Status changed from new to closed

(In [12862]) allow initial site_id to be assigned by MySQL, fixes #12021

#3 @nacin
10 years ago

  • Milestone changed from Unassigned to 3.0
Note: See TracTickets for help on using tickets.