Форум программистов, компьютерный форум, киберфорум
Java: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
0 / 0 / 1
Регистрация: 05.02.2015
Сообщений: 7

Блокировка записи в базе данных

01.03.2017, 10:49. Показов 1956. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, подскажите пожалуйста, как можно проверить свободна запись или заблокирована??? Сервер FireBird - JDBC
При редактировании записи, она должна блокироваться, это у меня происходит великолепно! Но другой пользователь в таком случае просто зависает на попытке редактировать эту же запись. А мне нужно вместо ожидания, выдавать пользователю соответствующую информацию - "запись редактируется другими, приходите завтра".
Блокировку произвожу скриптом из транзакции:

Java
1
2
3
    connectionUpdate.setTransactionIsolation(Connection.TRANSACTION_READ_COMMITTED); 
    stmtG = connectionUpdate.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
    rs = stmtG.executeQuery("select .. from... where... for update With Lock");
А дальше? Если второй клиенты пытается редактировать эту запись, то конечно подвисает в ожидании... То есть нужно перед редактированием проверять, свободна ли запись, а как проверить??? Update set x=x where id = 3 или select .. from... where id = 3 for update With Lock. Так же подвисают.
В iSQL это решается настройкой транзакции nowait, в оракле nowait можно использовать прямо в запросе, а как здесь быть?
Перерыл весь интернет, не могу найти как мне в jaybird настроить транзакцию, что бы было nowait.
Заранее благодарен.

Добавлено через 5 часов 27 минут
Нашел! Заменил Connection, на FBConnection, воспользовался setTransactionParameters для установки параметров транзакции, НОО!!!
Оказывается сервер баз данных при запросе nowait на блокированную запись выдает ошибку, при этом в ResultSet, что то попадает, а что именно можно определить только next(), last() и т.д.
В результате, если все нормально, то нормально, а если сервер выдал ошибку, то есть запись заблокирована, то next(), last() зависают и никакие try не помогают... Что делать? Кто знает, подскажите пожалуйста, как отличить, что в ResultSet?

Добавлено через 2 часа 42 минуты
что-то совсем не так, похоже я что-то делаю не правильно, rs.next() отпускает сразу же как другой пользователь закрывает свою транзакцию... Вот код:
Java
1
2
3
4
5
6
7
8
9
connectionUpdate = (FBConnection)Dst.getDBConnect();              
        connectionUpdate.setAutoCommit(false); 
        int [] iix = {TransactionParameterBuffer.NOWAIT,TransactionParameterBuffer.WRITE};
        connectionUpdate.setTransactionParameters(Connection.TRANSACTION_READ_COMMITTED,iix);              
        try{                                                             
            PrstUpd = connectionUpdate.prepareStatement("select id from tb where id = x for update With Lock ");
            boolean bl =  PrstUpd.execute();
            ResultSet rs = PrstUpd.getResultSet();                                  
            while(rs.next()) {     В этом месте зависает, если запись уже блокирована...
А по моей логике, rs.next() должен не зависать в ожидании, а возвращать false, если запись заблокирована или саму запись, если она свободна.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.03.2017, 10:49
Ответы с готовыми решениями:

Блокировка записи в базе данных на сервере
Здравствуйте. Написал простую сетевую программу. На сервере база данных Access. Программа запускается одновременно на 2-х компьютерах и...

Записи в базе данных, как встать на последнюю запись в базе после открытия?
Есть два вопроса. Во-первых - как встать на последнюю запись в базе после открытия? И во-вторых - есть база в которую каждые 10...

Не удаляет записи в базе данных
db.exec("delete from where ='"+ blog +"' "); db.exec("delete from where ='" + blog + "' "); Не срабатывает, и ничего не возвращает...

2
Эксперт Java
 Аватар для turbanoff
4094 / 3828 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 12
01.03.2017, 22:31
Так зачем вы вызываете execute? Вызывайте executeQuery
0
0 / 0 / 1
Регистрация: 05.02.2015
Сообщений: 7
02.03.2017, 01:59  [ТС]
Спасибо всем! Я пробовал по разному, и executeQuery() так же не работает...
Причина оказалась в другом, может я конечно чего-то не учитываю, или слишком глупый, НО!
Java
1
2
3
int [] 
iix = {TransactionParameterBuffer.NOWAIT,TransactionParameterBuffer.WRITE};
connectionUpdate.setTransactionParameters(Connection.TRANSACTION_READ_COMMITTED,iix);
Вот здесь я заполняю параметры через массив, и такой конструктор есть, параметры тасовал по разному, ничего не получалось, а потом взял и поступил иначе:
Java
1
2
3
4
5
6
7
8
9
10
TransactionParameterBuffer tpb = null;
        try {
            tpb = connectionUpdate.createTransactionParameterBuffer();
            tpb.addArgument(TransactionParameterBuffer.READ_COMMITTED);
            tpb.addArgument(TransactionParameterBuffer.WRITE);
            tpb.addArgument(TransactionParameterBuffer.REC_VERSION);
            tpb.addArgument(TransactionParameterBuffer.NOWAIT); 
        } catch (SQLException ex) { Logger.getLogger(mdlxx.class.getName()).log(Level.SEVERE, null, ex); }               
        try { connectionUpdate.setTransactionParameters(tpb); 
              ....
Удивительно, но заработало только так...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.03.2017, 01:59
Помогаю со студенческими работами здесь

Не сохраняются записи в Базе Данных
Здраствуйте! Меня оооочень раздражает, мягко говоря, одна проблема при работе с базами данных в Delphi 7. У меня не сохраняются записи!...

Удаленный доступ к записи в базе данных
Уважаемые коллеги! Сильно не пинайте, мои знания в базах данных можно назвать поверхностными. Но возникла задачка, которую хочу решить....

Объединить все записи в базе данных
Всем доброго времени суток. Есть база,с разделением по категориям.То есть выбираю 1 категорию-в ДБГриде отображаются данные из этой...

Не обновляется записи в Базе данных Mysql
есть php код для обновления статьи include "start.php"; if (!empty($_POST)) { $torrent = htmlspecialchars("torrents/".($_FILES));...

Обновление записи в базе данных через форму
Здравствуйте! Через id вытаскиваю запись из БД и засовываю её по разным <input> в форме. Кнопка формы передает данные из...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru