Для справки: репродукция ответа Джейка Уортона :
Вы обновили OkHttp до версии 3.13 или новее и согласно примечаниям к выпуску , OkHttp теперь требует, чтобы вы включили Java 8 в ваших сборках для работы. Вы можете узнать больше о том, как включить это, на https://developer.android.com/studio/write/java8-support .
Вам нужно добавить что-то вроде
blockquote>android { compileOptions { targetCompatibility = "8" sourceCompatibility = "8" } }
Я не рассматриваю использование двойной, чтобы быть взломом. Для избавлений от привязки/ввода дважды я сделал бы что-то как:
merge into data
using (
select
'someid' id,
'testKey' key,
'someValue' value
from
dual
) val on (
data.id=val.id
and data.key=val.key
)
when matched then
update set data.value = val.value
when not matched then
insert (id, key, value) values (val.id, val.key, val.value);
Я предпочитаю пробовать обновление перед вставкой для сохранения необходимости проверить на исключение.
update data set ...=... where ...=...;
if sql%notfound then
insert into data (...) values (...);
end if;
Даже сейчас у нас есть оператор слияния, я все еще склонен делать, одна строка обновляет этот путь - просто кажется больше более естественным синтаксисом. Конечно, слияние действительно добивается признания при контакте с большими наборами данных.
Я скрыл бы СЛИЯНИЕ в МН / SQL API и затем назвал бы это через JDBC:
data_pkg.merge_data ('someid', 'testKey', 'someValue');
Как альтернатива СЛИЯНИЮ, API мог сделать:
begin
insert into data (...) values (...);
exception
when dup_val_on_index then
update data
set ...
where ...;
end;