Long story short, I have a SQL file that I want to import as a skel
style file, so this will be done repeatedly, programmatically. I can edit the SQL file however I want, but I'd rather not touch the application itself.
This application uses userid = 0
to represent the anonymous user. It also has a relevant (blank) entry in the database to represent this 'user'. Hence, the line in my skel.sql
looks something like this:
INSERT INTO `{{TABLE_PREFIX}}users` VALUES (0, '', '', '', 0, 0, 0, '', '', 0, 0, 0, 0, 0, NULL, '', '', '', NULL);
The problem with this is that uid
is a auto_increment
field, for which, technically, 0
is an invalid value. Or atleast, if you set it to 0, you're basically telling MySQL, "Please insert the next id into this field."
Now, I suppose I could put an INSERT
then an UPDATE
query into my SQL file, but is there a way of telling MySQL in general that yes, I actually want to insert 0
into this field?
-
You can use:
SET [GLOBAL|SESSION] sql_mode='NO_AUTO_VALUE_ON_ZERO'
Which as described here, will prevent MySQL from interpreting an INSERT/UPDATE ID of 0 as being the next sequence ID. Such behaviour will be limited to NULL.
It is what I'd consider pretty bad behaviour from the application though. You'll have to be real careful that it's used consistently, especially if you choose to implement replication at a later date.
From Dan Carley -
Check your sql DB mode with:
SELECT @@[GLOBAL|SESSION].sql_mode;
If it's empty or not set, use:
SET [GLOBAL|SESSION] sql_mode='NO_AUTO_VALUE_ON_ZERO'
BE CAREFUL! If you use
GLOBAL
, it's not an inmediate change, you need to restart your connection to apply the setting.So, if you're restoring data from one DB to another, for example, and you're not sure if this setting is applied, use
SESSION
for an inmediate change (resets when closing connection). When done, insert 0 value and it won't change even if thesql_mode
is changed.To reset this mode (and others) use
SET [GLOBAL|SESSION] sql_mode=''
Zero autoincrement values are not recommended to be used, 'cause it's not set as default in mysql databases.
For more info check mysql dev page topic on this
From Nacho
0 comments:
Post a Comment