Here is my output. Note that my updates are for "0.44444444444444442" not "0.4444444444444444". Both Python 2.5.2 and 2.6.5 interpret the test_value this way. I wonder if you are not seeing the error due to the float changes in Python 2.7?
$ uname -a Linux dev05 2.6.24-24-server #1 SMP Wed Apr 15 15:41:09 UTC 2009 x86_64 GNU/Linux $ python Python 2.5.2 (r252:60911, Jan 20 2010, 23:14:04) [GCC 4.2.4 (Ubuntu 4.2.4-1ubuntu3)] on linux2 Type "help", "copyright", "credits" or "license" for more information. >>> import sqlalchemy >>> sqlalchemy.__version__ '0.6.5' >>> 0.4444444444444444444 0.44444444444444442 >>> $ python ~/float_update_test.py 2010-11-05 06:12:13,122 INFO sqlalchemy.engine.base.Engine.0x...b750 SELECT DATABASE() 2010-11-05 06:12:13,122 INFO sqlalchemy.engine.base.Engine.0x...b750 () 2010-11-05 06:12:13,124 INFO sqlalchemy.engine.base.Engine.0x...b750 SHOW VARIABLES LIKE 'character_set%%' 2010-11-05 06:12:13,124 INFO sqlalchemy.engine.base.Engine.0x...b750 () 2010-11-05 06:12:13,125 INFO sqlalchemy.engine.base.Engine.0x...b750 SHOW VARIABLES LIKE 'lower_case_table_names' 2010-11-05 06:12:13,125 INFO sqlalchemy.engine.base.Engine.0x...b750 () 2010-11-05 06:12:13,126 INFO sqlalchemy.engine.base.Engine.0x...b750 SHOW COLLATION 2010-11-05 06:12:13,126 INFO sqlalchemy.engine.base.Engine.0x...b750 () 2010-11-05 06:12:13,130 INFO sqlalchemy.engine.base.Engine.0x...b750 SHOW VARIABLES LIKE 'sql_mode' 2010-11-05 06:12:13,130 INFO sqlalchemy.engine.base.Engine.0x...b750 () 2010-11-05 06:12:13,131 INFO sqlalchemy.engine.base.Engine.0x...b750 CREATE TABLE sqlalchemy_test_my_model ( id INTEGER NOT NULL AUTO_INCREMENT, float_value FLOAT, PRIMARY KEY (id) )ENGINE=InnoDB 2010-11-05 06:12:13,132 INFO sqlalchemy.engine.base.Engine.0x...b750 () 2010-11-05 06:12:13,135 INFO sqlalchemy.engine.base.Engine.0x...b750 COMMIT 2010-11-05 06:12:13,138 INFO sqlalchemy.engine.base.Engine.0x...b750 BEGIN (implicit) 2010-11-05 06:12:13,139 INFO sqlalchemy.engine.base.Engine.0x...b750 INSERT INTO sqlalchemy_test_my_model (float_value) VALUES (%s) 2010-11-05 06:12:13,139 INFO sqlalchemy.engine.base.Engine.0x...b750 (0.44444444444444442,) 2010-11-05 06:12:13,140 INFO sqlalchemy.engine.base.Engine.0x...b750 COMMIT 2010-11-05 06:12:13,143 INFO sqlalchemy.engine.base.Engine.0x...b750 BEGIN (implicit) 2010-11-05 06:12:13,144 INFO sqlalchemy.engine.base.Engine.0x...b750 SELECT sqlalchemy_test_my_model.id AS sqlalchemy_test_my_model_id, sqlalchemy_test_my_model.float_value AS sqlalchemy_test_my_model_float_value FROM sqlalchemy_test_my_model WHERE sqlalchemy_test_my_model.id = %s 2010-11-05 06:12:13,144 INFO sqlalchemy.engine.base.Engine.0x...b750 (1L,) 2010-11-05 06:12:13,146 INFO sqlalchemy.engine.base.Engine.0x...b750 UPDATE sqlalchemy_test_my_model SET float_value=%s WHERE sqlalchemy_test_my_model.id = %s 2010-11-05 06:12:13,147 INFO sqlalchemy.engine.base.Engine.0x...b750 (0.44444444444444442, 1L) 2010-11-05 06:12:13,147 INFO sqlalchemy.engine.base.Engine.0x...b750 ROLLBACK 2010-11-05 06:12:13,149 INFO sqlalchemy.engine.base.Engine.0x...b750 DROP TABLE sqlalchemy_test_my_model 2010-11-05 06:12:13,149 INFO sqlalchemy.engine.base.Engine.0x...b750 () 2010-11-05 06:12:13,425 INFO sqlalchemy.engine.base.Engine.0x...b750 COMMIT Traceback (most recent call last): File "/nail/home/lenza/float_update_test.py", line 70, in <module> test_class.test_update_data() File "/nail/home/lenza/float_update_test.py", line 51, in test_update_data session.commit() File "/var/lib/python-support/python2.5/sqlalchemy/orm/session.py", line 623, in commit self.transaction.commit() File "/var/lib/python-support/python2.5/sqlalchemy/orm/session.py", line 385, in commit self._prepare_impl() File "/var/lib/python-support/python2.5/sqlalchemy/orm/session.py", line 369, in _prepare_impl self.session.flush() File "/var/lib/python-support/python2.5/sqlalchemy/orm/session.py", line 1397, in flush self._flush(objects) File "/var/lib/python-support/python2.5/sqlalchemy/orm/session.py", line 1478, in _flush flush_context.execute() File "/var/lib/python-support/python2.5/sqlalchemy/orm/unitofwork.py", line 304, in execute rec.execute(self) File "/var/lib/python-support/python2.5/sqlalchemy/orm/unitofwork.py", line 448, in execute uow File "/var/lib/python-support/python2.5/sqlalchemy/orm/mapper.py", line 1852, in _save_obj (table.description, len(update), rows)) sqlalchemy.orm.exc.StaleDataError: UPDATE statement on table 'sqlalchemy_test_my_model' expected to update 1 row(s); 0 were matched. On Fri, Nov 5, 2010 at 12:27 AM, Michael Bayer <mike...@zzzcomputing.com>wrote: > > On Nov 5, 2010, at 2:51 AM, Lenza McElrath wrote: > > Well, turns out that it doesn't take much of a pool at all to get the test > to fail: http://pastebin.com/trHhiG47 > > > sorry, again this works fine, and theres still nothing in the test as given > that can cause StaleDataError. > > output when I add echo=True: > > 010-11-05 03:24:49,463 INFO sqlalchemy.engine.base.Engine.0x...e610 SELECT > DATABASE() > 2010-11-05 03:24:49,463 INFO sqlalchemy.engine.base.Engine.0x...e610 () > 2010-11-05 03:24:49,465 INFO sqlalchemy.engine.base.Engine.0x...e610 SHOW > VARIABLES LIKE 'character_set%%' > 2010-11-05 03:24:49,465 INFO sqlalchemy.engine.base.Engine.0x...e610 () > 2010-11-05 03:24:49,465 INFO sqlalchemy.engine.base.Engine.0x...e610 SHOW > VARIABLES LIKE 'lower_case_table_names' > 2010-11-05 03:24:49,466 INFO sqlalchemy.engine.base.Engine.0x...e610 () > 2010-11-05 03:24:49,466 INFO sqlalchemy.engine.base.Engine.0x...e610 SHOW > COLLATION > 2010-11-05 03:24:49,466 INFO sqlalchemy.engine.base.Engine.0x...e610 () > 2010-11-05 03:24:49,469 INFO sqlalchemy.engine.base.Engine.0x...e610 SHOW > VARIABLES LIKE 'sql_mode' > 2010-11-05 03:24:49,469 INFO sqlalchemy.engine.base.Engine.0x...e610 () > 2010-11-05 03:24:49,470 INFO sqlalchemy.engine.base.Engine.0x...e610 > CREATE TABLE sqlalchemy_test_my_model ( > id INTEGER NOT NULL AUTO_INCREMENT, > float_value FLOAT, > PRIMARY KEY (id) > )ENGINE=InnoDB > > > 2010-11-05 03:24:49,470 INFO sqlalchemy.engine.base.Engine.0x...e610 () > 2010-11-05 03:24:49,473 INFO sqlalchemy.engine.base.Engine.0x...e610 COMMIT > 2010-11-05 03:24:49,474 INFO sqlalchemy.engine.base.Engine.0x...e610 BEGIN > (implicit) > 2010-11-05 03:24:49,475 INFO sqlalchemy.engine.base.Engine.0x...e610 INSERT > INTO sqlalchemy_test_my_model (float_value) VALUES (%s) > 2010-11-05 03:24:49,475 INFO sqlalchemy.engine.base.Engine.0x...e610 > (0.4444444444444444,) > 2010-11-05 03:24:49,476 INFO sqlalchemy.engine.base.Engine.0x...e610 COMMIT > 2010-11-05 03:24:49,477 INFO sqlalchemy.engine.base.Engine.0x...e610 BEGIN > (implicit) > 2010-11-05 03:24:49,477 INFO sqlalchemy.engine.base.Engine.0x...e610 SELECT > sqlalchemy_test_my_model.id AS sqlalchemy_test_my_model_id, > sqlalchemy_test_my_model.float_value AS > sqlalchemy_test_my_model_float_value > FROM sqlalchemy_test_my_model > WHERE sqlalchemy_test_my_model.id = %s > 2010-11-05 03:24:49,477 INFO sqlalchemy.engine.base.Engine.0x...e610 (1L,) > 2010-11-05 03:24:49,479 INFO sqlalchemy.engine.base.Engine.0x...e610 UPDATE > sqlalchemy_test_my_model SET float_value=%s WHERE > sqlalchemy_test_my_model.id = %s > 2010-11-05 03:24:49,479 INFO sqlalchemy.engine.base.Engine.0x...e610 > (0.4444444444444444, 1L) > 2010-11-05 03:24:49,479 INFO sqlalchemy.engine.base.Engine.0x...e610 COMMIT > 2010-11-05 03:24:49,480 INFO sqlalchemy.engine.base.Engine.0x...e610 > DROP TABLE sqlalchemy_test_my_model > 2010-11-05 03:24:49,480 INFO sqlalchemy.engine.base.Engine.0x...e610 () > 2010-11-05 03:24:49,482 INFO sqlalchemy.engine.base.Engine.0x...e610 COMMIT > > > > > > On Thu, Nov 4, 2010 at 10:33 PM, Lenza McElrath <le...@lenza.org> wrote: > >> Interesting. When I use your simple engine I do not get the error either, >> but I definitely get it when using my real configuration. We are using a >> connection pool. So the construction of the session maker for the test >> looks like this: >> >> e = sqlalchemy.create_engine('mysql://', pool=connections.get_pool()) >> sessionmaker = sqlalchemy.orm.sessionmaker(e) >> >> The connection pool is somewhat complex, so I will try to find the >> simplest possible pool that reproduces the problem. But, do you have ideas >> based on this? The script only fails when I use a Float type with a >> test_value that is higher percision than the DB can represent. It works >> when I use an Integer type, or when test_value is 44 or 0.44. >> >> Thanks for your help! >> >> >> On Thu, Nov 4, 2010 at 6:18 PM, Michael Bayer >> <mike...@zzzcomputing.com>wrote: >> >>> >>> On Nov 4, 2010, at 8:17 PM, Lenza McElrath wrote: >>> >>> I am getting a StaleDataError when updating a Float column to the same >>> value twice in a row. This happens because SQLAlchemy thinks that I am >>> changing the value, but then the DB reports that no value was changed. >>> >>> Test case can be seen here: http://pastebin.com/vxFBAMxm >>> >>> >>> the test fails to note what "sessionmaker" is, if I run it like this: >>> >>> e = create_engine('mysql://scott:ti...@localhost/test') >>> test_class = UpdateFunctionTest(sessionmaker(e)) >>> >>> the script runs as expected with no errors. StaleDataError only occurs >>> if you execute() an update() or delete() construct that affects the primary >>> key or version number of a row in the same transaction as one that also >>> calls flush() and also targets that row. This test doesn't emit any raw SQL >>> constructs nor does it modify any primary key attributes or use version ids >>> so no error occurs. Float columns that aren't primary keys have nothing to >>> do with StaleDataError. >>> >>> >>> >>> -- >>> You received this message because you are subscribed to the Google Groups >>> "sqlalchemy" group. >>> To post to this group, send email to sqlalch...@googlegroups.com. >>> To unsubscribe from this group, send email to >>> sqlalchemy+unsubscr...@googlegroups.com<sqlalchemy%2bunsubscr...@googlegroups.com> >>> . >>> For more options, visit this group at >>> http://groups.google.com/group/sqlalchemy?hl=en. >>> >> >> > > -- > You received this message because you are subscribed to the Google Groups > "sqlalchemy" group. > To post to this group, send email to sqlalch...@googlegroups.com. > To unsubscribe from this group, send email to > sqlalchemy+unsubscr...@googlegroups.com. > For more options, visit this group at > http://groups.google.com/group/sqlalchemy?hl=en. > > > -- > You received this message because you are subscribed to the Google Groups > "sqlalchemy" group. > To post to this group, send email to sqlalch...@googlegroups.com. > To unsubscribe from this group, send email to > sqlalchemy+unsubscr...@googlegroups.com<sqlalchemy%2bunsubscr...@googlegroups.com> > . > For more options, visit this group at > http://groups.google.com/group/sqlalchemy?hl=en. > -- You received this message because you are subscribed to the Google Groups "sqlalchemy" group. To post to this group, send email to sqlalch...@googlegroups.com. To unsubscribe from this group, send email to sqlalchemy+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/sqlalchemy?hl=en.