Перейти к публикации

TC10 Работа из толстого клиента с СУБД напрямую?


Рекомендованные сообщения

Суть задачи в следующем, есть 2-ух звенный ТС10, хочется в нем сделать журнал регистрации документов (№п.п., Дата, Наименование, Вид документа, Автор...). Причем работать с журналом будут несколько десятков человек. То бишь самый простой вариант с каким-нибудь набором данных из электронной таблицы не очень подходит, так как велик человеческий фактор и вероятность ошибки. По-этому возникла идея сделать плагин приложение для TC в котором была бы табличка с журналом и поля для заполнения. Сама таблица физически будет хранится в той же БД что и таблицы данных TC. 

Отсюда и вопрос: работал ли кто-нибудь с СУБД напрямую из толстого клиента? Так как один вариант это прописать данные для соединения с СУБД где-нибудь в плагине или в преференциях, и порождать в плагине новое соединение с СУБД. Но, с другой стороны ведь есть же уже соединение по которым обменивается запросами сам ТС, почему бы не использовать его. Но как?

 

Я понимаю что можно декомпилировать модули ТС и разобраться как он там с базой общается, но этот путь займёт неопределенное количество времени, и возможно кем-то из форумчан уже был пройден, и они согласятся поделится опытом.

 

Может быть кто-то имеет предложить другой вариант решения задачи?

Ссылка на сообщение
Поделиться на других сайтах


Так как один вариант это прописать данные для соединения с СУБД где-нибудь в плагине или в преференциях, и порождать в плагине новое соединение с СУБД

Был такой опыт. 

Я понимаю что можно декомпилировать модули ТС и разобраться как он там с базой общается

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

Хотелось  бы ограничиться Java. То бишь, проще просто создавать в приложении отдельное соединение с СУБД и работать через него?

Изменено пользователем asterixik
Ссылка на сообщение
Поделиться на других сайтах

не знаю как проще. В моем случае коллега делал soap-сервис который крутился на сервере и работал с СУБД, я уже обращался к этому сервису из плагина ТС.

Ссылка на сообщение
Поделиться на других сайтах
а чо на "айтемах" не сделать?

 

...и генератором отчетов вытаскивать нужные формы для печати.

Реализацию (в силу слабого знания матчасти репортгенератора) преставляю только теоретически, но, по крайней мере, выглядит логичнее плясок с бубном и кривым OCI.dll. 

Ссылка на сообщение
Поделиться на других сайтах

а чо на "айтемах" не сделать?

Такой вариант тоже рассматривался, но как-то быстро его отбросили, хотя... Сейчас ещё раз рассмотрим с коллегами.

 

А Вы как видите такую реализацию, в общих чертах?

...и генератором отчетов вытаскивать нужные формы для печати.

Реализацию (в силу слабого знания матчасти репортгенератора) преставляю только теоретически, но, по крайней мере, выглядит логичнее плясок с бубном и кривым OCI.dll. 

Печать не нужна.

Нужен просмотр на экране, создание записи без последующей возможности редактирования (только администратором) с одновременной генерацией сложного номера по определенным правилам

Ссылка на сообщение
Поделиться на других сайтах

Можно сделать pom объект описывающий одну запись.
Сделать айтем со свойством: массив этих пом объектов.
Или вместо айтема тоже pom, но еще с логическим свойством для блокировки (помему pom нельзя блокировать).

 

Ну и все, остальное все в плагине. Блокируем, генерим номер, записываем, разблокируем. 

 

Ссылка на сообщение
Поделиться на других сайтах

Документ - "айтем" + нужные вам атрибуты + код который будет генерировать сложный номер.

Ссылка на сообщение
Поделиться на других сайтах

koner, Krusty спасибо

 

У меня такие же мысли намыслились как у Krusty по поводу подхода к реализации были, так что буду реализовывать наверное через item-ы  :smile:

Ссылка на сообщение
Поделиться на других сайтах

Отсюда и вопрос: работал ли кто-нибудь с СУБД напрямую из толстого клиента?

работали но на чтение.

если коротко - это неверный подход и нерекомендуемый - именно писать напрямую в БД.это противоречит логике работы с TC.Хотя технически не запрещено.

Для решения множества задач есть разные интерфейсы - ITK, JAVA API, SOA а так же надо учитывать бизнес логику тимцентра и использовать возможности его модели данных. Она гибкая,объектно-ориентированная. Используйте объекты модели данных,создавайте свои классы и атрибуты и уже из них стройте свою конкретную модель для конкретной задачи, легче будет получать через API потом данные

писать напрямую в БД - это даже чревато,вам необходимо хорошо знать сруктуру таблиц БД, как реализована объекто-ориентированная модель данных тимцентра на уровне таблиц оракла,саму модель данных,бизнес логику работы,в итоге это куча времени и гемора на изучение у вас может уйти.

Когда мы осваивали чтение напрямую из БД для генерации больших отчетов через бесплатный движок под eclipse, то тоже пришлось попариться немного,но результат того стоит.

Изменено пользователем lexx174
Ссылка на сообщение
Поделиться на других сайтах
это неверный подход и нерекомендуемый

Я так понимаю речь не о данных/таблицах тимцентра, а о своих отдельных таблицах.
В противном случае полностью с вами согласен. 
Ссылка на сообщение
Поделиться на других сайтах

Ещё раз посоветовался с коллегами, решили попробовать реализовать стандартными средствами, то бишь через кучу naming rules с счетчиками (коих будет около 100, так как журналов много), а сами "журналы" получать с помощью поиска. Ну и скорее всего придется сделать приложение которое будет отображать результаты поиска в виде приближенном к журналу из ГОСТа, так как пользователи которым нужен "журнальный" вид не очень дружат с ТС, им надо чтобы по нажатию одной кнопки был "журнал".

 

Да, речь не шла о редактировании таблиц используемых ТС, речь шла о размещении собственных таблиц в БД ТС и редактировании уже их.

Ссылка на сообщение
Поделиться на других сайтах

Ещё раз посоветовался с коллегами, решили попробовать реализовать стандартными средствами, то бишь через кучу naming rules с счетчиками (коих будет около 100, так как журналов много), а сами "журналы" получать с помощью поиска. Ну и скорее всего придется сделать приложение которое будет отображать результаты поиска в виде приближенном к журналу из ГОСТа, так как пользователи которым нужен "журнальный" вид не очень дружат с ТС, им надо чтобы по нажатию одной кнопки был "журнал".

 

Да, речь не шла о редактировании таблиц используемых ТС, речь шла о размещении собственных таблиц в БД ТС и редактировании уже их.

я бы сразу советовал вам кодить, нейминг рулы..... ну может их вам не хватить, хотя если у вас 11 то там появились..... smart number, вроде так

.... пишите сразу свой прекрасный кодификатор.

О! У сименса попросите - модель данных Архив, может там есть все то, что нужно вам.

Ссылка на сообщение
Поделиться на других сайтах

Отсюда и вопрос: работал ли кто-нибудь с СУБД напрямую из толстого клиента? Так как один вариант это прописать данные для соединения с СУБД где-нибудь в плагине или в преференциях, и порождать в плагине новое соединение с СУБД. Но, с другой стороны ведь есть же уже соединение по которым обменивается запросами сам ТС, почему бы не использовать его. Но как?

 

У нас есть такое, и это, вероятно, самый простой для реализации вариант. Читаете конекшн стринг откуда-нибудь и работаете с sql напрямую. Сам толстый клиент напрямую к БД не обращается, только через tcserver.

С другой стороны, это накладывает свои ограничения: при 4-звенке прямого доступа к БД может и не быть. Ну и выглядит такой подход, скажем так, непрофессионально. Поэтому есть у меня желание перенести работу с SQL на серверную часть. Может у кого-то есть пример как сделать свой сервис в тимцентре, который вызывает pl/sql процедуру? 

Ссылка на сообщение
Поделиться на других сайтах

Присоединяйтесь к обсуждению

Вы можете опубликовать сообщение сейчас, а зарегистрироваться позже. Если у вас есть аккаунт, войдите в него для написания от своего имени.
Примечание: вашему сообщению потребуется утверждение модератора, прежде чем оно станет доступным.

Гость
Ответить в тему...

×   Вставлено в виде отформатированного текста.   Вставить в виде обычного текста

  Разрешено не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отобразить как ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставить изображения напрямую. Загрузите или вставьте изображения по ссылке.

  • Сейчас на странице   0 пользователей

    Нет пользователей, просматривающих эту страницу.




  • Сообщения

    • gudstartup
      да у вас очень древний чемоданчик думаю из 90-х ну его ломать не жалко но если все уже заменили с рабочего то тут даже не знаю что и посоветовать....
    • stanislavz
      Спасибо за ответ. Так этот и был заказан на запас. В машине живой рабочий. Носителя нету, все в памяти hm628128-10 + ээпром.
    • gudstartup
      @stanislavz вы уж сразу еще один контроллер закажите а потом этот доламывайте. а со старым комбинировать не пробовали? у вас там диск или ssd в качестве носителя? может hdd загибается а вы сразу в мат.плату полезли. дисковые операции тоже ввод вывод тормозят...
    • maxx2000
      Подушную малость. Чё там. Уже в упор научились резьбу резать без выходной канавки?
    • ispite
      Здравствуйте, не могу построить стандартную сетку, что не позволяет дальше провести расчёт. Получается сделать сетку "на основе кривизны", но солид отказывается считать, после нажатия кнопки "запустить исследование" происходит сбой. https://disk.yandex.ru/d/D8wvRbYMW1lWjQ
    • ddm
      изготовить по чертежу с последующим покрытием,цинкование ,по 1000 шт каждой позиции ,предложение отправить на почту qwer463@yandex.ru
    • sklide008
      И еще можно ли задать горчие клавиши на кнопки открыть, скрыть и тд?
    • sklide008
      Подскажите, пожалуйста, в инвенторе есть такой пункт упорядочи по алфавиту дерево. Здесь найти такого не могу, пытался treesorter ставить но он добавляет просто в папку а не сортирует в дереве. Есть ли такой макрос чтобы все детали в дереве по порядку и алфавиту шли?
    • stanislavz
      Есть станок с данным контроллером. Все работает. Недавно была проблема с передачей данных - установил запасной контроллер. А запасной контроллер сказал нет работе. Проблема была в программе компьютера для передачи данных. Грустно, досадно, контроллер был куплен как рабочий. Как бы и не горит, но необходимо поправить. Плата управления с процессором mc68020, память hm628128-10. Память буферным питанием от 3 батареек + 0,5 Фарада на плате как буфер для замены батареек на 1 сутки. Лежало долго, без батареек. Симптомы: После первого включения, в памяти были и программы и параметры (0 странность). Честно, удивило. Но - система жутко тормозит, отклик на нажатие кнопки 3-5 секунд. В таком режиме сумел закачать машинные параметры под свой станок. Но это заняло час.. 4 строки и ждет секунд 10 итд. Есть видео. Перекинул с рабочего контроллера, БП, плату плц, ээпром плц - все то же. Проверил осциллографом кварцы живые , частота есть, амплитуда хорошая. 1 странность - после манипуляций по замене батарейки, старые записи из памяти исчезли. Ничего не коротнул. Возможно 0,5 Ф был не заряжен. Там тоже необходимы сутки для зарядки. Но как оно было запечатоно до этого - мистика. 2 странность. Если плата лежит ночь без питания, только с буфером - потом 2-3 минуты работает хорошо. 3 аналогично работает 2-3 минуты если питание отключить и очистить питание памяти (выпаял 0,5 Ф буфер с платы) Проверка памяти на старте есть. Проходит хорошо. На зависает, на холодную пайку не похоже. Шевелил / двигал все. Да и не виснет, именно тормозит. При том если оставить на час - тоже все стабильно плохо. Если набрать быстро 5 символей- экран сразу пуст, но после задержки символы будут на экране. Заказал второй процессор и память. 10 штук. Подавал прямо 5 вольт на память - все так же. Токи потребления между плохой и хорошей платой смогу проверит.    
    • brigval
×
×
  • Создать...