json_encode () преобразует большое число в научную нотацию [duplicate]

Ограничения оператора in () являются корнем всего зла.

Он работает для тривиальных случаев, и вы можете расширить его с помощью «автоматической генерации подготовленного заявления», однако он всегда имеет свои пределов.

  • , если вы создаете оператор с переменным числом параметров, который будет обрабатывать служебные данные SQL для каждого вызова
  • на многих платформах, количество параметров of () ограничены
  • на всех платформах, общий размер текста SQL ограничен, что делает невозможным отправку 2000 заполнителей для параметров in
  • , отправляющих переменные связывания 1000- 10k невозможно, так как драйвер JDBC имеет свои ограничения

Подход in () может быть достаточно хорош для некоторых случаев, но не для защиты от ракеты:)

Ракетно-защитное решение состоит в том, чтобы передать произвольное количество параметров в отдельный вызов (например, путем передачи клока параметров), а затем иметь представление (или любой другой способ) для представления их в SQL и использовать в вашем месте критерии.

Вариант грубой силы здесь http://tkyte.blogspot.hu/2006/06/varying-in-lists.html

Однако, если вы можете использовать PL / SQL, этот беспорядок может стать довольно опрятным.

function getCustomers(in_customerIdList clob) return sys_refcursor is 
begin
    aux_in_list.parse(in_customerIdList);
    open res for
        select * 
        from   customer c,
               in_list v
        where  c.customer_id=v.token;
    return res;
end;

Затем вы можете передать произвольное количество идентификаторов клиентов, разделенных запятыми, в параметре и:

  • не будет получать задержку синтаксического анализа, так как SQL для select является стабильным
  • Отсутствие сложностей с конвейерными функциями - это всего лишь один запрос
  • , когда SQL использует простое соединение, вместо этого из оператора IN, который довольно быстр
  • в конце концов, это хорошее эмпирическое правило not , попадающее в базу данных с любым простым выбором или DML, поскольку это Oracle, который предлагает lightyears больше, чем MySQL или аналогичные простые двигатели баз данных. PL / SQL позволяет скрыть модель хранилища от вашей модели домена приложения эффективным способом.

Трюк здесь:

  • нам нужен звонок который принимает длинную строку и хранит где-нибудь, где сеанс db может получить к ней доступ (например, простая переменная пакета или dbms_session.set_context)
  • , тогда нам нужно представление, которое может анализировать это на строки
  • , а затем у вас есть представление, которое содержит идентификаторы, которые вы запрашиваете, поэтому все, что вам нужно, - это простое соединение с запрошенной таблицей.

Вид выглядит так:

create or replace view in_list
as
select
    trim( substr (txt,
          instr (txt, ',', 1, level  ) + 1,
          instr (txt, ',', 1, level+1)
             - instr (txt, ',', 1, level) -1 ) ) as token
    from (select ','||aux_in_list.getpayload||',' txt from dual)
connect by level <= length(aux_in_list.getpayload)-length(replace(aux_in_list.getpayload,',',''))+1

, где aux_in_list.getpayload ссылается на исходную строку ввода.


Возможным подходом было бы передать массивы pl / sql (поддерживаемые только Oracle), однако вы можете ' t использовать их в чистом SQL, поэтому шаг преобразования всегда необходим. Преобразование не может быть выполнено в SQL, поэтому, в конце концов, самым эффективным решением является передача clob со всеми параметрами в строке и преобразование его в представление.

6
задан Josua Marcel Chrisano 2 June 2015 в 08:02
поделиться

2 ответа

Пока ваша PHP-версия может обрабатывать большие целые числа, то есть если вы используете 64-разрядную версию PHP (что-то , отличное от Windows ), у json_decode нет проблем с it:

$json  = '{"foo":9223372036854775807}';
$obj   = json_decode($json);
$json2 = json_encode($obj);

var_dump(PHP_INT_MAX, $obj, $json2);

int(9223372036854775807)
object(stdClass)#1 (1) {
  ["foo"]=>
  int(9223372036854775807)
}
string(27) "{"foo":9223372036854775807}"

Если целые значения, которые вам нужно обрабатывать, превышают PHP PHP_INT_MAX, вы просто не можете представлять их в родных типах PHP. Так что у вас нет головоломки; вы не можете использовать собственные типы для отслеживания правильного типа, и вы не можете подставлять другие типы (например, строки вместо целых чисел), потому что это неоднозначно, когда кодирование возвращается к JSON.

В этом случае вам придется изобретать собственный механизм отслеживания правильных типов для каждого свойства и обрабатывать такую ​​сериализацию с помощью пользовательского кодировщика / декодера. Например, вам нужно написать собственный JSON-декодер, который может декодироваться в пользовательский класс, например new JsonInteger('9223372036854775808'), и ваш пользовательский кодер распознает этот тип и закодирует его на значение JSON 9223372036854775808.

В PHP нет такой вещи.

3
ответ дан deceze 15 August 2018 в 20:13
поделиться
0
ответ дан Oli Griffiths 29 October 2018 в 03:25
поделиться
Другие вопросы по тегам:

Похожие вопросы: