Rake db Fixtures MySql autoincrement problem?

I’m trying to load some Rake Fixtures (rake db:fixtures:load) into a
MySql database and I’m seeing some weird behaviour with AutoIncrement
values. Normally this goes up by 1 for each insert which allows me to
define/create tests. (BTW - normal create/insert from script works
correctly).

However when I load from fixtures the id field is assigned a large
random number and the autoinc value on the table is also a large
number (1054583385) after the load. Has anyone else seen this?

FWIW this is on Windows XP with MySql 5.0 (I also tested with MySql
5.1, found the problem and rolled back to 5.0).

Anybody else seen this - Is this a known bug/issue?

TIA

BrendanC wrote:

I’m trying to load some Rake Fixtures (rake db:fixtures:load) into a
MySql database and I’m seeing some weird behaviour with AutoIncrement
values. Normally this goes up by 1 for each insert which allows me to
define/create tests. (BTW - normal create/insert from script works
correctly).

However when I load from fixtures the id field is assigned a large
random number and the autoinc value on the table is also a large
number (1054583385) after the load. Has anyone else seen this?

This is normal behavior (I believe the numbers come from a hash of the
record, or something like that). Why is it a problem for you?

Best,

Marnen Laibow-Koser
http://www.marnen.org
[email protected]

Just tried the same think and I was surprised as you. I do not think
that it is normal behavior.
It is really weird. And even sometimes it works as I wish and second
time (after rake db:fixture:load) not.

Zdenek

On 1 srp, 00:36, Marnen Laibow-Koser <rails-mailing-l…@andreas-

2009/8/5 [email protected] [email protected]:

Just tried the same think and I was surprised as you. I do not think
that it is normal behavior.
It is really weird. And even sometimes it works  as I wish and second
time (after rake db:fixture:load) not.

As Marnen said this is normal behaviour. If an id value is explicitly
provided for a record in the fixture data then that value will be
used, otherwise a value is calculated from the name of the record (ie
the heading line of the record in the fixture). This allows automatic
linking of associated record. So if A has_many Bs and B belongs_to A
then in A fixture:

a_1:
field_1: data
field_2: data

and in B fixture

b_1:
a: a_1 # instead of a_id: id_of_a_1_whatever_that_is

this makes it much easier to link records than manually setting up all
the id values

Colin