﻿id	summary	reporter	owner	description	type	status	component	version	severity	resolution	keywords	cc	stage	has_patch	needs_docs	needs_tests	needs_better_patch	easy	ui_ux
26120	Make HStoreField cast its key/values to strings	Przemek	Greg Chapple	"Suppose I have a simple model:

{{{
class Simple(models.Model):
    data = HStoreField(default={})
}}}

I can save hstore with mixed types, which is normal:

{{{
    simple = Simple.objects.create(data = {'a': 1, 'b': 'B'})
}}}

But the `update` function throws an exception:

{{{
   Simple.objects.filter(id=simple.id).update(data={'a': 1, 'b': 'B'})
}}}

{{{
Traceback (most recent call last):
  File ""failing.py"", line 19, in <module>
    show_error()
  File ""failing.py"", line 11, in show_error
    simple = Simple.objects.create(data={'a': 1, 'b': 'B'})
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/manager.py"", line 127, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/query.py"", line 348, in create
    obj.save(force_insert=True, using=self.db)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/base.py"", line 734, in save
    force_update=force_update, update_fields=update_fields)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/base.py"", line 762, in save_base
    updated = self._save_table(raw, cls, force_insert, force_update, using, update_fields)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/base.py"", line 846, in _save_table
    result = self._do_insert(cls._base_manager, using, fields, update_pk, raw)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/base.py"", line 885, in _do_insert
    using=using, raw=raw)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/manager.py"", line 127, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/query.py"", line 920, in _insert
    return query.get_compiler(using=using).execute_sql(return_id)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/models/sql/compiler.py"", line 974, in execute_sql
    cursor.execute(sql, params)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/backends/utils.py"", line 79, in execute
    return super(CursorDebugWrapper, self).execute(sql, params)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/backends/utils.py"", line 64, in execute
    return self.cursor.execute(sql, params)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/utils.py"", line 98, in __exit__
    six.reraise(dj_exc_type, dj_exc_value, traceback)
  File ""/usr/local/lib/python2.7/dist-packages/django/db/backends/utils.py"", line 64, in execute
    return self.cursor.execute(sql, params)
DataError: invalid input syntax for integer: ""B""
LINE 1: ...(""data"") VALUES (hstore(ARRAY['a', 'b'], ARRAY[1, 'B'])) RET...
}}}

See the toy project at https://github.com/CGenie/django_hstore_field_fail

This fails for 1.8 as well as for 1.9."	Cleanup/optimization	closed	contrib.postgres	1.8	Normal	fixed		Marc Tamlyn	Accepted	1	0	0	0	0	0
