Как зайти в Даркнет?!
25th January, 01:11
5
0
Как в tkinter из поля ввода Entry получить значение в одну переменную и обновить строку кнопкой, затем получить ещё одно введённое значение и затем сложить их. Ниже пример кода
21st July, 19:00
893
0
Программа, которая создает фейковые сервера в поиске игровых серверов CS 1.6 Steam
21st March, 17:43
948
0
Очень долго работает Update запрос Oracle
27th January, 09:58
912
0
не могу запустить сервер на tomcat HTTP Status 404 – Not Found
21st January, 18:02
905
0
Где можно найти фрилансера для выполнения поступающих задач, на постоянной основе?
2nd December, 09:48
938
0
Разработка мобильной кроссплатформенной военной игры
16th July, 17:57
1724
0
период по дням
25th October, 10:44
3955
0
Пишу скрипты для BAS только на запросах
16th September, 02:42
3720
0
Некорректный скрипт для закрытия блока
14th April, 18:33
4613
0
прокидывать exception в блоках try-catch JAVA
11th March, 21:11
4380
0
Помогите пожалуйста решить задачи
24th November, 23:53
6084
0
Не понимаю почему не открывается детальное описание продукта
11th November, 11:51
4350
0
Нужно решить задачу по программированию на массивы
27th October, 18:01
4395
0
Метода Крамера С++
23rd October, 11:55
4309
0
помогите решить задачу на C++
22nd October, 17:31
4002
0
Помогите решить задачу на python с codeforces
22nd October, 11:11
4492
0
Python с нуля: полное руководство для начинающих
18th June, 13:58
2599
0
Переход на платформы
Я играю с идеей поэтапного ввода ORM в приложение, которое я поддерживаю. Приложение не очень структурировано без модульных тестов. Поэтому любое изменение будет рискованным. Я, очевидно, обеспокоен тем, что у меня есть достаточно веская причина, чтобы измениться. Идея заключается в том, что будет меньше кода котельной плиты для доступа к данным и там для большей производительности.
Это звучит правдиво с вашим опытом?
Это возможно или даже хорошая идея, чтобы фазировать его?
Каковы недостатки ORM?
Я бы настоятельно рекомендовал получить копию книги Майкла пера, эффективно работающую с устаревшим кодом (под "Legacy Code" перьями подразумевается любая система, которая недостаточно охвачена модульными тестами). Он полон хороших идей, которые должны помочь вам с рефакторингом и поэтапным внедрением лучших практик.
Конечно, вы можете поэтапно ввести ORM, первоначально используя его для доступа к некоторому подмножеству вашей модели домена. И да, я обнаружил, что использование ORM ускоряет время разработки - это одно из ключевых преимуществ, и я, конечно, не скучаю по тем дням, когда я использовал кропотливо ручные слои доступа к данным.
Недостатки ORM-из опыта, неизбежно есть немного кривой обучения, чтобы справиться с концепциями, конфигурацией и особенностями выбранного решения ORM.
Изменить: исправлено имя автора
Книга "Robert C Martin", которая на самом деле была написана Майклом перышком ("дядя Боб" - это, кажется, фирменный знак в наши дни!) является обязательным.
Это почти невозможно-не говоря уже о безумно трудоемком - поставить модульные тесты в приложение, не разработанное с ними. Код просто не будет поддаваться.
Но это не проблема. Рефакторинг - это изменение дизайна без изменения функции(я надеюсь, что я не слишком сильно испортил смысл), поэтому вы можете работать намного шире.
Начните с больших кусков. Настройте повторяемое выполнение и зафиксируйте то, что происходит в качестве ожидаемого результата для последующих исполнений. Теперь у вас есть ваше приложение, или часть его, по крайней мере, под тестом. Не очень хороший или всеобъемлющий тест, конечно, но это начало, и все может только улучшиться оттуда.
Теперь вы можете начать рефакторинг. Вы хотите начать извлечение кода доступа к данным, чтобы его можно было заменить на функциональность ORM, не нарушая слишком много. Тест часто: с устаревшими приложениями вы будете удивлены, что ломается; сплоченность и сцепление редко то, что они могли бы быть.
Я бы также рассмотрел рефакторинг Мартина Фаулера, который, очевидно, является окончательной работой над процессом.
Я работаю над большим приложением ASP.net, где мы недавно начали использовать NHibernate. Мы переместили большое количество объектов домена, которые мы сохраняли вручную, на сервер Sql вместо NHibernate. Это немного упростило ситуацию и значительно упростило ее изменение с течением времени. Мы рады, что внесли изменения и используем NHibernate там, где это уместно для многих наших новых работ.
Правило рефакторинга таково. Выполняйте модульные тесты.
Поэтому, возможно, сначала вы должны разместить некоторые unittests, по крайней мере, для основных/основных вещей.
ORM должен быть разработан для уменьшения шаблонного кода. Время / неприятности против ROI, чтобы быть предприимчивым, зависит от вас, чтобы оценить :)
Если ваш код уже не имеет архитектуры, позволяющей использовать "hot swapping" вашего бэкэнда уровня модели, изменение его каким-либо образом всегда будет чрезвычайно рискованным.
Попытка построить сеть безопасности модульных тестов на плохо спроектированном коде не гарантирует успеха, только заставляет вас чувствовать себя в безопасности при его изменении.
Так что, если у вас нет веских оснований для принятия на себя рисков, связанных с этим, вероятно, лучше оставить достаточно хорошо в покое.