with ambiguous(j) as
(select '[' || char(9) || '721]')
select
json_valid(j, 0x1) as "RFC 8259",
json_valid(cast(j as blob), 0x8) as "JSONB"
from ambiguous;
Also, this is an example of why dynamic typing is never safe, whether in a normal programming language or in your sql database. It turns out that the sqlite documentation has been lying for years and people assumed everything was fine. d = '0' | ... | '9'
e = 'E' | 'e'
int-frag = d d d
canon-float-frag = int-frag | d e d | d '.' d
float-frag = canon-float-frag | '.' d d | d d '.'
float-suffix-frag = float-frag | e '+' d | e '-' d | e d d | '.' e d
string-type = '7' | '8' | '9'
polyglot-json =
'3' int-frag |
'5' canon-float-frag |
'6' float-frag |
string-type float-suffix-frag |
'[' '\x09' string-type float-suffix-frag ']'
There are some additional possibilities like `40e3` which are rejected by the validation code but otherwise accepted. (`4` encodes a three-byte-long hexadecimal literal.)More like the SQLite docs made an assumption and people, maintainers and users, didn't realize it until later.
Why the sudden hostility?
Especially remember that most people don't care about opening files in text mode vs binary mode. This is only more true in a UTF-8-only world.
Per this comment:
https://sqlite.org/forum/forumpost/b6f940e87dd28cf8
> Fix your code with CASTs instead of complaining about it. You didn't follow the documentation
Essentially, the person was using json incorrectly (as per documentation even prior to this release) and now this version of SQLite is causing their incorrect code to not behave as they wanted.
But because SQLite doesn’t want to break backward compatibility (even for a prior unknown bug), they are considering persisting the bug as seen here:
He considers it a bug (in an EARLIER version of having unspecified behavior, not a later version, but there's no difference in practice):
That you could use a BLOB as the left-hand side argument to -> in 3.44.0 is a previously unreported bug in 3.44.0.
This bug in prior versions of SQLite was unknown to the developers. If I had known about it, I would have done something about it. I probably would have tried to preserve the buggy behavior - to maintain "bug compatibility". But I didn't know.
So there is a bug -- which is fine, all software has bugs -- but it's not a USER error, which you're implying.
If the documentation clearly says that something should not work, the same thing does not work in other DBs (-> semantics follow Postgres for example), and the definition of the underlying DB types does not really allow for this to work, then the smart thing is to not rely on the behavior (and open a bug report).
> This bug in prior versions of SQLite was unknown to the developers. If I had known about it, I would have done something about it. I probably would have tried to preserve the buggy behavior - to maintain "bug compatibility". But I didn't know.
That comment is much more patient, and less easily misconstrued by drive-by commenters.
Having been bitten by them breaking compatibility by fixing a "bug" that worked for a long time[0], I would dispute this (albeit mildly.)
[0] Using CTEs with views.