|
JSONB и ASCii-символы <32
|
|||
---|---|---|---|
#18+
всем привет я тут пытаюсь таблицы из мускуля в пг загнать через COPY FROM, а там в колонке под JSONB есть такая строка: авторЕганово воладарски шоссе 22\1"} и в итоге я ловлю ошибку: авторСимвол с кодом 0x01 необходимо экранировать. из-за \1 получается, что пользовательские данные вообще в jsonb совать нельзя, потому что все такие сюрпризы не отловишь или как быть? ... |
|||
:
Нравится:
Не нравится:
|
|||
24.09.2017, 21:20 |
|
JSONB и ASCii-символы <32
|
|||
---|---|---|---|
#18+
точнее стандартно от юзера можно это провалидировать, но вот пропустит ли его ПХП pg_query_params() ? ... |
|||
:
Нравится:
Не нравится:
|
|||
24.09.2017, 21:28 |
|
JSONB и ASCii-символы <32
|
|||
---|---|---|---|
#18+
но anyway, с COPY FROM то что делать? ... |
|||
:
Нравится:
Не нравится:
|
|||
24.09.2017, 21:28 |
|
JSONB и ASCii-символы <32
|
|||
---|---|---|---|
#18+
tip78 пропустит ли его ПХП pg_query_params() ? pg_query_params гарантирует корректную передачу параметра в запрос. То что параметр вы будете использовать как несовместимый с каким-то типом данных - это ваши проблемы. Например, строку попробуете запихать в число, или как сейчас некорректно сформированный json. А теперь ещё раз и сначала: - какой тип данных в mysql - как формируете copy - какая структура таблицы в pg - валидный ли json получается в copy (хинт: невалидный. Для строкового значения "22\1" валидным json представлением будет "22\\1") ... |
|||
:
Нравится:
Не нравится:
|
|||
24.09.2017, 22:48 |
|
|
start [/forum/topic.php?fid=53&fpage=66&tid=1996215]: |
0ms |
get settings: |
8ms |
get forum list: |
13ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
32ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
46ms |
get tp. blocked users: |
2ms |
others: | 281ms |
total: | 399ms |
0 / 0 |