Программирование


Ответить в тред Ответить в тред

Check this out!
<<
Назад | Вниз | Каталог | Обновить тред | Автообновление
570 46 225

Кластеризованный уникальный баз данных тред /sql/ /sql/ Аноним 25/05/19 Суб 21:52:18 14064551
Снимок.PNG (39Кб, 801x251)
801x251
Добро пожаловать в свитерный тред.

Анализируем планы запросов,
Поясняем, какой из гигантов СУБД лучше: MySql или SqLite.

Ну а теперь серьезно:
Базы данных: реляционные и объектные/документные
Хранилища данных и BI
ETL
Хадуп и бигдата

В этои IT ИТТ тредю
поясняем за специальности, в которые можно вкатиться в сфере СУБД
обсуждаем скиллы, которые нужно подтягивать новичкам
* составляем базу необходимых знаний на гитхабе





Аноним 25/05/19 Суб 23:41:15 14064812
Screenshot76.png (112Кб, 1289x809)
1289x809
оцените курсовую ебана
Аноним 26/05/19 Вск 00:04:17 14064953
>>1406481
Сущности называются единственным числом.
Тем более, что множественное число ты все равно не умеешь образовывать.
Аноним 26/05/19 Вск 05:42:21 14065414
>>1406481
Ты долго ебашил спайсы чтобы додуматься хранить билеты и поезд не в таблице билетов, а в таблице пассажиров?
Аноним 26/05/19 Вск 06:01:46 14065465
>>1406481
>>1406541
Где таблица с рейсами? Иди дорабатывай.
Ну либо своруй структуру бд самолётов с sql-ex
Аноним 26/05/19 Вск 08:59:21 14065656
>>1406455 (OP)
> поясняем за специальности, в которые можно вкатиться в сфере СУБД
Кто начнёт?
Аноним 26/05/19 Вск 11:19:37 14065957
>>1406565
Пердеды с sql.ru Только они здесь не сидят, наверное
Аноним 26/05/19 Вск 12:27:36 14066308
>>1406455 (OP)
> скиллы, которые нужно подтягивать новичкам
sql, основы реляционных бд, python(опционально)
>поясняем за специальности, в которые можно вкатиться в сфере СУБД
на hh можно посмотреть
(и там же знания необходимые для нюфагов)
Аноним 26/05/19 Вск 13:29:18 14066589
>>1406630
нахуя питон? R не интегрируется в эти ваши опенсорсные субды?
Аноним 26/05/19 Вск 14:15:28 140670310
>>1406658
не видел разрабов на R
да и кому он нужен если есть змей
Аноним 26/05/19 Вск 14:49:30 140672111
>>1406703
тошо он изначально заточен под анализ данных, а путон вкатился в эту нишу не пойми каким боком
Аноним 26/05/19 Вск 17:26:04 140686712
>>1406546
>>1406541
Это вы еще ему не сказали, что он навернет говна, когда пилот с одного самолета на другой пересядет.
Аноним 26/05/19 Вск 18:03:06 140690113
>>1406595
Я тоже читаю ин-фу от наших предков. Нам всем базачём нужно составить вопросы и создать там тред.
Аноним 26/05/19 Вск 18:05:38 140690514
Я еще помню тут совсем давно один уважаемый анон пояснял за дата инженера. Я нашёл немного информации про хадуп, если ты тут, дай пожалуйста ссылки на упражнения.
Аноним 26/05/19 Вск 23:46:25 140710215
>>1406721
тебе не нужно их анализировать тебе нужно их обрабатывать и складывать
(маня ты не дата саентист! проснись!)
Аноним 27/05/19 Пнд 09:06:31 140718116
Аноним 27/05/19 Пнд 10:47:46 140722517
>>1406455 (OP)
Что там по книгам/ресурсам по которым можно освоить работу с каким-нибудь постгре и научиться sql, чтобы на собеседование стыдно не было?
Аноним 27/05/19 Пнд 11:06:58 140723518
Аноним 27/05/19 Пнд 13:33:48 140730919
>>1407181
Ты не в тот тред пришёл, не позорься.
мимо
Аноним 27/05/19 Пнд 13:34:56 140731020
Аноны, есть какой-нибудь ресурс, типо sql-exe, только по процедурным расширениям? Можно на английском.
Аноним 27/05/19 Пнд 16:06:20 140738921
Аноним 27/05/19 Пнд 21:00:50 140760322
Анон, посоветуй какую нибудь годную книгу про технические аспекты RDBMS. Ну типа как реализован конкурентный доступ, как отрабатывают локи, когда открываются транзакции и как они менеджатся
Аноним 27/05/19 Пнд 21:16:59 140761123
>>1407603
А какая СУБД интересует?
Аноним 27/05/19 Пнд 21:34:50 140761524
Аноним 27/05/19 Пнд 22:35:48 140764625
>>1407603
У Оракла в документации до хуя есть.
Concepts, например, если я не путаю.
У Постгре тоже в документацию втыкай.
Аноним 28/05/19 Втр 10:00:18 140780326
Аноним 28/05/19 Втр 11:37:10 140783627
Ребят, помогите, через 2 дня собес, а мне нужно знать базовые знания запросов sql, а я кроме как вставить что то из таблицы и вытащить ничего не знаю, что за эти 2 дня можно прочитать и где?
Аноним 28/05/19 Втр 11:43:39 140783928
>>1407836
это и есть базовые знания
Аноним 28/05/19 Втр 11:44:39 140784029
>>1407839
окей, а дальше как это развить?
Аноним 28/05/19 Втр 11:59:09 140784930
>>1407840
ну джойны почитай
дальше индексы
возможно cte, оконные функции
опционально процедуры/функции/вью
Аноним 28/05/19 Втр 12:01:28 140785031
>>1407836
>базовые знания запросов sql
CREATE, REMOVE, UPDATE, DELETE (CRUD), что еще нужно для счастья?
Аноним 28/05/19 Втр 12:02:14 140785132
Аноним 28/05/19 Втр 14:15:47 140792933
>>1407850
Для начала нужно все-таки разобраться, что означает буква R
А то ты и так на умного не похож, а своими высерами окончательно всех убеждаешь в том, что ты даун
Аноним 28/05/19 Втр 14:33:58 140794534
Аноним 28/05/19 Втр 15:44:15 140799335
Аноним 28/05/19 Втр 16:05:29 140802336
Аноним 28/05/19 Втр 16:10:08 140802637
Аноним 28/05/19 Втр 17:09:11 140807438
Аноним 28/05/19 Втр 17:22:41 140807939
Аноним 28/05/19 Втр 18:30:42 140810440
А где, ну или в какой субд, лучше всего практиковать запросы?
Аноним 28/05/19 Втр 19:16:50 140813841
Аноним 28/05/19 Втр 19:30:16 140814442
Аноним 29/05/19 Срд 00:54:07 140838243
>>1408138
Бля, я думал, тут умные-остроумные собрались.
А тут ебанат в словарь полез.

Бля, я думал, программист понимает, что можно что-то новое создать.
А тут ебанат только готовыми шаблонами из словаря готов пользоваться.

Пиздец, вообще. Закрывайте на хуй программач.
Аноним 29/05/19 Срд 00:56:02 140838744
>>1408382
>программач
Какой нахуй программач, юродивый, это же /зк
Или в лучшем случае /prrrrrrrrrrrrrrrrr
Живи с этим.
Аноним 29/05/19 Срд 08:20:25 140849945
>>1408387
>Какой нахуй программач, юродивый, это же /зк
он дома расскажет друзьям и невесте как он подстрелил двух /зк ?
Аноним 30/05/19 Чтв 18:15:48 140932646
Проебал перекот.

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

Ожидаемый опыт:
- Знания Oracle SQL, PL/SQL
- Понимание принципов разработки OLTP систем
- Умение разобраться в чужом коде
- Умение отлаживать код
- Умение работать с документами

>Знания Oracle SQL, PL/SQL
Про это расскажу думаю. Спросят поди про синтаксис, основные конструкции. Индексы, партиции, план такое говно.

>Понимание принципов разработки OLTP систем
Что тут хотят от меня? Ну индексы не вешать чтобы вставка была быстрее, ну sql аналитику не крутить на oltp базах, что еще тут рассказать?
Аноним 30/05/19 Чтв 19:28:07 140939747
>>1409326
>Умение разобраться в чужом коде
Пидарасы, сэр.
Аноним 31/05/19 Птн 06:54:56 140967448
>>1409326
Ну вот про партиции и расскажи, как бы ты транзакционную табличку партиционировал, например, чтобы база через пару лет не подохла от миллиардов записей. Олсо, можно спиздануть, что - нахуй форейн кеи, потому что они только тормозят производительность, но если ребята с таким не сталкивались, то могут и не оценить.
Аноним 31/05/19 Птн 20:36:11 141006149
image.png (1553Кб, 959x960)
959x960
Аноны, помогите. Нужно к базе данных написать простенький интерфейс, чтобы через него в эту самую бд (или эти самые бд) можно было вводить записи + проводить какую нибудь сортировку, поиск и подобные простые запросы. На чем легче всего будет реализовать? Интернетик пестрит вариантами либо с php, либо с C# + MySql или Microsoft Access, но не могу пока определиться. В этих языках и софте я полный штрих, придется с нуля осваивать. Единственное, чуток в С разбираюсь и еще меньше в плюсах.
Аноним 31/05/19 Птн 20:45:28 141006250
>>1410061
C# + Entity Framework
обучающих статей на MSDN должно хватить для простейшего круда. алсо EF имеет провайдеры для множества базочек, под капотом можешь хоть SQLite заюзать
Аноним 01/06/19 Суб 13:35:51 141027851
Господа, попробуйте представить, что вы стали ниибатся менеджером, который выбивает деньги на проекты у бизнеса.
Деньги вы получили, но при выборе средств разработки вы столкнулись с альтернативой. Продукт вы можете реализовать, используя три СУБД:
1) Oracle
2) MS SQl
3) Postgress
Есть ли хоть какая-нибудь статья, которая ОБЪЕКТИВНО сравнивает эти три СУБД?
Аноним 01/06/19 Суб 13:37:05 141028152
>>1410278
Если нет, то как бы вы аргументировали свою позицию в ту или иную сторону, бабки не проблема
Аноним 01/06/19 Суб 14:40:37 141031853
>>1410278
оракл - неубиваемая хуйня для миллиарда транзакций в секунду. требует, возможно, дорогих девелоперов

мс - оракл на минималках. выбор хорош если нужны какие-то решения из коробки и не хочется их девелопить с нуля

постгре - опенсурс и этим все сказано
Аноним 01/06/19 Суб 15:02:16 141033854
>>1410281
1) Oracle
Дорого. Нужен как минимум один DBA. Отточенная
железобетонная отказоустойчивость при верной настройке. Куча плюх и пердолек, которые позволяют эффективно управлять СУБД и данными. Есть встроенный язык PL/SQL - процедуры/функции. Есть поддержка и подробная документация. Если если пятизначные цифры в $ на лицензирования не страшны - это однозначно твой выбор. Идеально подходит банкам или крупному ритейлу для OLTP/OLAP.

2) MS SQl
Дорого поделить на джва, если сравнивать с Ораклом. Развертывается на шиндовс сервере. По плюхам почти как оракле. Есть встроенный язык T-SQL - процедуры/функции. Ниже по производительности и отказоустойчивости. Поддержка сообщества подробная почти как у Оркала. Механизмы репликации отсасывают у Оракла. Подходит сторонним подразделениям банков, мелкому ритейлу и крутить 1С. Прекрасно крутит OLAP. При правильных админах и разрабах можно крутить OLTP.

3) Postgress
Если будешь использовать в интерпрайзе то нормальная поддержка все равно за бабки. В последних версиях есть процедуры и функции. Спецов найти сложнее для администрирования. Поддержка сообщества слабее, чем у ребят выше. Может крутить мелкую хуету типа телефонии, сайтов, логи, мониторинг. Есть единичные мазохисты которые крутят это в серьезном Энтерпрайзе.


ИМХО за 3,5 года с БД
Аноним 01/06/19 Суб 18:01:46 141039655
Товарищи, выручите пожалуйста, помогите правильно запрос к БД написать.

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

У меня проблема вот с чем, пишу клиентскую часть, и не могу понять - как правильно написать запрос к БД, чтобы результат выдачи показывал только те ID'шники машин, которые могут быть заказаны на сегодняшнее число.

Аноним 01/06/19 Суб 18:23:43 141040156
>>1410396
Без структуры таблиц сделать это сложно.

Я так понимаю, у машины есть атрибут типа свободно/занято. Если занято, то скорее всего можно сделать джоин к тому за кем занято-на какую дату.
Аноним 01/06/19 Суб 18:42:43 141040757
>>1410401
table.Car // Машина
{
     int id;
     driver_id; // Кто водитель;
     nvarchar type; // Тип (груз, легковушка);
     nvarchar mark. // Марка.
}

table.Order // Заказы
{
     int id;
     int car_id; // Машина;
     int client_id; // Кто заказал;
     date orderDate; // Дата заказа;
     date returnDate. // Дата возврата в автопарк.
}

Связь: 1 - TO - MANY (1 Car - Many Orders), T-SQL;

Я пробовал в структуру машины добавить булевое "Свободна/Занята", но не догнал как это можно с пользой использовать.
В шарповском треде мне кое-где подсказали, но что-то так и не понял как с умом использовать. Суть в том, что я через запрос могу вывести те машины в диапазоне того времени, когда они заняты. А мне бы этот запрос отреверсить как-нибудь, чтобы видеть внешние диапазоны, когда машина доступна для заказа.

Запрос на внутренний диапазон:
SELECT [Order].car_id
FROM [Order]
WHERE orderDate <= @currentDate AND returnDate > @currentDate;

А мне бы наоборот, выводить те машины, которые свободны, а не заняты.

Небольшой примерчик:
3 машины - 3 заказа;
1) Машина№1 - с 01.06.2019 по 07.06.2019;
2) Машина№2 - с 05.06.2019 по 10.06.2019;
3) Машина№3 - с 31.05.2019 по 05.06.2019;

Точкой отсчета в запросе я беру, сегодняшний день - 01.06.2019.
Следовательно, по запросу мне машина №2 должна быть доступна с сегодняшнего числа по 04 (или 05, хотя в собесе не сказано, что машина может быть заказана и возвращена в тот же день).
Аноним 01/06/19 Суб 18:43:40 141040958
>>1410407
Наврал, SQLite у меня, а не T-SQL. Прошу прощения!
Аноним 01/06/19 Суб 18:50:57 141041259
Безымянный.png (29Кб, 647x527)
647x527
Привет, аноны. В каком софте можно нарисовать именно такую логическую модель бд?
Аноним 01/06/19 Суб 19:57:14 141044160
Аноним 01/06/19 Суб 20:09:21 141044761
image.png (10Кб, 514x269)
514x269
image.png (24Кб, 749x480)
749x480
image.png (22Кб, 583x512)
583x512
image.png (27Кб, 1225x313)
1225x313
Дароу. Короче меченый я тебя спас и в благородство играть не буду придумаешь для меня пару заданий и мы в расчете. А именно для такой базы данных надо придумать 10 запросов на INSERT и 10 на UPDATE и 1 на DELETE. Сами решения писать не надо только текст заданий. Фантазии пиздец не хватает написал уже 40 ебучих заданий из 60. схема на пикчах
Аноним 02/06/19 Вск 12:17:52 141063562
Привет антуанам.
Наслышан про схему, когда вместо offset'ов используются page_token'ы (потому что оффсеты медленные на больших таблицах).
Как мне объясняли, page_token'ы делаются по какой-то хитрой схеме через where, но я тупой и у меня не получается нагуглить это самостоятельно.
Подскажите, как вообще это делается?

Я вижу это так, что когда у меня запрашивают N-ю страницу, я беру оттуда id последней строки (у меня это uuid, но по тдее не важно) и возвращаю в качестве page_token'а, соответственно на N+1 страницу мне передают этот самый токен и я делаю запрос вида "дай мне 10 строк после строки у которой id=page_token", но я хз, как это сформулировать в виде запроса.
Сортировать по id'ам и говорить where id > page_token не вариант, потому что это отсортирует строки по дате создания (а у меня другие правила сортировки).

Вопрос сложный, только для настоящих программистов, так что с меня утроенное количество сотен нефти.
Аноним 02/06/19 Вск 13:30:59 141067163
Аноним 02/06/19 Вск 16:23:27 141079064
>>1410407
тебе нужно шоп ORM нагенерило запрос, или простыня из SQL тоже сойдет?
Аноним 02/06/19 Вск 16:30:44 141079965
>>1410790
ORM'ом или SQL - мне лишь бы понять суть.
И, если не затруднит, подскажите литературу, где подобные случаи разбирают/рассматривают.
Аноним 02/06/19 Вск 16:48:33 141081466
>>1410799
https://pastebin.com/WWjstCU3

в общем задача звучит как Gaps and Islands. но с наскоку гуглить может быть непонятно
я попробовал сгруппировать по машиносу и вывести MIN/MAX свободная дата, но так делать неправильно ибо все промежуточные занятые даты будут пропущено. я ебал делать еще одно CTE, для начала сойдет (если я вообще правильно понял суть). путем самопердолинга можно довести запрос до нужного
Аноним 02/06/19 Вск 17:00:06 141082167
>>1410814
Премного благодарен, подскажите пожалуйста ещё что-нибудь по подобным задачам, где можно какие-то материалы почитать, хотелось бы найти что-нибудь для обучения на реальных примерах, без абстрактных задач.
Аноним 02/06/19 Вск 17:30:40 141084668
>>1410821
лично я не учился на каких-то примерах. все - это либо задания с собесов, либо реальные кейсы, либо что-то случайно нагугленное
Аноним 03/06/19 Пнд 19:01:47 141135669
bfd.jpg (81Кб, 681x527)
681x527
Пытаюсь подключить учебную базу из MySQL в VS 2017.
На ютабе решается установкой других версий коннектов.Но у меня проблема не решается, двач помоги.
Аноним 04/06/19 Втр 19:17:51 141185370
Пацаны, в мускул workbench можно как-то передвигать нормально эти линии, показывающее отношения? А то у меня они наложились на друг-друга, под таблицы, под небо, Аллаха. Хочу штоб покрасивше их расставить, но не пойму как очевидным способом нихуя не дает
Аноним 05/06/19 Срд 08:51:18 141205771
>>1406455 (OP)
Можно ли за пару месяцев нахвататься, чтобы взяли на самую простенькую вакансию релейтед?
Аноним 05/06/19 Срд 09:07:42 141206472
>>1412057
После 3 месяцев на sql-ex.ru 100к дают же
Аноним 05/06/19 Срд 09:47:05 141207773
db.png (49Кб, 634x501)
634x501
Привет, анонимусы. Есть такой кусок БД, а смысл таков: есть айтемы, у айтемов может быть сколько угодно параметров и соответствующих им значений. Например, свитер: цвет - зеленый, размер - маленький, автор - Дэвид Блэйн. Теперь вот думаю, либо я дурак и не могу запрос составить чтобы по параметрам и значениям выбрать айтемы, либо я дурак и неправильную архитектуру запилил. Что скажете, уважаемые?
Аноним 05/06/19 Срд 10:02:34 141208474
Untitled.png (2Кб, 482x146)
482x146
>>1412077
разделять parameter и value тебе нужно ибо значения параметров имеют фиксированный сет значений?

если бы проще, то как на пике
а вообще и из твоего поделия можно сочинить более-менее вменяемый запрос, правда за охуительное количество джоинов оптимизатор тебе спасибо не скажет
Аноним 05/06/19 Срд 10:09:43 141208875
>>1412084
>значения параметров имеют фиксированный сет значений?
Да. С точки зрения оптимизации было бы заебись параметры в столбцы выносить, как раньше и было, но я устал каждый раз код править добавляя новый параметр, поэтому решил сделать их динамическое создание через админку. И встрял.
Аноним 05/06/19 Срд 10:11:08 141208976
>>1412088
поколоночное хранение подобных данных - это либо сознательная денормализация ради убийственного перфоманса, либо топкекрофл

так что не получается?
Аноним 05/06/19 Срд 10:15:19 141209177
>>1412089
select t.id as item_id, p.id as parameter_id, v.id as value_id
from item u
join item_value iv on i.id = iv.item_id
join value v on v.id = iv.value_id
join parameter p on p.id = v.parameter_id
where p.id = 1
and v.id = 3
and p.id = 3
and v.id = 5

Такой запрос работать не будет. Нужно выбрать одновременно несколько параметров и несколько значений.
Аноним 05/06/19 Срд 10:16:47 141209378
>>1412091
давай запрос по-человечески, что ты хочешь выбрать на основании каких фильтров?
Аноним 05/06/19 Срд 10:20:44 141209479
>>1412093
Хочу выбрать айтемы, у которых: параметр "цвет" = значение "зеленый", параметр "размер" = значение "маленький" и т.д. Количество параметров в запросе может быть разным, но я это в коде сделать смогу.
Аноним 05/06/19 Срд 11:29:47 141213680
>>1412094
чет я сам не подрасчитал сложноту задачи
https://pastebin.com/wDAvZuj5

не думаю, что такое решение имеет право на существование, но, справедливости ради, оно работает как ты хочешь лол)
я юзаю SQL Server-ный диалект, полагаю, все подобное поддерживается всеми стандартными базами
в T/SQL мне не хватает шарповского "выбрать строки, у которых встречаются все значения из подможества".
еще как вариант делать каскадную фильтрацию, типа:
- выбрать все айтемы
-- отфильтровать, у которых "цвет" не "розовый/зеленый"
--- отфильтровать, у которых "размер" не "маленький"
но подобное на SQL реализовывать занятие так себе. разве что генерить запрос в коде и на верочку отправлять его в базу
Аноним 05/06/19 Срд 11:34:23 141214081
>>1412136
Мощно. Буду пробовать, спасибо тебе.
Если я правильно понял у меня получается модель EAV, которая часто во всяких интернет-магазинах встречается.
Аноним 05/06/19 Срд 23:29:30 141263182
Пасаны, покажите пожалуйста конкретный (не просто х->у......, а с какой-нибудь табличкой или конкретными данными) пример нетривиальной и полностью нетривиальной функциональных зависимостей.
Я прост не понимаю как разница у них будет выглядеть
Аноним 07/06/19 Птн 21:37:37 141342583
Антоны, я переношу огромные массивы данных с FireBird на Oracle. Но деля это через промежуточный .csv получается пиздец, кодировки летят как угорелые. Что делать то?
Аноним 07/06/19 Птн 23:13:33 141347384
Нужно сохранить древовидную структуру в БД, при этом нужно:
1. Быстро выбирать все поддерево для указанной ноды.
2. Быстро перемещать поддерево к другому родителю.
То что нагуглил: с первым хорошо справляется nested sets, со вторым adjacency list. Materialized paths - вообще непонятно зачем нужное говно.

Накидайте идей как хранить в БД древовидную структуру, так чтобы усидеть на двух рекваиментах? Может скомбинировать как, или materialized paths спасут меня?
Аноним 08/06/19 Суб 00:55:13 141350485
>>1413473
Какая база-то?
Оракл умеет нормально выбирать деревья/поддеревья
Постгре, вроде, тоже.
parent_id -> id
Хули сложного?

Не, конечно, если у тебя МуСКЛ, то просто иди на хуй.

А если ты еще не решил, какая у тебя база, то бывают, внезапно ГРАФОВЫЕ БД
Типа https://neo4j.com/
Аноним 08/06/19 Суб 00:56:46 141350586
>>1413425
SQL*Developer's Migration Workbench не для тебя сделали?
Аноним 08/06/19 Суб 00:58:45 141350787
>>1412136
>но подобное на SQL реализовывать занятие так себе. разве что генерить запрос в коде
>генерить запрос в коде
Внезапно, это единственно правильное решение
Аноним 08/06/19 Суб 08:00:12 141353388
>>1413507
внезапно, это решение упирается в реализацию и соскочить с написанного будет непросто в реальном мирке
Аноним 08/06/19 Суб 13:04:31 141359589
>>1409326
Это хоум кредит? Как сходил?
Аноним 08/06/19 Суб 17:35:21 141371290
>>1413505
Спасибо!!!(Восклицание)
Аноним 08/06/19 Суб 19:48:19 141377891
Как оптимальнее всего написать накопительный запрос по зарплате сотрудников.

Create table PersonA(Tbn number primary key, name varchar2(20), otd number, sal number);
--Табельный номер , имя, отдел , зарплата

Insert into PersonA(Tbn,name,otd,sal) values(1, 'Аня',10,9000);
Insert into PersonA(Tbn,name,otd,sal) values(2, 'Саша',10,5500);
Insert into PersonA(Tbn,name,otd,sal) values(3, 'Таня',10,7000);
Insert into PersonA(Tbn,name,otd,sal) values(4, 'Ваня',20,2300);
Insert into PersonA(Tbn,name,otd,sal) values(5, 'Олег',20,4300);
Insert into PersonA(Tbn,name,otd,sal) values(6, 'Коля',20,3900);
Insert into PersonA(Tbn,name,otd,sal) values(7, 'Таня',30,7000);
Insert into PersonA(Tbn,name,otd,sal) values(8, 'Макс',30,9000);
Insert into PersonA(Tbn,name,otd,sal) values(9, 'Таня',30,8500);
Insert into PersonA(Tbn,name,otd,sal) values(10,'Макс',30,9900);
Insert into PersonA(Tbn,name,otd,sal) values(11,'Олег',30,9900);
Insert into PersonA(Tbn,name,otd,sal) values(12,'Макс',30,9900);
Insert into PersonA(Tbn,name,otd,sal) values(13,'Макс',30,9900);
Insert into PersonA(Tbn,name,otd,sal) values(14,'Макс',30,9900);
Insert into PersonA(Tbn,name,otd,sal) values(15,'Макс',30,9900);
Insert into PersonA(Tbn,name,otd,sal) values(16,'Макс',30,7000);
Insert into PersonA(Tbn,name,otd,sal) values(17,'Таня',30,3500);
commit;
Вот например тут если мы сделаем запрос:
select name , otd , sal , sum(sal) over (partition by otd order by sal) as num from personA, то результат будет некорректный, из-за того что поле sal может повторятся.
Как написать корректную аналитическую функцию?
Аноним 08/06/19 Суб 19:51:18 141377992
изображение.png (123Кб, 1240x602)
1240x602
Результат выполнения выделенный функции будет как на пике, мне же нужно, чтобы суммирование продолжалось.
Аноним 08/06/19 Суб 19:54:37 141378193
изображение.png (112Кб, 1125x528)
1125x528
Я ничего кроме этого придумать не смог.
select a., sum(sal) over (partition by name order by name, num)
from
(select a.
, row_number() over (partition by name order by name) num
from PersonA a) a
Аноним 08/06/19 Суб 19:56:59 141378394
И правильно ли я понимаю, что в конструкции "sum(sal) over (partition by name order by name, num)" первым выполняется оператор сортировки?
Аноним 08/06/19 Суб 20:00:22 141378495
Да вообще, если order by это только сортировка, то как она может влиять на результат запроса?
Аноним 08/06/19 Суб 20:10:39 141378796
>>1413778
ROWS BETWEEN UNBOUNDED PRECEEDING AND CURRENT ROW
Аноним 08/06/19 Суб 20:57:37 141380197
Аноним 08/06/19 Суб 20:57:57 141380298
Аноним 08/06/19 Суб 23:06:19 141388099
db1.png (19Кб, 1108x407)
1108x407
db2.png (19Кб, 1007x177)
1007x177
Господа, пожалуйста, подскажите. Имеется БД как на первом пике: три таблицы с данными foo, bar, baz и одна таблица common, в которой ведется учет добавления в те три таблицы. Например, если в таблицу foo добавится элемент:

insert into foo values (0, 999);

то в таблицу common автоматически добавится такая новая запись:

insert into common values (N, 0, null, null);

, где N - автоинкрементирующийся id.

Вопрос такой, можно ли и как сделать такой селект по таблице common, чтобы в результате получить данные со всех трех таблиц foo, bar, baz (пока предположим, что все поля у таблиц одинаковые)? Кароче, нужен результат как в таблице select result, как показано в примере на втором пике.

Я пытался через inner join сделать, записав три join подряд, но естественно результат нулевой, потому что он для всех условий join использует конъюнкцию, то есть находит пересечение множеств. Мне надо чтобы он в строке common находил не null поле с id и дергал данные из соответствующей таблицы по этому id.
Аноним 08/06/19 Суб 23:32:58 1413891100
>>1413880
>Вопрос такой, можно ли и как сделать такой селект по таблице common, чтобы в результате получить данные со всех трех таблиц foo,
Можно
Аноним 09/06/19 Вск 00:55:17 1413914101
>>1413504
Про Оракловый connect by prior я знаю, и кстати MySQL с 8 версии тоже может выбирать поддеревья целиком. У меня больше вопрос перфоманса. Как там работает connect by prior не совсем ясно, но скорее всего просто тупо джоинит внутри. Быстрее чем самому, запрос за запросом выбирать. Но с nested sets когда тупо выбирается диапазон и рядом не стоит.

Neo4j я знаю и начал смотреть, но там пока вообще непонятно насколько быстро выбирается поддерево.
Аноним 09/06/19 Вск 01:08:44 1413916102
>>1413914
В оракле все нормально.
Там точно не джойны внутри.
Делаешь запрос и смотрешь план. Думаешь.

Нео - говно, но если тебе нужен граф немыслимой вложенности, то почему бы и нет?
Аноним 09/06/19 Вск 08:45:42 1413951103
Расскажите про EAV. Он ещё актуален для всяких CMS и маркетплейсов? Или что-то лучше придумали?
Аноним 09/06/19 Вск 11:47:19 1413984104
>>1413891
> Можно
Отлично, как это сделать?
Аноним 09/06/19 Вск 12:13:36 1413997105
>>1413880
Левые джойны + coalesce не учил, не?
Аноним 09/06/19 Вск 18:14:12 1414153106
>>1413787
Объясни пожалуйста:
>UNBOUNDED PRECEEDING - Окно начинается с первой строки текущей группы и заканчивается текущей обрабатываемой строкой
- CURRENT ROW - Окно начинается (и заканчивается) текущей строкой
Как это можно связать через between? Почему UNBOUNDED PRECEEDING не включает в себя CURRENT ROW? И почему на результат аналитических функций влияет дублирующие строки в имени функции?
Аноним 10/06/19 Пнд 06:53:07 1414344107
Screenshot2019-[...].png (44Кб, 796x500)
796x500
Screenshot2019-[...].png (51Кб, 794x550)
794x550
Screenshot2019-[...].png (26Кб, 1042x408)
1042x408
>>1414153
>Окно начинается с первой строки текущей группы и заканчивается
где ты это описание нашел? где нашел, там и оставь

границы окна указываются как rows between <start> and <end>. причем, заставить учесть одну и ту же строку дважды без костыльных подзапросов достаточно проблематично
Аноним 10/06/19 Пнд 20:34:24 1414617108
изображение.png (106Кб, 1239x375)
1239x375
>>1414344
Том Кайт
СУБД Оракл
Алсо, запрос корректно работает и без
>BETWEEN AND CURRENT ROW
Просто там по умолчанию стоит RANGE UNBOUNDED PRECEEDIN
Аноним 10/06/19 Пнд 20:36:10 1414618109
>>1414617
ёпт, оракл. не знал, что в диалектах есть хоть что-то похожее
Аноним 10/06/19 Пнд 20:37:11 1414619110
>>1414618
Конкретно эта хуета от транзакта не отличается, это анси.
Аноним 10/06/19 Пнд 23:39:19 1414689111
Посоветуйте научпоп по БД на ночь глядя и что нибудь по проектированию бд
Аноним 10/06/19 Пнд 23:50:51 1414691112
>>1414619
Бля, второй раз в жизни на дваче что-то полезное!
Никогда не пользовался этими функциями и даже не знал, что так можно, епта!
Даже в сраном мускуле это есть, охуеть, что уж там про оракл говорить...

Спасибо, аноны!
Аноним 10/06/19 Пнд 23:56:14 1414694113
>>1414689
Томас Коннолли, Каролин Бегг — Базы данных. Проектирование, реализация и сопровождение. Теория и практика.
Аноним 11/06/19 Втр 16:29:15 1414856114
Screenshot391.png (15Кб, 1136x253)
1136x253
Приветик.
Хочу переименовать название одной колонки в таблице, погуглил (так как я нуфаг), выдало решение:

ALTER TABLE table_name RENAME COLUMN name1 TO name2;

Но чот меня шлет нахер читать документацию и ругается на синтаксис в месте: COLUMN name1 TO name2;
Пробовал с кавычками, писал RENAME_COLUMN (а что а вдруг) результат тот же.
Подскажите, как переименовать, будьте добры.
Использую PhpMyAdmin, если это важно.
Аноним 11/06/19 Втр 16:45:04 1414865115
>>1414856
ALTER TABLE table_name
Change column_name1 column_name2 Data_Type
Аноним 11/06/19 Втр 16:51:53 1414866116
Аноним 11/06/19 Втр 20:32:50 1414933117
image.png (232Кб, 781x870)
781x870
>>1414694
Знаешь, я пожалуй поищу что то менее затратное и лежащее на торрентах
Аноним 11/06/19 Втр 22:07:55 1414965118
image.png (348Кб, 1886x584)
1886x584
>>1414933
Бвахахахаха
Ты не видел, что ли, сколько классика стоит?
Аноним 12/06/19 Срд 00:33:54 1415009119
>>1414965
>Дейт.
Бляяяяять. Этого клоуна невозможно воспринимать серьёзно.
Аноним 12/06/19 Срд 01:39:07 1415024120
>>1415009
Ну ок.
Наконец-то на дваче мне распедалили, кто клоун, а кто нет.
Аноним 12/06/19 Срд 07:00:45 1415052121
>>1415009
я чувствовал, конечно, что его книгу по основам реляционной теории я купил зря. но это настолько бесполезный автор что ли в домене?
Аноним 12/06/19 Срд 16:03:03 1415326122
>>1415052
Ну, примерно как Матфей в области рассказов об Иисусе.
Апологет Невзорова, конечно, назовет его клоуном.

Все ты правильно сделал.


His book An Introduction to Database Systems, currently in its 8th edition, has sold well over 700,000 copies not counting translations, and is used by several hundred colleges and universities worldwide.

Хуйня, конечно. У Пупкина лучше все описано.
Аноним 12/06/19 Срд 16:50:26 1415367123
>>1415326
круто, рофловасян смог скопипастить с вики. а сказать-то что хотел?
я говорил где-то, что у него хуево написано (что-то где-то)?
Аноним 13/06/19 Чтв 00:34:04 1415552124
>>1415367
Круто, рофловасян без всякой вики обосрет любого. а сказать-то что хотел?
13/06/19 Чтв 12:43:50 1415744125
>>1406455 (OP)
>составляем базу необходимых знаний на гитхабе
И где она?
Аноним 13/06/19 Чтв 14:51:37 1415805126
>>1415744
Крис Дейт спиздил, чтобы продавать по 250 баксов.
Вон, у анона уже жопа полыхает
Аноним 13/06/19 Чтв 18:10:42 1415951127
Здоров, котоны. Реализовал я, значит, кусок базы в шаблоне EAV.
Поиск по атрибутам и значениям выполняю вот так:
SELECT t0.
FROM eav t0
join eav t1 on t0.phone_id=t1.phone_id and t1.parameter = "Источник" and t1.value = "Сайт 1"
join eav t2 on t0.phone_id=t2.phone_id and t2.parameter = "Группа" and t2.value = "Основная"
join eav t3 on t0.phone_id=t3.phone_id and t3.parameter = "Регион" and t3.value = "Ленинградская область"
group by t0.phone_id
having count(
) = 3

Проблема в том, что в EAV-таблице приходится держать сами значения и они многократно дублируются. Хотелось бы в этой таблице держать только ID, а искать так же по значениям. Если добавить таблицы с атрибутами и значениями, а в этом запросе их заджойнить, то поиск не возвращает ничего. Пример с джойнами:
SELECT t0.
FROM eav t0
join parameter p on p.id = t0.parameter_id
join value v on v.id = t0.value_id
join eav t1 on t0.phone_id=t1.phone_id and p.name = "Источник" and v.name = "Сайт 1"
join eav t2 on t0.phone_id=t2.phone_id and p.name = "Группа" and v.name = "Основаная"
join eav t3 on t0.phone_id=t3.phone_id and p.name = "Регион" and v.name = "Ленинградская область"
group by t0.phone_id
having count(
) = 3

Я что-то не так делаю или это в принципе невозможно?
Аноним 13/06/19 Чтв 18:33:34 1415965128
0byyGf0cfXs.jpg (136Кб, 894x894)
894x894
>>1415805


>Крис Дейт спиздил, чтобы продавать по 250 баксов.

ух сволочь

>Вон, у анона уже жопа полыхает

Еще тлеет
Смотрю и не могу найти что то стоящее

Объясни мне момент. С учетом фундаментальной основе в виде знания БД, почему в целом так мало людей разибирающихся в них чуть больше "сделать ручками зазубренные вызовы", хотя и таких не так много, ибо ОРМ... Аналитиков БД в обще кот наплакалпытался найти себе ментора
Аноним 13/06/19 Чтв 19:04:42 1415977129
Аноним 13/06/19 Чтв 19:10:09 1415979130
>>1415977
Но большая часть из них это не программисты на питоне и яваскрипте.
Да даже и на яве, хули там.

ОРМ, которая может за тебя "сгенерить" схему БД, и, тем более, ебаные РЕСТ-репозитории, которые вообще без всякой мысли программиста что-то хуярят в базу, или из нее читают...
Да ну на хуй.

Просто сайт-визитку сделать это заебись, быстро, и всем видно. Молодец, мальчик, фуллстэк, 300кк/нс
А огранизовать правильное, надежное хранение с разумной скоростью характерных выборок - да кто ж это увидит? Ничего же не пердит и не свистит.
Вот и специалистов не видно в толпах говнокодеров.
Только и всего
Аноним 13/06/19 Чтв 19:12:16 1415982131
>>1415951
пример твоих АВ мы сами должны угадывать из твоих селектов?
Аноним 13/06/19 Чтв 20:20:19 1416004132
>>1415979
>специалистов не видно в толпах говнокодеров
во-первых, попробуй заглянуть дальше своего "проекта"
во-вторых, говнокодерство может быть обусловлено положняком на самом проекте (sad but true)
в-третьих, уметь использовать ОРМ тоже нужно. и, обычно, без знания того, какой код нагенерит тебе этот ОРМ, сильно не погуляешься
кто для тебя специалист-то вообще?
Аноним 13/06/19 Чтв 20:36:52 1416011133
>>1416004
Да я не про свои проекты же.
В моих проектах у меня есть я, мне других не надо.
Я про то, что вижу вокруг.
Даже если не брать двач, бггг, то форумы и ебаные тенденции (напоминаю про способность ОРМов генерить схему базы, такое кто мог придумать, на такое кто мог подписаться, и почему это еще живо, мм?)
ОРМ - хорошо. Там, где ему место.
Но, опять же, ОРМ по большей части делают люди, которые пляшут от программирования и объектов. А не от грамотной схемы.
Поэтому некоторые очевидные (для меня) ходы через какой-нибудь Хибернейт охуеешь делать.
Аноним 13/06/19 Чтв 21:20:51 1416023134
Помогите мне, я студент-постгрессодебил. НУЖНА ПОМОЩЬ!

Я пытаюсь создать функцию и триггер, который будет обновлять атрибут timeorder с текущей датой, когда атрибут floatingItem обновляется. Функция, с которой я работаю, работает с одной проблемой. Он обновляет все записи, а не те, которые были обновлены.
Проблема: при обновлении данных в floatingItem timeorder остается неизменным

ALTER TABLE public.orders ADD COLUMN timeorder timestamp without time zone;

CREATE FUNCTION web() RETURNS trigger AS
$$
BEGIN IF new.floatingItem = FALSE
THEN
UPDATE public.orders SET timeorder = current_timestamp WHERE
new.bubNum=orders.bibNum;
END IF;
RETURN new;
END;
$$
LANGUAGE plpgsql VOLATILE;

CREATE TRIGGER IF NOT EXISTS mytrigger AFTER UPDATE ON public.fund FOR EACH ROW EXECUTE PROCEDURE mytrigger ();
Аноним 13/06/19 Чтв 21:29:08 1416025135
image.png (530Кб, 1374x888)
1374x888
Аноним 13/06/19 Чтв 23:14:55 1416066136
>>1416023
>CREATE FUNCTION web() RETURNS trigger AS
На хуя?
В чем проблема код написать сразу в триггере?
Аноним 13/06/19 Чтв 23:16:46 1416069137
Аноним 13/06/19 Чтв 23:21:15 1416071138
>>1416069
Не, я уже глянул в доку, это ебанутый синтаксис постгре

ты бы показал свой апдейт, который заставляет обновиться все записи
Аноним 13/06/19 Чтв 23:23:23 1416074139
>>1416023
и ты уверен, что new должно сработать, а не NEW?
я постгре не ебал особо, не знаю, насколько он регистрозависимый
Аноним 13/06/19 Чтв 23:27:12 1416077140
>>1416023
>UPDATE public.orders SET timeorder = current_timestamp WHERE
new.bubNum=orders.bibNum;
>UPDATE public.orders
>orders.bibNum
Я бы либо orders. выкинул бы, либо public добавил бы
Аноним 14/06/19 Птн 00:05:50 1416095141
image.png (225Кб, 1604x810)
1604x810
нихуя не работает бляяя
CREATE FUNCTION web() RETURNS trigger AS
$$
BEGIN IF new.floatingItem = FALSE
THEN
UPDATE public.orders SET timeorder = current_timestamp WHERE
new.bubNum=orders.bibNum;
END IF;
RETURN new;
END;
$$
LANGUAGE plpgsql VOLATILE;

CREATE TRIGGER web AFTER UPDATE ON public.fund FOR EACH ROW EXECUTE PROCEDURE web ();
Аноним 14/06/19 Птн 00:31:43 1416106142
>>1416095
тебе сказали уже: поменяй для начала на NEW
Аноним 14/06/19 Птн 00:54:33 1416114143
Снимок экрана 2[...].png (109Кб, 1752x824)
1752x824
Снимок экрана 2[...].png (143Кб, 1878x848)
1878x848
Аноним 14/06/19 Птн 07:48:29 1416162144
>>1416011
>ОРМ по большей части делают люди, которые пляшут от программирования и объектов. А не от грамотной схемы
я, честно говоря, не вижу противоречия в использовании ОО-модели и грамотной схемы базочки
Аноним 14/06/19 Птн 09:02:42 1416178145
eav.png (54Кб, 684x453)
684x453
Аноним 14/06/19 Птн 13:41:45 1416324146
>>1416162
Грамотная схема базочки не должна ничего знать про ОО-модель.
Только и всего.
Потому что схема реляционной бд строится по своим законам, а ОО-модель - по своим.
Я, в общем-то, об этом.
Аноним 14/06/19 Птн 13:45:08 1416331147
>>1416324
так модели уровня ORM - это рефлексия модели базы данных, с которой (обычно) приложение (бизнес-логика) не работает напрямую
если я нихуя не понял и сказанул хуйню, просто проигнорь
Аноним 14/06/19 Птн 13:45:35 1416333148
>>1416178
а теперь не поленись, и перечисли поля в селекте 1 и поля в селекте 2
Аноним 14/06/19 Птн 14:55:16 1416386149
>>1416333
Там макаба звездочку сожрала. На самом деле достаточно t0.phone_id
Аноним 14/06/19 Птн 16:33:59 1416442150
>>1416386
Ок. Чтобы понятнее было:
сделай со звездочкой, но убери груп бай
внимательно смотри, что у тебя в выборке получается
и почему не группируется вообще
Аноним 16/06/19 Вск 21:38:11 1417418151
Правильно ли я понимаю, что бизнес логику в БД уже никто не держит и изучать БД смысла нет?
Аноним 16/06/19 Вск 21:54:41 1417425152
Аноним 16/06/19 Вск 21:56:36 1417426153
Аноним 16/06/19 Вск 21:58:37 1417427154
>>1417418
Ещё как держат. Оракл это не только бд, но и целый стек накрученный поверх этой бд, и в банках этот стек используют во всю.
Аноним 16/06/19 Вск 22:05:00 1417432155
>>1417427
>Ещё как держат.
А зачем? В чём профит?
Аноним 16/06/19 Вск 23:53:27 1417458156
>>1417432
1. Простота. Все операции перед глазами, а не хуй знает где по стеку вызовов. Меньше шансов нафакапить с распределёнными транзакциями.
2. Скорость. Ты знаешь какие будут запросы в момент разработки, и можешь тюнить сразу же. Можешь пересобрать статистику вручную при необходимости, добавить хинтов, прибить план запроса гвоздями или не делать нихуя ибо так быстрее.
3. Единая платформа и куча программистов в штате под неё. В платформе есть всё что душа пожелает, даже готовая АБС за отдельный прайс
4. Легаси. Nuff said.
Аноним 17/06/19 Пнд 14:52:34 1417702157
>>1417432
Т.е. ты не видишь разницы в цепочке:
достать хуй из базы - сделать из него объект - ебануть что-нибудь с этим объектом - отправить обратно в базу

и

сделать все это в базе, выдав наружу только какой-нибудь иммутабл срез данных?
Аноним 17/06/19 Пнд 17:48:26 1417827158
>>1416442
Братан, второй запрос вообще ни одной строки не выводит. Группировать нечего. Я потому и спрашиваю что я не так делаю, раз у меня по ID ничего не ищет.
Аноним 17/06/19 Пнд 18:01:47 1417833159
>>1417827
У меня только вот так получилось это сделать, но выглядит как-то стрёмно.
SELECT t0.phoneId
FROM eav t0
join eav t1 on t0.phoneId=t1.phoneId and t1.parameterId = (select id from parameter where name = "Источник") and t1.valueId = (select id from value where name = "Сайт 1")
join eav t2 on t0.phoneId=t2.phoneId and t2.parameterId = (select id from parameter where name = "Группа") and t2.valueId = (select id from value where name = "Основная")
Аноним 17/06/19 Пнд 19:50:45 1417951160
Анон реквестинг хелп.
Надумал тут сдавать экзамены на сертификацию по мелкософт SQL, первый экзамен 761 сдал без особых проблем, готовлюсь к 762, так там оф учебник говорит, что его нихуя не достаточно и оно так. Особые проблемы ощущаю с dmv и мониторами для чека ресурсов и тюнинга производительности(Activity Monitor, Data Collector Sets, sys.dm_sranaya_ebota и т.д.). Знает ли анон какие проверенные ресурсы по данной тематике и/или прикладные конкретно для 762. В инете полно дампов, но там ответы неправильные, и их явно недостаточно, ибо цель не тупо натаскаться на экзамен, а подтянуть себя заодно.
Аноним 17/06/19 Пнд 20:00:44 1417967161
Аноны, обьясните пожалуйста нубу, что происходит при выполнении запроса, например, с сортировкой? Как ведут себя таблицы с которых идет выборка данны? Например, запрос
Slect * From Student ORDER BY name DESC; По какому алгоритму этот запрос обрабатывается? Сначала таблица Student сортируется по name, а уже потом возвращается? А после того как таблица вернулась операции отменяются? Или создается буферная таблица, с которой сначала выбираются данные, а уже там сортируются?
Аноним 17/06/19 Пнд 20:05:54 1417975162
>>1417967
Согласно оф мануалу от MS SQL(другие, полагаю, работаю так же):
the logical query processing order, which is the conceptual interpretation order, is different. It starts with the FROM clause. Here is the logical query processing
order of the six main query clauses:
1. FROM
2. WHERE
3. GROUP BY
4. HAVING
5. SELECT
6. ORDER BY
Each phase operates on one or more tables as inputs and returns a virtual table as output.
The output table of one phase is considered the input to the next phase. This is in accord with
operations on relations that yield a relation. Note that if an ORDER BY is specifed, the result
isn’t relational. This means that you can’t operate on such result with an outer query because
an outer query expects a relation as input

Карач, Order by работает на основе того, что сделали другие операторы, поэтому, кстати, только в нем можно обращаться к столбцам результата по алиасу.
Аноним 17/06/19 Пнд 22:27:35 1418040163
>>1417975
Этот дурачек.
>>1417967
Нужно смотреть план запроса.
Аноним 17/06/19 Пнд 22:39:56 1418045164
>>1418040
>Нужно смотреть план запроса.
Если покажешь такой план, где ОРДЕР БАЙ не последним идет, я охуею.
Но ты же не покажешь, да?
Аноним 18/06/19 Втр 07:42:07 1418111165
Screenshot2019-[...].png (51Кб, 1386x722)
1386x722
>>1418045
inb4 я тобой согласен полностью

я не он, хотя могу показать такой план
Аноним 18/06/19 Втр 09:11:37 1418136166
>>1418045
Да пожалуйста - запрос с фильтрацией на больше/меньше по rownum и сортировкой.
Запрос с аналитической функцией - тоже отработает после сортировки.
Охуеть, да?
Аноним 18/06/19 Втр 21:48:11 1418527167
>>1418111
Я так и думал, что найдется мастер-ломастер, который покажет на ордер-бай из вложенного селекта.
Найс.
Давай следующую попытку. С ордербаем от общего селекта.
Передавай привет, кстати, тому мудрецу, который вхуячил ордербай в подселект, он же там так нужен!
Аноним 18/06/19 Втр 21:51:24 1418529168
>>1418136
Первое - разумно, да. Хотя это и, очевидно, краевой случай.
Про аналитические функции поразмышляю. Но не вижу такой хуйни, кроме как для тех, которым важен порядок строк.

Но, очевидно, план запроса и тут на хуй не сдался. И так понятно, что если ты оперируешь rownum, то он будет после любых других действий.
Аноним 18/06/19 Втр 23:03:56 1418566169
postgres600.jpg (44Кб, 600x377)
600x377
Nastya960x703.jpg (124Кб, 960x703)
960x703
Объясните мне, почему вы такие никчемные? Пока вы рисуете схемки, тянка из МФТИ стала 59тым контрибьютором PostgreSQL.
https://postgrespro.ru/blog/company/4203947
Что вычувствуете, когда узнаёте о таких вещах?
Аноним 19/06/19 Срд 00:19:11 1418603170
>>1418566
Молодец! Умница! А я никчёмное говно. Такие дела.
Аноним 19/06/19 Срд 00:24:24 1418608171
Аноним 19/06/19 Срд 01:07:21 1418614172
>>1418608
двачую
у куна коммит не приняли бы, а у сельди есть вареник и ей все можно
Аноним 19/06/19 Срд 02:10:59 1418622173
>>1418529
Ну, роунам - специфичные случаи, но иногда бывает. Например, когда ты в подзапросе сортируешь по дате и добавляешь rownum as rn в поля выборки, а потом по нему делаешь rn = 1 - получаешь первую запись по дате. Таки лучше случая date = (select min date from huy).

Насчёт аналитики - влияет на план запроса, если в аналитике важна сортировка(а она чаще всего важна, насколько я сталкивался в пределах своей работы). От сортировки зависит, будет ли аналитическая функция заново сортировать набор или будет использовать уже имеющийся отсортированный.

А ещё сортировка может повлиять на выбор оптимизатором хэш джойна или мердж джойна при соединении двух наборов данных, так-то.
Аноним 19/06/19 Срд 10:45:51 1418692174
про порядок обработки. Вот вам дока: https://docs.microsoft.com/en-us/sql/t-sql/queries/select-transact-sql?view=sql-server-2017

Logical Processing Order of the SELECT statement

The following steps show the logical processing order, or binding order, for a SELECT statement. This order determines when the objects defined in one step are made available to the clauses in subsequent steps. For example, if the query processor can bind to (access) the tables or views defined in the FROM clause, these objects and their columns are made available to all subsequent steps. Conversely, because the SELECT clause is step 8, any column aliases or derived columns defined in that clause cannot be referenced by preceding clauses. However, they can be referenced by subsequent clauses such as the ORDER BY clause. The actual physical execution of the statement is determined by the query processor and the order may vary from this list.

FROM
ON
JOIN
WHERE
GROUP BY
WITH CUBE or WITH ROLLUP
HAVING
SELECT
DISTINCT
ORDER BY
TOP
Аноним 19/06/19 Срд 19:50:07 1418954175
>>1418692
Ты по-английски плохо читаешь, да?
>This order determines when the objects defined in one step are made available to the clauses in subsequent steps
И все.
К предмету обсуждения не относится вообще.
К предмету обсуждения относится вот это:
>The actual physical execution of the statement is determined by the query processor and the order may vary from this list.

Попробуй в следующий раз читать все буквы
Аноним 20/06/19 Чтв 00:15:59 1419119176
>>1418622
>А ещё сортировка может повлиять на выбор оптимизатором хэш джойна или мердж джойна при соединении двух наборов данных
Дай ссылку почитать про это
Без подъебки прошу
Аноним 20/06/19 Чтв 03:42:09 1419151177
>>1419119
Ну, вот что-то похожее на правду:
https://studfiles.net/preview/1037891/page:30/

А так там даже читать не о чем: если у тебя два отсортированных набора данных, то для группы значений из первого набора идёт поиск таких же значений во втором наборе до нахождения первого большего - дальше нет смысла искать, набор-то отсортирован.
Как nested loops, но меньше итераций вложенного цикла за счёт предварительной сортировки либо чтения индекса.
Аноним 20/06/19 Чтв 21:55:05 1419597178
>>1419151
Ну, твоя же ссылка говорит, что хешу вообще не всралась сортировка.
В сортмердже не будет итераций вообще, а будет 1 проход по одному набору, и 1 по другому.
НО! Сортировка ни на что не влияет. Оптимизатор может без всякой сортировки с твоей стороны решить, что сотрмердж будет быстрее.

В общем, сделай селект с /*+ USE_MERGE (или как в твоем диалекте хинт выглядит), и ордер баем. Хоть по тем же полям, что были в условии объединения.
И глянь в план запроса. Где будет ордер бай?

Если ты говорил о том, что имеет смысл херачить ордер бай в подселекты, то нет, не имеет. Если ты хочешь, чтобы сработал сорт-мердж, так оптимизатору и скажи. А не прыгай с бубном.
Аноним 21/06/19 Птн 01:29:09 1419694179
1561069732619.jpg (714Кб, 810x2745)
810x2745
>>1419597
Правильно моя ссылка говорит. И я тебе говорю, что сортировка нужна для мердж-джойна, а не для хэш джойна.
Только вот оптимизатор может на основании наличия в запросе сортировки и объема выборки сам выбрать мердж-джойн, а может выбрать хэш-джойн.
А может и выбрать мердж-джойн и сам отсортировать наборы данных. А один точно будет сортировать.
Смотри пикрил и не неси хуйню, что сортировка подзапроса не имеет смысла в случае мердж-джойна.

А ещё ты, наверное, не очень понимаешь смысл и процесс построения реального плана запроса и хинтов.
Аноним 21/06/19 Птн 16:28:07 1420021180
>>1419694
Пиздец, я так и думал (судя по тому, что первую ссылку ты прислал на русском), что с английским у тебя беда.

Удачи.
Аноним 21/06/19 Птн 16:59:42 1420033181
>>1420021
Хера ты рофлишь.
Ну давай, укажи, где я неправильно перевел. Я признаю свою ошибку, если ты не ебучий тролль без мозгов.
Аноним 22/06/19 Суб 20:16:32 1420520182
Ну ка двощерские погроммисты, поясните начинающему Богу Access-а как спланировать базу данных. Есть два стула... Один нормальный, второй с отверстием. Триллиард остальных характеристик абсолютно одинаковые. И есть таблица в которой эта пара стульев идет по возрастающему размеру, типа: стул высотой 19см, стул высотой 21см. Так вот, заводить по паре записей, типа стул 19см, стул 19см с отв. или сделать доптаблицу: "с отверстием";"без отверстия" и ключ этой таблицы добавить в таблицу со стульями? Но тогда опять их будет по две записи. Короче я уже нихуя не понимаю
Аноним 22/06/19 Суб 23:40:01 1420657183
>>1420520
>Ну ка двощерские погроммисты, поясните
Ну-ка пройди на хуй
Аноним 23/06/19 Вск 00:18:51 1420666184
>>1420520
А теперь выключи смехуечки и объясни, что у тебя за схема, в которой нельзя дырку в стуле сделать характеристикой. Высоту, значит, можно, а тип сиденья нет?
Если это два разных объекта, то как не пытайся, придется делать две записи.
Аноним 23/06/19 Вск 11:06:04 1420810185
>>1420666
>то как не пытайся
Пнятненько. Думал есть секретные многоходовки от мастеров проектирования БД.
Аноним 23/06/19 Вск 16:27:57 1420937186
Существуют ли какие-нибудь преимущества у noSQL перед обычными реляционками?
Тут есть люди, которые работют с хадуп и террадатой? Если ли у терродаты преимущества перед, например, ораклом? Правильно ли я понимаю, что она гораздо сильнее распаралленина?
Аноним 23/06/19 Вск 16:57:10 1420951187
>>1420937
Непересекающиеся задачи, а не преимущества
Когда кто-то пытается использовать noSQL для того, для чего все остальные десятилетиями используют SQL, это просто значит, что этот кто-то - мудак
Аноним 23/06/19 Вск 17:11:05 1420969188
>>1420951
Можешь привести пример задачи, где нужно использовать noSQL и не нужно SQL?
Аноним 23/06/19 Вск 17:51:29 1420990189
>>1420937
Обычно упоминается CAP теорема. noSQL это быстро но не гарантируется целостность данных в каждый конкретный момент времени. SQL (с транзакциями) - медленно но гарантируется целостность данных.
Аноним 23/06/19 Вск 20:51:45 1421122190
>>1420969
там, где у тебя естественным образом возникает 3НФ и, соответственно, постоянное пересечение таблиц - там sql
там, где неструктурированная информация (до хуя текстов, про которые тебе настрать, кто они, откуда, зачем, когда и где родились, и как связаны друг с другом) - там nosql

но умнее будет, если ты в гугле забьешь nosql vs sql и прочтешь первый пяток из выдачи
Аноним 24/06/19 Пнд 13:40:51 1421482191
Анон, сколько средняя ЗП разработчика БД в ДС?
Пишу пока изредка процедуры и триггеры на работе, сам бэкенд-разраб.
Вот думаю перекатиться, тк всегда хотел лучше разбираться в БД и проектировании, нравится писать на SQL, да и вообще ищу более консервативную область IT без модных фреймворков, гик-культуры, маскотов и прочей блевоты. Потом может в аналитику перекачусь.
Аноним 24/06/19 Пнд 16:48:44 1421591192
>>1421482
Хм, а сколько у тебя лет опыта и на каком языке пишешь? Может просто останешься в нём же, но найдёшь более интересную работу?

Стартовую ЗП сеньора ораклиста я бы обозначил в 150+, но это устаревший на сегодняшний день подход - сейчас в БД принято только хранить данные.
Аноним 26/06/19 Срд 08:41:23 1422337193
>>1421482
мне как бекенду [как правило] нужно разбираться в базочках чуть выше среднего уровня. офк, если сильно распределенные команды, то там за этим могут следить совсем отдельные люди, но, преимущественно, на твоей стороне все, чего касается бэк, входит в зону ответственности (хотя бы на уровне, я знаю слово redis и почему мы достаем сейчас трогаем его, а не мускульный кластер)
Аноним 26/06/19 Срд 14:16:18 1422493194
PmT9c1RpN38.jpg (230Кб, 810x1080)
810x1080
Привет. Подскажите как вкатиться в базы данных (какой-нибудь учебник или что-то типа того).
Сам по базам данных слушал только курс в универе и писал чё-то на C# с entity framework, но уже всё забыл.
Аноним 26/06/19 Срд 15:40:24 1422574195
>>1422493
что уровня сложнее википедии тебя вообще интересует?
Аноним 26/06/19 Срд 21:23:13 1422779196
1327895036252.jpg (175Кб, 535x807)
535x807
Привет, анон.
Не увидел в шапке гайда, но спасибо на том, что такой тред вообще есть. Хотел бы получить совет куда дальше расти.
Имею за плечами 6 лет опыта oracle developer. Уровень оценил бы как крепкий мидл, но многих нюансов работы базы не знаю, какие должен знать сеньор.
Последние два года работаю в одном из топ банков, в основном пишу бизнес-логику, работа уже становится однообразной.
Понимаю, что писать однообразный код и решать типовые задачи придется вскоре через силу. В какую сторону развиваться дальше? Вкатываться в ентерпрайз разработку желания особого тоже нет (имеется в виду java). Может в дата инженеры или сайнтисты? Вообщем вопрос, куда можно податься разрабу БД, при этом чтобы переквалифицироваться частично и/или постепенно. А если по ЗП не сильно просесть - то вообще сказка.
Аноним 26/06/19 Срд 21:38:54 1422785197
Ананасы, работа интересует? Есть вакансия для начинающих вкатывальщиков с минимальным опытом работы, или вообще без него.

Нужен эскуэльщик, который быстро разберется в существующих скриптах, и будет хуярить новые как безумная обезьянка. Быстро и правильно. А также - смотреть на цифры, которые выгрузились, и проверять их на адекватность. Эти скрипты нужно документировать и цеплять к экселю.
Больших познаний в sql не нужно, нужно понимание как работают оконные функции, джойны и как выбрать индекс для таблицы. ЗП от 100к, в зависимости от опыта. В общем, особо уметь нихуя не надо, но работы много.

Ах да, из формальных требований нужна вышка, остальное не принципиально.

Если кому-то интересно, телега @random_1234, пишите, пообщаемся.

Аноним 26/06/19 Срд 21:46:24 1422788198
Аноним 26/06/19 Срд 21:48:10 1422792199
>>1422788
ДС. Прошу прощения, забыл.
Аноним 26/06/19 Срд 22:33:20 1422814200
>>1422779
Я наделяю тебя ответственным за шапки треда.
Ты всё равно тут самый топовый.
Аноним 26/06/19 Срд 22:49:35 1422829201
>>1422814
Кек, плиз, судя по обсуждениям треда тут скучающие свитерысиньоры троллят друг друга.
Аноним 26/06/19 Срд 23:00:18 1422839202
>>1422779
Вот ты и разрешишь спор выше насчёт за sort merge, раз шесть лет опыта.

Так ты же можешь с таким количеством опыта начать свои темы продвигать. Начиная от какого-нибудь сборщика патчей заканчивая оптимизацией бд в целом.
Ну, то есть, ты же можешь расти внутри своего банка, разве нет?
Аноним 27/06/19 Чтв 00:40:30 1422888203
>>1422839
>Вот ты и разрешишь спор выше насчёт за sort merge, раз шесть лет опыта.
Ну начнем соправданий того, что все учатся по-разному и на разных примерах и учебниках и 6 лет работы ни о чем не говорит.
Ниже расскажу про фейл, который случился не так давно.

Думаю order все же в первую очередь используется, когда клиенту требуется предоставить результат запроса в сортированном виде (top n, pagination и т.п.). В примере из поста с вопросом очевидно, что сортировка выполнится последней.
В любом случае согласен с аноном, который предлагает смотреть реальный план соединения двух сортированных выборок, с хинтом и без.
>А может и выбрать мердж-джойн и сам отсортировать наборы данных
Задался вопросом, а может оптимизатор отказаться от промежуточных сортировок, которые явно указаны в коде запроса? Например, в случае merge joina двух сортированых выборок, результат будет отсортирован по ключу соединения , а в случае hash joina нет такой гарантии?

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

Так же встречал вот такое применение order by
SELECT * FROM demo
order by case when id%2=0 then '1' else '0' end desc
только вместо case использовался decode
с последующей фильтрацией rownum = 1.
Посмотрю план, кстати, не понятно чем это эффективнее простого фильтра в where.


Аноним 27/06/19 Чтв 02:51:04 1422913204
>>1422888
Ну, значит, мой проеб, я неправильно сделал выводы на основании того, что читал.
Насчёт промежуточных сортировок - кстати, даже не задумывался. Хрен уже с этим sort merge, насчёт этого - думаю, что если сортировка одна, он вынесет ее на верхний уровень. А вот в случае нескольких - уже не знаю.
В любом случае, я сталкивался с тем, что реальный план может отличаться от того, который строится без выполнения запроса. Это и насчёт явных хинтов: сам был ситуации, когда мердж в подзапрос выглядел с виду хорошо, а на самом деле выбрал NL для набора данных в несколько миллионов с обеих сторон, если не ошибаюсь. И пока я явно ему не сказал use_hash, он не выполнялся. То есть либо смотреть v$sql_plan, либо лог сервера, мирончик показывал как(а я уже не помню, как именно).
Можно ещё про driving_site сказать, но это немного другое дело.
А иногда тот же use_hash может быть лучше при хуевом факторе кластеризации и table access by rowid.

Про твою сортировку - мб там функциональный индекс был? Хотя этот запрос же выбирает, по факту, рандомную строку среди чётных - мало ли, зачем нужно было именно так.
С другой стороны, оракл говорит, что нет гарантии, что один запрос в два разных момента времени вернет одинаковые с точки зрения сортировки наборы данных, так что, в теории, и обычный фильтр должен дать случайную строку хотя я не раз обращал внимание, что хотя бы для простых запросов без параллелей порядок один и тот же. Либо как в индексе лежит, либо "сортирует" по rowid.

ты забыл про фейл рассказать
Аноним 28/06/19 Птн 15:49:12 1423979205
Screenshot2019-[...].png (10Кб, 460x106)
460x106
Screenshot2019-[...].png (13Кб, 236x161)
236x161
Screenshot2019-[...].png (19Кб, 320x168)
320x168
Есть 2 таблицы. Почему такой запрос не работает? БД - postgresql,
Аноним 28/06/19 Птн 16:50:03 1424021206
>>1423979
Потому что есть зарезервированные слова в SQL.
Аноним 28/06/19 Птн 17:59:51 1424052207
>>1423979
потому что ты используешь зарезервированное слово from?
Аноним 28/06/19 Птн 18:53:53 1424086208
>>1424052
Потому что я ньюфаг, сорри.
Аноним 29/06/19 Суб 01:18:50 1424283209
>>1422913
>ты забыл про фейл рассказать
Могу рассказать даже про два, но позже.
Денек отойду от работы.
Аноним 29/06/19 Суб 22:12:37 1424706210
>>1422913
>ты забыл про фейл рассказать
Это все относится к Ораклу, в других СУБД может и не воспроизвести.

1. В процедуре, в самом внутреннем вложенном цикле в курсоре написал селект с большим количеством джоинов по таблице
из которой удаляются/добавляются записи в той же самой транзакции. Если не вдаваться в подробности, то на большом объеме входных данных это вылилось в подвисание процедуры.
Основная причина - чтение данных не из блоков, а из сегмента отката. Ну это со слов более опытных коллег такая причина.
В логах сессии это проявлялось очень большим значением buffer_gets, что считается дурным знаком.

2. Представим таблицу, в которой есть текстовая колонка
"Значение свойства" (val ) - для хранения значений с разными типами данных: строки, числа, даты .
"Код свойства" (code) - все значения с одинаковым кодом относятся к одному типу данных.
"id объекта" (object_id) - несколько разных свойств могу относиться к одному объекту

Упрощенно, задача была написать запрос, выбирающий объекты с конкретным значением свойства.
Заранее известно, что требуемому коду свойства соответствуют числовые значения.

Таблица свойств P
Таблица Object O

select o.*
from o, p
where o.id = p.object_id
and p.code = 'PRICE'
and p.val = :x

, где x - число.
колонки p.code, p.val - индексированы простым индексом

Так вот на одном стенде этот код работал без ошибок, а на другом завершался с ошибкой рано или поздно.
Ответ очевиден, но если вдруг кому-то интересно подумать, могу под спойлер ответ спрятать.


Надо помнить, что в оракле, если в коде запроса есть бинды, но нет явного приведения типов в сравнении переменной и значения колонки,
то тип колонки таблицы приводится к типу переменной.
В одном случае план запроса был с index range scan по колонке code,
т.е. сначала находилась запись, где точно было число, а потом происходило сравнение.
В другом же был full scan и для каждой записи происходила попытка преобразовать значение к числу,
что и вываливалось в ошибку, если в строке встречался не числовой символ.

Мелочь вроде, но досадная, нельзя такое упускать.


2.
Аноним 30/06/19 Вск 00:40:07 1424757211
>>1424706
Жиза, сталкивался и с тем, и с другим. Второй пункт - так вообще в первые пару месяцев постоянно допускал такие ошибки - первичные ключи у нас были текстовые, а сравнение могло быть с числом, а оракл всегда при сравнении строки с числом неявно приводит первую к числу. Но нюанс про биндовые переменные не знал, запомню.

А первый пункт - да, есть такое, хотел как-то апдейтить 40+ миллионов одним мерджем, откат операции лет больше 25-ти минут.
Аноним 30/06/19 Вск 17:30:47 1424974212
>>1424706
>Основная причина - чтение данных не из блоков, а из сегмента отката.
Если блок был обновлён апдейтом, то оригинальный блок помещается в сегмент отката. Оттуда будут читать данные другие сессии, если им понадобится тот же самый блок, и производиться rollback. Но твоей собственной сесии, которая обновляет данные, обращаться в сегмент отката не за чем.
Ты упомянул про циклы, да еще и вложенные. Всякие forall не зря ведь придумали, sql в циклах работает медленно.
По поводу buffer gets. Вангую, что после того как блок был прочитан в кэш, затем обновлён, Оракл не мог получить его из кэша и перезачитывал заново с диска. Отсюда серьёзно возросший I/O, который и повесил процедуру. Но это предположение.

> тип колонки таблицы приводится к типу переменной.
Не совсем так, приводится к старшему типу. Если у тебя поле нумбер, а переменная варчар2, то конвертироваться будет бинд, и всё будет хорошо. А если наоборот, то да, конвертироваться будет поле, и индекс не будет использован.
Аноним 30/06/19 Вск 18:11:14 1424987213
>>1424974
Да, верно, неправильный вывод сделал.
Вот этим утверждением руководствовался

During SELECT FROM operations, Oracle converts the data from the column to the
type of the target variable

Видимо под target variable подразумевается переменная для хранения результата запроса.
Аноним 01/07/19 Пнд 22:23:28 1425760214
Анончик, помоги плз. Собираюсь делать свою приложуху. С беком мало работал, с базами еще меньше. С основами скл разобрался(как запросы делать), теперь нужно спроектировать базу, но я не знаю как. Подскажи статей(не книги), можно на английском, как по-быстрому спроектировать базу ньюфагу.
Аноним 02/07/19 Втр 01:01:48 1425904215
>>1425760
>По-быстрому
>Спроектировать базу
>Ньюфагу
Кек.

В первую очередь - кури нормальные формы. Потом пойми, какая бд тебе нужна - транзакционная или аналитическая. Дальше сам догадаешься.
Аноним 02/07/19 Втр 09:01:48 1425998216
Двач,добрый день,не могу понять как можно реализовать определенную задачу,в общем,в Excel есть таблица с номерами телефонов,номером группы и именем. Всё это нужно конвертировать в Word подставляя к шаблону. Т.е. ,может так будет понятнее.
Excel
телефон Группа Имя
123 1 Лера
222 2 Женя
444 3 Катя

Word
Студент группы 1 Лера была зачислена(или отчислена). Контактный номер 123

Можете помочь или я могу пойти нахуй?
Аноним 03/07/19 Срд 10:46:20 1426901217
>>1425998
почему ты с этой задачей пришел в тредик про базочки?
не уверен, что офисные продукты могут вот так влегкую импортировать данные из одного пакета в другой, да и по образцу тем более
Аноним 03/07/19 Срд 13:41:05 1426979218
>>1426901
уже сделал системму через filldocuments,полезная хуйня
Аноним 04/07/19 Чтв 12:11:37 1427779219
>>1425998
Тебе один раз или какая-то интеграция нужна?

Если один раз, выполни свой select, потом скопируй результат просто ctrl+v а потом вставь в word и excell
Если умеешь вставлять не только через ctrl+v, все получится.
Аноним 05/07/19 Птн 12:13:21 1428371220
Выручайте, поцоны. На работке сменилось руководство, мне дали задание вкатиться в область, в которой я вообще нулевой. расклад такой: БД оракл, есть програмизды, которые пишут обновы. Мне нужно эти обновы накатывать, перед этим делая бекап тех элементов, которые затрагиваются обновлением.
Как в это въехать по быстрому, что почитать? Может кто ссылку на статью/главу даст. В данный момент нужен именно этот минимум знаний, более подробно изучать буду уже потом.
Аноним 05/07/19 Птн 13:23:25 1428393221
>>1428371
О, Дима, привет)).
Если я угадал, то у тебя весь функционал уже есть.
А если нет - то пиши сборщик, который по имени файла из патча будет звать процедуру, которая текст пакета вытаскивает из бд и делай spool в файл бекапа.
это если из sqlPlus будешь ставить патчи.
Аноним 05/07/19 Птн 13:32:05 1428397222
>>1428393
>О, Дима, привет)).
Это не я.
Аноним 05/07/19 Птн 14:52:55 1428418223
>>1428397
"Райдер, опять ты
Нет, это не я!"

Бтв раз не ты, то окей.
Короче, простая схема: вот есть у тебя патч (архив, ветка в гите или ещё какое изъебство). Ты пишешь прогу, которая формирует из файлов патча скрипт для sqlPlus(т.е файл, в котором у тебя будут вызовы выполнения файлов патча) в определенном порядке(например, DDL до DML), а в этой проге проверяешь, что если тебе встретился пакет/функция или что-то в этом роде, то ты перед выполнением файла из патча включаешь спул, достаешь текст этого объекта(он попадет в указанный в спуле файл) и выключаешь спул.
Вот тебе простой бэкап. Если ты особо извращенец - повесь триггер на DDL, чтобы текст старого объекта записывался в таблицу бэкапа + была запись в таблице логов.
Аноним 12/07/19 Птн 13:16:11 1433168224
Привет, ребятки.
Есть кто по сфинксу?
Можете пояснить как в sphinxql заставить работать select distinct так же как в mysql?
Версия 2.2.11
Аноним 15/07/19 Пнд 01:02:21 1435414225
Анонасы!
Тупой вопрос из разряда "читай документацию", но все же, может, кто-то от доброты душевной ответит.

Таблица с записями с группировкой по полю Х.
a varchar,
b number
x number

(например: x - ид сотрудника, b - месяц, a - оценка работы)

Как взять такие записи по max(b) group by x, у которых В МАКСИМАЛЬНОЙ ПО b записи a like '%zaebal%'?
(т.е. взять только таких сотрудников, которые в последний месяц заебали всех)

Как это сделать без подселектов.
С подселектом любой дурак сделает.

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

Короче, можете издеваться сколько влезет, только ответьте, как сделать одним селектом (может оконные/аналитические функции?)
Аноним 15/07/19 Пнд 09:09:47 1435460226
>>1435414
>max(b) group by x
это значит в последний месяц для каждого работника иль чо?
Аноним 15/07/19 Пнд 09:57:22 1435503227
Аноним 15/07/19 Пнд 17:02:01 1435983228
>>1435460

>это значит в последний месяц для каждого работника иль чо?
да, там же написано дальше:
>т.е. взять только таких сотрудников, которые в последний месяц заебали всех)
Аноним 15/07/19 Пнд 17:02:20 1435985229
>>1435503
Нет.
Надо было БЕЗ ПОДСЕЛЕКТОВ :)
С подселектами я и сам с усам.
Аноним 15/07/19 Пнд 17:05:35 1435991230
>>1435985
cte не подселект ващет )
Аноним 15/07/19 Пнд 18:01:42 1436067231
Аноним 15/07/19 Пнд 18:33:27 1436110232
>>1435991
Ну, даже не знаю, что тебе на это и ответить.
Давай, чтобы не было лишних споров, я переформулирую:
слово SELECT во всем запросе должно быть только одно
Более того, во From должна быть только одна таблица только один раз

Я подозреваю, что это так не сделать. Но я дремучий папуас среди специалистов, вся надежда на это.
Аноним 15/07/19 Пнд 21:59:11 1436327233
>>1436110
Честно, не знаю, как тебе именно помочь с таким условием, но попробуй поиграться с cube и rollup, вдруг там отыщешь нужное тебе. А если это oracle, то можешь изъебнуться с model.
Проблема в том, что вышеупомянутые расширения группировки, скорее всего, в плане запроса будут использовать union all и разные группировки в каждом из запросов - та же работа rollup, если мне не изменяет память, так и описывается. То есть, строго говоря, одним селектом это не будет.
Аноним 16/07/19 Втр 02:13:07 1436508234
Анон, привет, куда можно податься pl/sql девелоперу в Спб?
По уровню околомиддл.
Аноним 16/07/19 Втр 15:55:40 1436819235
>>1435414
СУБД какое?
С помощью АНСИ с одним селектом сделать это довольно сложно, но я вижу вариант сделать это в оракл.
Аноним 16/07/19 Втр 18:56:03 1436982236
>>1436819
Давай оракл
Я оттуда подумаю, в чем цимес
Прям ща Постргес, так что почти оракл
Но я надеялся, что я просто проебал новшества в анси (я оконные функции, например, только пару месяцев назад по диагонали проглядел, хотя ебашу много лет).
С другой стороны, это ж значит, что я все правильно понимаю. Хотя задача настолько очевидная, что странно, почему к ней еще не прикрутили простое решение
Аноним 17/07/19 Срд 09:53:39 1437393237
БД.JPG (145Кб, 1159x574)
1159x574
Анончики, может кто оценить лабораторную? Что поменять, чтобы потом не охуеть, когда нужно будет пилить из этого курсач с приложением? Есть требование к числу сущностей, а с фантазией и представлением работы поликлиники трудно, так что как уж вышло.
Аноним 17/07/19 Срд 10:37:14 1437415238
Первый раз использую базу данных в приложении.
Мне нужно, чтобы пользователь выбирал какое-то большое количество параметров (у каждого параметра выбор да/нет). Параметров около 1000. Как лучше это хранить и реализовать? Я подумал, что нужно делать такую таблицу
ИмяПользователя - 0011100... где 1 или 0 выбор параметра.
А отдельно хранить список параметров с соответсвующими индексами.
Может есть лучше решение?
Аноним 17/07/19 Срд 10:49:10 1437422239
>>1437393
Обращение-Прием 1:1 - супер-спорно ) Причем анализы едут от обращения, а диагноз от приема

Занимаемая должность - Должность как минимум сбивает с толку. К тому же ставка привязана к кабинету по факту, а не к реальной должности

ну и График. предполагается, что у тебя люди приходят только в нужные дни с Х до У? смену сочинить бы е-маё

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

>>1437415
[Пользователи] 1:М [Парамерты пользователей] М:1 [Параметры]
Аноним 17/07/19 Срд 11:33:28 1437449240
>>1437393
А VBA разве может понять строки с пробелами?
Аноним 17/07/19 Срд 11:48:46 1437459241
>>1437422
>Обращение-Прием 1:1 - супер-спорно )
Да, с этим соглашусь, ошибочка, пациент вполне может записаться к нескольким врачам.

>Причем анализы едут от обращения, а диагноз от приема
А это непонятно. Ну, как бы, пациент обращается и идет либо к врачу (прием), либо на анализы (они же необязательно врачом на приеме назначаются). Диагнозы ставятся врачом на приеме. Пока не доходит, на какую ошибку ты указываешь

Над остальным покумекаю.

>>1437449
Если обрамить квадратными скобками - вроде как да.
Аноним 17/07/19 Срд 11:57:59 1437465242
>>1437459
я не совсем понял, что ты хотел описать как "Обращение", а что как "Прием". с одной стороны там все можно залить в одну сущность, с другой есть нюансы.
ну вообще обращение оно не всегда линейное. я вот пришел к терапевту потому, что голова болит (считай, обращение началось еще до приема), терапевт посмотрел (прием раз), отправил к хирургу (прием 2.1) и патологоанатому (прием 2.2) (а это все то же обращение, но не точечное во времени, очевидно), они еще куда-то отправили, плюс накидали анализов. причем, кто-то посередине не может поставить никаких диагнозов пока не пришли ответы из направлений.
Аноним 17/07/19 Срд 12:36:31 1437499243
>>1437422
>[Пользователи] 1:М [Парамерты пользователей] М:1 [Параметры]
Но ведь тогда вторая таблица получится сверх большая. Каждый новый пользователь будет увеличивать её на 1000 строк (это если параметров только 1000). Если количество пользователей будет большим, пиздец же случится, не?
Аноним 17/07/19 Срд 12:59:17 1437519244
>>1437499
пару лямов строк любая хоть сколько-нибудь серьезная СУБД отработает без больших проблем. тебе же не SELECT * FROM делать, предполагается, что ты еще и использовать будешь адекватно таблицу.
разделение параметров по колонкам (в одном физическом аттрибуте или по каждому на один параметр) сверх-сильно усложняет поддержку такого решения.
если ты сможешь сгруппировать параметры каким-либо образом и выделить нечто вроде:
[Пользователи] 1:М [Параметры пользователей 1] М:1 [Параметры_1]
[Пользователи] 1:М [Параметры пользователей 2] М:1 [Параметры_2]
[Пользователи] 1:М [Параметры пользователей 3] М:1 [Параметры_3]
будет попроще, но это такое себе решение, я бы ниадобрил
Аноним 17/07/19 Срд 13:03:51 1437523245
Аноним 17/07/19 Срд 19:21:08 1437757246
>>1435414
Дай пример с данными.
Как есть и как должно быть.
Аноним 17/07/19 Срд 21:02:09 1437853247
>>1435414
Есть вариант сделать в анси
select x, max(b)
from table_pr
group by x
Having max(b) = max(case when a = 'zaebal' then b else null end);

Но, в таком случае b - не всегда будет текущим месяцем, а максимальным для каждого сотрудника, если я правильно понял, это то, что тебе нужно
Аноним 17/07/19 Срд 21:03:00 1437856248
Аноним 17/07/19 Срд 23:47:22 1437997249
>>1435414
Я и забыл совсем и про model тебе что-то говорю.
Это же max keep, ёпта. А в ордер бай пихаешь кейс, в котором a like '%zaebal%' даёшь единичку, а остальному - null. И тогда у тебя выберется максимум для именно таких значений a.
Аноним 18/07/19 Чтв 01:08:15 1438034250
Аноним 18/07/19 Чтв 04:51:01 1438057251
Screenshot20190[...].jpg (38Кб, 1719x889)
1719x889
У меня в задании курсовой образуется замкнутыц цикл в отношениях сущностей (нужно создать бд по заданным таблицам т.е. добавлять своё нормас, а убирать что-то - не круто). Так вот с этим циклом сижу мучаюсь уже сколько всего перечитал так толком и не въехал, кажется, будто препод троллирует. Суть - составить расписание занятий, выглядит примерно так. С телефонп накалякал
Долго бьюсь над тем как все организовать, подкиньте почитать про то что цикличность это круто и тд или хотя бы пару идей как организовать. Мозговой шторм иссяк на идеях сделать последнюю таблицу неким расширением второй, но тогда это будет уже один ко одному, а по заданию один ко многим отношения везде
Аноним 18/07/19 Чтв 08:56:20 1438083252
>>1438057
а ты уверен, что он образуется?
я вот вижу какую-то каракулю в пэинте и честное слово, что все именно так
Аноним 18/07/19 Чтв 13:46:02 1438164253
>>1438057
>У меня в задании курсовой
Сейчас же лето. Нахуй ты делаешь курсач?
Аноним 18/07/19 Чтв 14:26:28 1438180254
ZAxJnJ1O43M.jpg (34Кб, 659x234)
659x234
>>1438164.
>>1438083
Проебался в срок, да не суть
Выглядит вот так в задании
Аноним 18/07/19 Чтв 14:29:15 1438185255
>>1438180
А нахуй тебе вообще универ нужен?
Аноним 18/07/19 Чтв 14:35:53 1438189256
>>1438185
Чтобы хоть чего-то добиться скорее всего. Плюсом какие-то основы и корочка
Аноним 18/07/19 Чтв 14:39:13 1438193257
>>1438057
Подожди, у тебя задание с ебанутым требованием подделать под определенную схему отношений?
Аноним 18/07/19 Чтв 14:42:04 1438196258
>>1438189
Ты ничего не добьёшься, имея только корочку.
По моему субъективному мнение тебе подобных из высшего заведения нужно выкидывать, поэтому я тебе принципиально не буду помогать.
Аноним 18/07/19 Чтв 14:43:44 1438199259
>>1438193
Задание может и нормальное составить расписание вуза и сделать запросы на свободные аудитории и т.д., но как раз его и надо подстроить под схему, которая и кажется ебанутой
Аноним 18/07/19 Чтв 14:45:47 1438200260
>>1438199
>но как раз его и надо подстроить под схему
Ну так это же и есть часть задания
Аноним 18/07/19 Чтв 14:46:23 1438201261
>>1438196
>тебе подобных
Это каких?
Аноним 18/07/19 Чтв 14:49:00 1438204262
>>1438196
Надеюсь ты не прав, все же специальность интересная и хотелось бы закончить, а не вылететь
Аноним 18/07/19 Чтв 14:49:54 1438206263
>>1438180
пиздец лол
ну ладно, а вопрос в чем? цикличные связи - это в общем не то, чтобы плохо, это странно по меньшей мере. но в твоем случае это норм потому, что задания другого нет. только цимес в том, чтобы Table2->Table4 или Table3->Table2 были по факту 1:[0..1/M]. иначе ты ни строчки не вставишь в базочку возможно, в транзакции так можно изъебнуться, но я сомневаюсь
Аноним 18/07/19 Чтв 14:52:15 1438209264
>>1438200
На твой взгляд со стороны тебе не кажется схема ебанутой? Сколько бы не рыл интернеты и русские и ангельские везде в основном проблемы вида "у меня цикл в бд и т.п., как это исправить?" Если же это нормальное явление, сразу же съебу
Аноним 18/07/19 Чтв 14:54:14 1438211265
>>1438206
Да, все вопрос был в том является ли цикличность чем-то нормальным вообще. Спасибо, анон, буду изощряться
Аноним 18/07/19 Чтв 14:57:52 1438215266
>>1438201
Это долбаёбов, которые просирают сроки сдачи курсачей и не в состоянии самостоятельно лог. схему спроектировать.
Аноним 18/07/19 Чтв 14:59:45 1438216267
>>1438215
Вопрос был не в проектировании а в явлении цикличности в отношениях между таблицами в бд. Нормальная ли тема это где можно по этому поводу инфы нарыть
Аноним 18/07/19 Чтв 15:00:06 1438218268
>>1438209
Мне кажется ебанутой сама идея задания подстраивать что-либо под какие-либо схемы, а не строить самому, про схему я вообще ничего не говорил.
Аноним 18/07/19 Чтв 15:02:23 1438220269
Хочешь или нет - это твой вариант задания, значит так положено, так что зачем разбираться?
Аноним 18/07/19 Чтв 15:04:13 1438222270
>>1438211
как бы если тебе придется хранить граф в базе данных, то цикличность станет привычным вопросом. фишка в том, что для графов есть свои хранилища, зачастую, более эффективные, чем реляционка.
на практике такое можно встретить в иерархических данных, типа, организационная структура компании или что-то вроде этого.
Аноним 18/07/19 Чтв 15:04:14 1438223271
>>1438220
Потому что в целом интересно как такое применяется и применяется ли вообще
Аноним 18/07/19 Чтв 15:05:40 1438224272
>>1438216
>Нормальная ли тема
Нет, но иногда она вполне имеет место быть.
Например, в бух. учете, связь между дебетом и кредитом вполне может быть цикличной.
Аноним 18/07/19 Чтв 19:46:13 1438422273
>>1438224
Вы как-то по-особенному понимаете цикличность, я гляжу.
Аноним 19/07/19 Птн 08:54:29 1438645274
Поясните за ";" и "/" что, когда используется? Почему например в pl/sql developer скрипт может пройти без ошибки, а в sql navigator поругается на слэш или точку с запятой?
Аноним 19/07/19 Птн 17:19:24 1438960275
>>1438645
; - конец блока, / - конец команды.
Скорее всего, прошло от того, что sql*plus должен как-то понимать, какой enter - это перевод строки, а какой - сигнал на выполнение, вот и / воспринимается как символ конца потока.

Всегда используй ;. Но если у тебя pl/sql блок - то заканчивай его /, чтобы следующий выполнился.
Аноним 19/07/19 Птн 19:41:15 1439061276
Есть таблица (table), структура/данные следующие:
А - 100
А - 200
А - null
B - 100
B - 300

Как сделать запрос, который выдаст макс по первому столбцу, если там нет значений null, иначе выдаст null.
Аноним 19/07/19 Птн 19:41:40 1439062277
>>1439061
Т. е.
Результат:
A-null
B-300
Аноним 19/07/19 Птн 19:56:44 1439069278
>>1439062
Забиваешь этот вопрос в гугл и выбираешь в выдаче ответы, подходящие к твоей субд
case используй
Аноним 19/07/19 Птн 20:16:00 1439083279
>>1439069
Что мне в гугле ввести, лол?
Я минут 40 эту ерись писать пытался.
Пока в голову пришло только ето:
with a as
(select t1, max(t2) m_t2
from table
group by t1)
select distinct a.t1,
case
when table.t2 is null then table.t2
else max(t2)
from a, table
Но это не правильно, т.к. результат будет =>
A-200
A-null
B-300
Как это фиксить?
Аноним 19/07/19 Птн 20:16:26 1439084280
>>1439083
>else max(t2)
Тут end проебал.
Аноним 19/07/19 Птн 20:20:28 1439089281
>>1439083
И в конце
where table.t1 = a.t1
Аноним 20/07/19 Суб 00:23:32 1439209282
>>1439083
max keep + respect nulls в сортировке - и проблемы нет.
Аноним 20/07/19 Суб 00:24:47 1439211283
>>1439209
>respect nulls
nulls first, конечно же
самофикс
Аноним 20/07/19 Суб 01:49:26 1439232284
Аноним 20/07/19 Суб 02:05:40 1439238285
>>1439232
> я бы, на твоем месте
Ок, бро, я к твоему совету обязательно прислушаюсь.
Аноним 20/07/19 Суб 11:56:58 1439328286
Я джавист, хочу изучить что-нибудь фундаментальное, просто чтобы лучше понимать, что происходит внутри. Например, Serializable в InnoDB pessimistic lock с блокировкой выборки на апдейт, а в Postgres - optimistic с ошибкой при коммите. Хз, что за это отвечает, как это вообще гуглить
Для такого Дейт подойдёт?
Аноним 20/07/19 Суб 13:16:25 1439348287
>>1439061
Select
t1,
Case
when Max(case when t2 is null then 1 else 0 end) = 1
then null
else max(t2)
end
From table
Group by t1
Аноним 20/07/19 Суб 17:20:35 1439531288
>>1439348
Блядь, ты ему еще лабы сделай.
Аноним 20/07/19 Суб 17:46:02 1439549289
изображение.png (144Кб, 1773x737)
1773x737
изображение.png (12Кб, 462x457)
462x457
Что не так с этим запросом?
Задание:
Для каждого производителя, у которого присутствуют модели хотя бы в одной из таблиц PC, Laptop или Printer,
определить максимальную цену на его продукцию.
Вывод: имя производителя, если среди цен на продукцию данного производителя присутствует NULL, то выводить для этого производителя NULL,
иначе максимальную цену.
Аноним 20/07/19 Суб 17:46:39 1439551290
>>1439531
Хули ты агрессивный такой?
Аноним 20/07/19 Суб 18:12:10 1439572291
Аноним 22/07/19 Пнд 11:56:10 1440325292
>>1406455 (OP)
Часто в вакансиях сисадмина/линукс-инженера можно увидеть требования:
Апач/нгинкс, постфикс/довекот, бинд,
Субднейм/субднейм/субднейм.
На счёт последнего можете подсказать что учить надо?
Субднейм.орг/документейшн от корки до корки? Может знаете какой смысл они вкладывают это? Какая-то конкретика. (А то может они вкладывают в это поставить lamp, чтобы CMS встала за 5 минут)
Аноним 22/07/19 Пнд 12:07:22 1440333293
>>1440325
Субд надо на случай внесения оптимизаций. Ну чтобы запросы вместо 1с выполнялись за 0.0001 пикосекунды. Репликации, бэкапы, апгрейд бд. Выполнять в ручную какие-нибудь запросы, перезагружать демон бд на худой конец.
Аноним 22/07/19 Пнд 12:11:48 1440335294
f
Аноним 22/07/19 Пнд 19:08:36 1440562295
Я правильно понимаю, БД - такой способ хранения информации на диске, если у Вас concurrency-головного-мозга?
Аноним 22/07/19 Пнд 22:30:25 1440703296
>>1439551
Отвечая на такие вопросы, ты поощряешь долбоебов все больше и больше лезть сюда.
Скоро будут приходить с вопросами, как жопу вытирать
Мне это не нравится, вот и агрессивный.
Аноним 22/07/19 Пнд 22:34:02 1440707297
>>1440325
Уметь поставить, забекапить, сконфигурить, реплицировать (хуй знает, надо или нет), засекьюрить.
Выдать юзерам (от дба до разработчика хуйни на жумле) доступ, чтобы они не ныли "аааа, у меня программа не видит БД"
Если кто-то от тебя будет ожидать умения писать селекты и их же потом оптимизировать, можно смело слать в жопу.
Аноним 22/07/19 Пнд 22:34:49 1440708298
>>1440562
Нет.
Никто не мешает тебе иметь БД в памяти.
Теперь попробуй еще каки-нибудь искрометно пошутить.
Аноним 23/07/19 Втр 00:20:11 1440776299
>>1440708
>пошутить
В мыслях не было. Пытаюсь прояснить.
>Никто не мешает тебе иметь БД в памяти.
Вопрос не о "можназделоть", а о цели.
23/07/19 Втр 01:58:51 1440790300
>>1440703
узбагойся, в этом и суть треда, чтобы "всякие долбоебы" сюда приходили.
Аноним 23/07/19 Втр 15:57:38 1441013301
acdd40d295365a2[...].jpg (47Кб, 660x496)
660x496
Ай нид хелп. Ищу ПО, желательно свободное для создания библиотеки документов, с возможностью редактирования этих документов и сетевым доступом.
Имеется следующая задача:
Есть ряд однотипных документов, порядка 500-600, в виде таблиц. Отличаются только содержимым этих таблиц. Нужно эти документы каталогизировать и иметь возможность осуществлять поиск по номеру этого документа. Находим в каталоге нужный документ, и в этом же ПО редактируем эту таблицу. Никаких картинок, тупо текст. Доступ к редактированию документа по логину и паролю.
Всякие навороченые гиганты типа Битрикса не нужны. Надо, что то маленькое и функциональное.
Есть что предложить?
Аноним 23/07/19 Втр 19:21:49 1441128302
image.png (7Кб, 453x135)
453x135
помогите понять то что записано в регулярном выражении, запрос меняет в
произвольной строке два и более встречающихся пробелов на один
with t as (
select ' a b c ' str from dual
)
select str ,
regexp_replace(str,'( +$)|((^| ) +)','\3') as r
from t
'( +$)|((^| ) +)' здесь указаны все варианты пробелов в строке
((^| ) +) - (если в начало строки или пробел) пробел входит больше одного раза) ?
'\3' - что это?
из определения не особо понять
\n n представляет собой число от 1 до 9. Соответствует n-му подвыражению находящемуся в ( ) перед \n.
Аноним 23/07/19 Втр 23:46:25 1441282303
Аноним 23/07/19 Втр 23:48:33 1441283304
Аноним 24/07/19 Срд 00:04:14 1441289305
>>1441128
https://regex101.com/
Сходи туда, чтобы не быть баттхертом.
Там каждый чих поясняется.

Но в целом это означает "все пробелы в начале или (читай "а заодно и") пробелы в конце строки".

\3 означает третье вхождение из всех найденных

короче, хули ты такой тупой, что не можешь выполнить запрос и посмотреть, что получается?
Аноним 24/07/19 Срд 08:06:48 1441386306
image.png (2857Кб, 2048x1074)
2048x1074
>>1406481
Ты под чем эту схему рисовал? Сделай связи аккуратно, с минимумом пересечений.
Аноним 24/07/19 Срд 18:09:59 1441754307
>>1441289
Я в курсе что это третье вхождение из всех найденных. И запрос тыкал
КАКОГО ХУЯ ТРЕТЬЕ ТО ИМЕННО
Вот в чем вопрос
Аноним 24/07/19 Срд 18:35:08 1441763308
>>1441128
А почему не regexp_replace(str, '\s{2,}', ' ')?
Это не третье вхождение, это третья подгруппа выражения, в данном случае - пробел.
Вот он и меняет все, что подходит под паттерн(сиречь два и более пробелов) на один
Аноним 24/07/19 Срд 19:34:46 1441787309
Аноним 25/07/19 Чтв 20:10:45 1442478310
Анон, привет, помогай-выручай.
Есть задача: логировать изменения отдельных атрибутов сущностей с которыми работает пользователь. С точки зрения пользователя выглядит так: открывается форма с атрибутами сущности, редактируются сущности, пользователь жмет "ОК" и, в случае изменения значений некоторых реквизитов, должна появляться еще одна форма, на которой пользователь выбирает причину изменений.Если от выбора отказывается, то изменения не сохраняются.

Причем БД? При том, что архитектура двухзвенная и при нажатии на "ОК" данные сохраняются в БД.
Тут вроде бы по классике можно создать триггер, но это решит проблему логирования изменений, но логирование и обновление экземпляра сущности должно происходит только после указания пользователем причины.
Как подойти к решению этой задачи?
Аноним 25/07/19 Чтв 20:52:10 1442499311
>>1442478
А ты не знал, что коммитить можно не только после DML?
Аноним 25/07/19 Чтв 21:55:49 1442544312
>>1406455 (OP)
Стоит в SQL Server вкатываться сейчас? На работе предлагают перейти и обучить. Чет в /б/ говорят, что эта вся хуйня уже устарела и со временем сойдёт на нет.

мимо-джун-фронтэнд
Аноним 25/07/19 Чтв 22:47:20 1442563313
>>1442499
Знал, более развернуто, пожалуйста, поясни.
Аноним 26/07/19 Птн 00:03:16 1442628314
>>1442478
>Причем БД? При том, что архитектура двухзвенная и при нажатии на "ОК" данные сохраняются в БД.
Сделай, чтобы было не так.
Хули ты как маленький?

Триггеры и сложные схемы коммитов - решение неудачное. Потому что потом хуй найдешь, что у тебя в какой момент срабатывает, и почему.
Вообще хуярить в базу надо только после того, как у тебя ВСЯ информация уже есть.
Иначе у тебя будет транзакция неизвестной длины, и все такое.

Не будь мудаком, короче, сделай нормально сразу.
Аноним 26/07/19 Птн 00:04:18 1442631315
>>1442544
Правильно говорят в /б.
Продолжай кнопки рисовать на аяксе.
Аноним 26/07/19 Птн 01:52:21 1442678316
>>1442563
Имеется в виду, что нужно либо написать так, либо поправить (если есть), чтобы коммит был не сразу после инсерта/апдейта, а после поверки на корректность.
Аноним 26/07/19 Птн 11:03:11 1442737317
>>1440776
>а о цели
Хранить большие объемы данных из которых надо быстро вытаскивать объемы поменьше?
Аноним 26/07/19 Птн 11:24:13 1442746318
>>1442737
Как этому помогает СУБД? Ускоряет работу диска? Или объём его увеличивает?
Аноним 26/07/19 Птн 11:25:42 1442748319
>>1442746
Да.
Теперь иди нахуй.
Аноним 26/07/19 Птн 11:47:07 1442762320
>>1442746
СУБД помогает это структурировать.
Давай рассказывай как ты без субд будешь копаться в условном ляме текстовиков каждый из которых хранит по 5-10 условных строчек инфы.
Аноним 26/07/19 Птн 11:49:23 1442765321
>>1442762
Просто и без задней мысли, ты же программист.
Аноним 26/07/19 Птн 11:53:42 1442767322
>>1442762
>как ты без субд будешь копаться в условном ляме текстовиков каждый из которых хранит по 5-10 условных строчек инфы
100500 способов. inb4 все они и есть СУБД, заведомо. Всё хорошее назовём СУБД. Остальное - не СУБД. Ага.
Аноним 26/07/19 Птн 11:54:55 1442768323
>>1442765
Вот теперь точно иди нахуй.
Аноним 26/07/19 Птн 11:59:01 1442771324
>>1442767
>100500
Школодебил, ты?
Да, ты.
>>1442768
Ебать ты медленный, конечно.
Аноним 26/07/19 Птн 12:10:32 1442779325
>>1442771
>Школодебил, ты?
Ты о чём, вообще?
Аноним 26/07/19 Птн 12:12:20 1442780326
>>1442779
Мало того что он школьник - так еще и тупой тавтология, хаха
Аноним 26/07/19 Птн 12:14:40 1442782327
>>1442780
Нет. Не школьник. к сожалению, наверно С чего ты взял. И какое это имеет значение?
Аноним 26/07/19 Птн 12:28:12 1442787328
>>1442782
С того, что ты тупое быдло.
Очевидно же.
Аноним 26/07/19 Птн 12:30:13 1442788329
Аноним 26/07/19 Птн 19:09:51 1443049330
>>1441763
я так и написал в итоге ( и изначально). Просто почему-то именно это решение все хвалили на sql.ru...
З.Ы тут есть разрабы бд или близкие к ним, шарящие в sql и немного и в[ b]pl/sql[/b]? А то я тут тестовое сделал (не сложное), отправил, должны были сегодня ответить до конца дня как сказала эйчарка, но нихуя не ответили. Хочу в общем чтобы кто-нибудь из бывалых посмотрел мое решение, неужели там все так плохо @heheloh - можно сюда писать ну или в тред
Аноним 26/07/19 Птн 21:45:24 1443129331
>>1443049
Там я только забыл trim, чтобы удалить пробелы в начале и конце строки.
Там такое решение, я думаю, чтобы именно регуляркой убрать все, как бы показать свои умения. Но зачем так усложнять - не знаю.
Присылай, я разраб на pl/sql, глянем, чего у тебя там.

А если не звонят, то позвони сам, хули - это нормально.
Аноним 26/07/19 Птн 22:35:43 1443157332


>>1443129
Кинь Контакты какие нибудь я тебе скину файл
Аноним 27/07/19 Суб 16:15:19 1443439333
Аноним 28/07/19 Вск 00:24:27 1443660334
>>1442767
Приведи три способа из 100500 хотя бы, как можно в многопользовательском приложении/сайте работать с данными на чтение/изменение/удаление/добавление, не используя субд,а то пока что складывается ощущение, что ты обычный тралл.

Аноним 28/07/19 Вск 04:41:11 1443694335
>>1443660
>в многопользовательском приложении/сайте
Всё же concurrency-головного-мозга? А если нет concurrency, то и в СУБД смысла нет? Я, ведь, это и предполагал.
Аноним 28/07/19 Вск 04:59:07 1443698336
>>1443694
Да, да. Все так.
Тебе не нужно. Не мучай жопу.
Аноним 29/07/19 Пнд 20:01:51 1444545337
>>1443694
Жопой сманеврировал как портовая шлюха, а примеров так и нет.
Аноним 29/07/19 Пнд 23:07:07 1444698338
>>1406455 (OP)
Есть ли задачники с ответами по разработке СУБД?
1) Например, разработать примитивную ER модель и в конце расписывается верное рассуждение и диаграмма. Как такое гуглить?
2) Есть ли годный материал по моделированию данных/мат моделированию на русском?
Аноним 01/08/19 Чтв 06:09:01 1445783339
image.png (3Кб, 239x79)
239x79
Помогите дебилу
Нужно получить все детали заказа, заменив названия столбцов на их порядковый номер
Я разобрался как переименовывать столбцы (пикрил)
А как вывести с нумерацией но в таблицу изменения не вносить?
Аноним 01/08/19 Чтв 09:38:14 1445818340
Аноним 01/08/19 Чтв 09:50:18 1445822341
>>1445783
Еееебать.
Погугли алиасы. Я крайне сомневаюсь, что тебе необходимо было вносить любые изменения в таблицу.
Аноним 01/08/19 Чтв 18:48:45 1446103342
Пытаюсь перенести базу данных с локалки на mongo atlas

Создал dump, пытаюсь передать его через команду mongorestore

mongorestore --host pricingtoolcluster-shard-0/pricingtoolcluster-shard-00-00-u2jv8.mongodb.net:27017,pricingtoolcluster-shard-00-01-u2jv8.mongodb.net:27017,pricingtoolcluster-shard-00-02-u2jv8.mongodb.net:27017 --ssl --username admin --password <PASSWORD> --authenticationDatabase admin

пишет Failed: error connecting to db server: no reachable servers

Кто-нибудь сталкивался?

У меня похожая проблема с npm. Могу скачивать пакеты только через прокси (tor bundle)
Аноним 01/08/19 Чтв 20:26:34 1446150343
v5sGZ8Gb8CE.jpg (73Кб, 585x600)
585x600
Аноним 02/08/19 Птн 00:03:35 1446299344
>>1446103
Ахахахахаха

>реляционки не нужны!
>sql - говно
>поцаны, я не осилил, как свою модную базу перенести

Ожидаемо.
Аноним 02/08/19 Птн 06:56:43 1446366345
>>1446103
Может у тебя dns не настроен?
Аноним 03/08/19 Суб 03:20:50 1447170346
>>1446366
Инет нормально работает (если не считать проблем с вышеперечисленным)
Аноним 03/08/19 Суб 04:02:41 1447178347
>>1447170
Раз днс работает нормально, может, в днк проблема?
Аноним 05/08/19 Пнд 13:36:09 1448381348
>>1406455 (OP)
Друзья, почему шапка не ньюби-френдли?

Вкатываюсь в погроммизды (c# web), пока учебники полистываю и задачки порешиваю, хотелось бы получить основательную базу по БД, а тут нихуя нет=((

Посоветуйте годноты, чтобы сразу получить фундаментальные знания и навыки: от простого к сложному. (P.S: заумные толстенные учебники на ангельском приветствуются)
Аноним 05/08/19 Пнд 16:36:56 1448476349
>>1448381
>Посоветуйте годноты
google.com
Аноним 05/08/19 Пнд 19:22:13 1448547350
>>1406455 (OP)
Что обычно подразумевается под пунктами "продвинутое знание sql" и "proficient in sql" в вакансиях дата саентиста/инжинёра?
Аноним 05/08/19 Пнд 21:05:16 1448589351
>>1448547
Знания аналитических функций, думаю, будет достаточно для дата сайнтиста.
Если их знаешь, то все остальное, связанное с селектами, тоже наверняка знаешь.
Аноним 06/08/19 Втр 14:33:16 1448886352
>>1448381
Сергей Тарасов. СУБД для программиста. Хороша для ознакомления с предметом, список литературы в конце неплох.
Аноним 06/08/19 Втр 19:59:26 1449086353
Аноним 08/08/19 Чтв 16:23:45 1449868354
Реально найти удаленную работу на PL/SQL?
Аноним 09/08/19 Птн 00:53:25 1450186355
>>1449868
Очень даже. Правда обычно это либо от 3+ лет опыта, либо будешь получать штук 60-80
Аноним 09/08/19 Птн 00:57:13 1450187356
>>1444698
Такого нет. Можешь проектировать базу на любую предметную область и сюда ERD на проверку кидать. В чем проблема? Я помогу
Аноним 09/08/19 Птн 21:12:29 1450649357
>>1406455 (OP)
Откуда можно скачать бигдату финансовых рынков?
Аноним 10/08/19 Суб 16:12:22 1450911358
>>1448589
Есть чего-нибудь почитать по ним? Понятным языком.
Аноним 10/08/19 Суб 18:00:02 1450966359
Аноним 12/08/19 Пнд 02:21:09 1451752360
Пасаны, если у меня запрос содержит фрагмент типа "where object.id in (select object.id from object where ...)", то нужно ли мне во вложенном запросе писать ORDER BY id? Я не очень шарю в выборке типа IN, поэтому мне непонятно, вырастет ли производительность при сортировке, или наоборот упадёт из-за ненужной сортировки.
Аноним 12/08/19 Пнд 11:17:34 1451811361
>>1451752
Открой планировщик запроса и посмотри как будет с ордером и без.
Аноним 13/08/19 Втр 10:23:33 1452239362
db.jpg (30Кб, 1034x218)
1034x218
Уважаемые знатоки, подскажите пожалуйста:
Есть список сотрудников и список оборудования. Нужно построить модель БД, так чтобы по каждому сотруднику можно было посмотреть какое оборудование находится у него на балансе в текущий момент, и какое было раньше. Когда он его получал, и когда сдал назад.

Сперва я думал что получится что-то типа пикрил, но теперь сомневаюсь. Ведь тогда получится что один сотрудник не может брать одно оборудование два раза. Типа взял, попользовался, сдал. Потом взял еще раз. Или я ошибаюсь?

Мудрые аноны, подскажите как правильно сделать?
Аноним 13/08/19 Втр 11:02:52 1452259363
>>1452239
Либо добавь в первичный ключ дату получения девайса, либо сделай таблицу с актуальным состоянием(сотрудник-девайс-когда получил) и с историей(сотрудник-девайс-когда получил-когда отдал) и после регистрации возврата переноси строчку из актуальной в историческую.
Первый вариант - то же самое, что и историческая таблица во втором, но после того как твоя бд и история разрастется до лютых размеров, очень долго будешь искать текущее состояние.
Аноним 13/08/19 Втр 11:22:53 1452269364
>>1452259
Спасибо огромное! Насчет первого варианта понял, а вот насчет второго не очень если честно.
Если тебе не трудно, не мог бы ты нарисовать как это выглядит в плане связей и ключей? Я просто первый раз сталкиваюсь с БД где больше двух таблиц с типичными связями и мой мозг никак не хочет это воспринимать.
Аноним 13/08/19 Втр 16:20:38 1452462365
>>1452259
Правила буравчика: всегда использовать суррогатные ПК.
Сегодня тебе кажется, что в качестве ПК можно использовать атрибут данных, завтра окажется, что он подвержен изменению или не уникален.
В крайних двух таблицах ты так и сделал.
А в средней - нет.
Не еби мозги, сделай в ней суррогатный ПК
Правила оформляй индексами и триггерами (ща наверняка еще подскажут, чем)
Аноним 14/08/19 Срд 20:56:06 1453441366
Есть табличка
id(PK), c1, c2(NN), c3(NN)
мне нужно найти дубли, совпадающие по c1 и c2, но отличающиеся по с3 и, естественно, id.
запрос я написал, но, мне кажется, пздц неоптимизированный

SELECT FROM mytable t1 WHERE
(SELECT COUNT(
) FROM mytable t2
WHERE t1.id != t2.id
AND (t1.c1 = t2.c1 OR (t1.c1 IS NULL AND t2.c1 IS NULL))
AND t1.c2 = t2.c2
AND t1.c3 != t2.c3
) > 0;

может кто нибудь посоветовать, как это оптимизировать?
если я разделю этот запрос на штук 30, в каждом сделаю WHERE c2 = some_const, и объединю их UNION ALL, это будет лучше для бд на проде? или я так просто еще больше загружу бд?
доверь джуну скл писать...
Аноним 14/08/19 Срд 21:57:20 1453469367
>>1453441
Да епту.
Select t1.звизда
From table t1
Where (t1.c1, t1.c2) in
(Select t2.c1, t2.c2
From table t2
Group by t2.c1, t2.c2
Having count(звизда) > 1);
Аноним 14/08/19 Срд 22:04:23 1453470368
>>1453469
Мне нужно обязательно шобы t1.с3 != t2.c3
Аноним 14/08/19 Срд 22:06:08 1453471369
Господа, а вы в курсе, что вся та инфа что мы сюда постим имеет не совсем конфиденциальный характер. Я почти уверен, что если Абу сильно попросят он отдаст все что угодно.
О ваших постах на двача может может знать ваш будущий hr, держу в курсе.
Аноним 14/08/19 Срд 22:18:21 1453480370
>>1453470
Тогда в подзапросе добавь джойн к самой себе по c1 и c2 и фильтр, где t2.c3 <> t3.c3.
Аноним 14/08/19 Срд 23:16:29 1453514371
>>1453471
>О ваших постах на двача может может знать ваш будущий hr
Да она, блядь, кончит фонтаном от моих постов.
Скорей бы.
Аноним 15/08/19 Чтв 07:20:48 1453595372
>>1453441


select id, c1, c2, c3
from (
select
a.,
count(case when first_c3 <> c3 then 1 end)
over (partition by c1, c2
order by c3
rows between unbounded preceding and unbounded following) as diff_c3
from (
select
mytable.
,
first_value(c3) over (partition by c1, c2 order by c3) as first_c3
from mytable
) as a
) as b
where diff_c3 > 0
Аноним 15/08/19 Чтв 11:45:32 1453679373
Почаны, в шапке нихуя нет, на ваших http://sql-ex.ru и http://www.sql-tutorial.ru сразу начинают с синтаксиса, а где все это тестить (если не брать консоль на сайтах), установка и настройка ms sql и прочие базовые вещи для вкатывальщиков где взять?
Аноним 15/08/19 Чтв 13:48:59 1453770374
>>1453679
В гугле забанен?

Чтобы тестить на, например, ms sql, тебе потребуется
- ms sql server developer edition
- sql server management studio
Аноним 15/08/19 Чтв 17:18:18 1453930375
Аноним 15/08/19 Чтв 17:19:26 1453932376
>>1453930
Ну это если кому консоль на сайтах подойдет.
Аноним 18/08/19 Вск 00:37:07 1455415377
Крч, устроился джуном на проект в бигдату.
Мой стек - python (написание ETL), mpp СУБД и один из ETL-фреймворков. Мне кажется, что проекты могут завершится, а бигдата как направление нужно лишь очень крупным компаниям, и у меня гораздо больше шансов полететь на улицу чем у рандомного фронтендера.
Насколько мои предположения правильны, и стоит ли вообще пытаться строить карьеру инженера данных?
Аноним 18/08/19 Вск 23:39:18 1455927378
Ребят, кто шарит в nosql бд? Я короче почитал про всякие и пришел к выводу, что Foundationdb самая пездатая, гибкая и все такое. Ща читаю по ней доки, сорцы. Оч хочу вкатиться в распределенные приложения в будущем, именно с этой бд. Только напрягает, что по ней одна вакансия всего на весь дс. В основном всякие кассандры, hbase и прочее говно мамонта. Скажите, велика вероятность, что ситуация изменится в ближайшем будущем? Учитывая, что порог входа для использования данной бд довольно высокий, т.к. по сути это очень сырое отсортированное key-value хранилище и нужно позалипать в доках недельку другую, чтобы разобраться, как с ним работать.
Аноним 19/08/19 Пнд 18:19:41 1456360379
У нас в базе в качестве ID записи вместо простого порядкового числа используется строка формата sha1. 
Олды говорят, что это дает равномерное распределение данных по кластеру в процессе хранения и обработки.
Как это понимать и для чего это нужно? Влияет ли это на скорость доступа или еще на что-то?
Аноним 19/08/19 Пнд 18:55:59 1456382380
>>1456360
Это в принципе правильное решение, потому что за счетчик айдишников обычно большая конкуренция в кластере. Как это вот все синхрогизировать, чтобы две записи с одинаковым ключом не сгенерились? Проще использовать UUID и проверять перед вставкой, чтотакого ключа в базе еще нет. С растущим интом такое тоже возможно, но в зависимости от степени конкуренции большая часть транзакций будет ретраится на этапе проверки, что такого ключа еще нет и производительность просто в 0 упадет.
Аноним 19/08/19 Пнд 19:37:46 1456457381
>>1456382
>Как это вот все синхрогизировать, чтобы две записи с одинаковым ключом не сгенерились
Ставим триггер на добавление в таблицу записи - храним переменную со сцетчиком и увеличиваем. Разве это все не решается на уровне базы?
>большая часть транзакций будет ретраится
Кажется я понял, спасибо, анан. Типо появится очередь за новым id'шником?
19/08/19 Пнд 20:42:03 1456563382
Подскажите как можно реализовать такую логику mysql. Есть таблица с полями id/user_id/token. При регистрации в этой таблице создается поле для пользователя. Если он решит выйти и снова авторизироваться, вместо новой записи в таблице должна обновляться старая запись. Я пробовал сделать это через
INSERT INTO t8rv0_mobile_tokens (user_id, token) VALUES (:user_id, :token) ON DUPLICATE KEY UPDATE user_id = values(user_id), token = values(token)
Но, видимо из-за того, что токены различаются, оно создает новую запись вместо обновления старой.

Так же вопрос. Сам объект пользователя сохраняется в другой таблице. Если я слинкую user_id двух таблиц, оно создаст мне записи под все id? Тогда можно было бы заменить INSERT на UPDATE и пофиксить проблему
Аноним 19/08/19 Пнд 21:13:02 1456607383
>>1456457
Мы вообще сейчас о распределенной бд говорим? Если нет, то это действительно просто и решается на уровне базы (по сути обычный AtomicInteger). В распределенной бд все сложнее намного. Нужна либо лочка по счетчику (а для этого нужен консенсус, который сильно бьет по производительности), либо optimistic concurrency control, который и будет ретраить большую часть транзакций. Допустим у тебя 20 транзакций одновременно вставляют строку в базу, только одна из них пройдет. Потом из 19 только одна пройдет и т.д.
Аноним 19/08/19 Пнд 21:22:46 1456612384
>>1456607
Все понятно.
У меня не распределенная. Вообще, зачем нужны распределенные базы?
Типа когда у нас сервера разбросаны по всему миру для высокой скорости доступа всех пользователей и на каждом один экземпляр базы?
Аноним 19/08/19 Пнд 21:27:00 1456617385
>>1456563
Не стал вникать в твою проблему, сейчас стрельну вслепую, может попаду
>ON DUPLICATE KEY
Посмотри что у тебя выставлено в качестве ключа
19/08/19 Пнд 21:35:40 1456623386
>>1456617
И ты угадал. Удалил поле id и поставил user_id как primary key.
Спасибо
Аноним 20/08/19 Втр 00:26:11 1456714387
Есть 2 вопроса

Полгода работаю "Дата инженером " - в основном трансформирую данные с 2х баз данных, а также разбираю созданные экселевские отчеты / цсвшные репорты которые мне присылают в новые базы. Иногда в юпитер ноутбуке разбираю и чищу данные -> скидываю ноутбук чуваку

Я занимаюсь говном, то есть это и есть тот самый дата engineering? - это первый вопрос

Почитал вакансии - вон, люди красиво визуализируют данные и в табло, я на начальном уровне какой-то дешборд построить могу, есть чему учиться

А чем ещё дата инженеры занимаются? - собсна вот такой второй вопрос
Аноним 20/08/19 Втр 19:24:04 1457034388
Кто-нить знает как впараше поиск людей работает? Ну типо, можно написать имя человека, город, возраст, пол и еще хуеву тучу другой инфы. Не стоит же у них индекс на каждую вариацию? Или стоит? Ну скажем если я ищу людей по универу, с какими-то доп. параметрами, то можно сначала найти всех из этого универа и уже их линейно просканировать на соответствие другим параметрам. Но скажем я ищу олегов из дс, которым 31 год. Олегов дохуя, людей в дсе дохуя и тех, кому 31, тоже дохуя. Как вот это сделать?
Аноним 21/08/19 Срд 03:12:23 1457277389
>>1457034
Может партицирование по регионам?
Если указываешь вузик, то регион по нему изи определить.
Ну, а если просто возраст, то рандомных Олегов 31 летних.
Хотя как количество записей так быстро воззращается.
хз, кароч
Аноним 21/08/19 Срд 15:21:44 1457648390
Дайте, пожалуйста, ссылку на рабочий скрипт создания Northwind на MySQL. Всё, что нагуглил - у меня не работает, постоянно какие-то ошибки. Спасибо
Аноним 21/08/19 Срд 16:57:55 1457724391
>>1457648
Короче, у меня вылазит ошибка
ERROR 1366 (HY000) at line 175: Incorrect string value: '\xF3n 222...' for column 'Address' at row 1
Пробовал делать то, что гугл советует - не помогло (или не так искал). Надеюсь на помощь местных гуру.
Аноним 21/08/19 Срд 23:36:11 1458042392
>>1457034
>Не стоит же у них индекс на каждую вариацию?
Индекс разве не просто на поля ставится без перебора вариаций?
Аноним 22/08/19 Чтв 01:58:22 1458125393
Аноним 22/08/19 Чтв 02:04:09 1458126394
>>1456714
Etl, отчетность, администрирование субд - вот и все, собсна.
Однажды приходит понимание, что этого мало, например, нужно тебе по апи что-то откуда-то скачать, учишь язык какой-нибудь, хотя бы PowerShell.
Потом оказывается, что какие-то данные хотят не загружать к тебе в бд, а редактировать прям в ней - понимаешь, что нужно приложуху для этого запилить, да чтоб у всех работало - учишь фронт, чтобы нашлеать формочек.

Потом данных уже много, хотят по ним прогнозы строить - вкатываешься в эконометрику (или как ща модно называть - МАШИН ЛЕРНИНГ), делаешь всякие там регрессии на ПАЙТОНЕ
Аноним 22/08/19 Чтв 18:32:02 1458639395
А по nosql вопросы тоже тут задавать?
Аноним 22/08/19 Чтв 18:51:39 1458663396
Аноним 22/08/19 Чтв 19:31:26 1458706397
>>1458663
Как работает $or в монге? Сильно он запрос замедляет?
Аноним 24/08/19 Суб 00:41:06 1459669398
>>1406495
> Сущности называются единственным числом.
Разве?
Где почитать про правила именования?
мимо
Аноним 24/08/19 Суб 03:32:17 1459718399
>>1459669
В гугле
Если твоя сущность - жопА, то называешь таблицу ЖопА
Если твоя сущность - жопЫ (явно указывает, что список жоп, а не одна), называешь таблицы ЖопЫ

В любой нормальной книжке про ДБ это будет где-нибудь написано. Откуда я это взял, я уже не помню, но весь мой опыт (20+ лет) показывает, что множественное число там, где сущность описывает ОДИН объект, - признак говеной системы (от ЕРД до кода).

остальные конвенции - кэмелКейс или подчеркивания - это внутренние соглашения.

и да, характерный признак пидора - использование зарезервированого слова в названии таблицы или поля

другой характерный признак пидора - неименованные констрейнты (фк без имен и пр.) - ты их потом не удалишь нормально.
Аноним 24/08/19 Суб 14:35:16 1459957400
>>1459718
А может быть табличка, где всего одна жопа?
Как ты это видишь? Одна строчка в ней хранится?
Аноним 24/08/19 Суб 14:39:47 1459959401
>>1459957
Очевидно же, что нет.
Если в одной строке твоей таблицы хранится информация об одной жопе - то таблица называется "жопа".
Если сразу о нескольких - то "жопы".
Аноним 24/08/19 Суб 14:41:14 1459963402
>>1459959
Приведи пример, в котором у тебя в табличке хранится информация для одной жопы. Непонятно, что ты имеешь в виду.
Аноним 24/08/19 Суб 16:40:37 1460041403
Анончики, а в этом треде уместно задать вопрос по запросам SQL?
Аноним 24/08/19 Суб 16:45:26 1460045404
>>1459957
>А может быть табличка, где всего одна жопа?
Двачер познает мир, бля.
Может быть табличка, где вообще ни одной жопы нет.
Если тебе это непонятно, то рановато за соглашения об именования браться.
Надо что-нибудь попроще
Аноним 24/08/19 Суб 16:46:36 1460048405
>>1460041
Ну что ты, анончик!
Вопросы по сиквелу надо задавать в питоно- и жс-тредах.

Хули ты издалека заходишь?
Есть вопрос - задавай.
Аноним 24/08/19 Суб 16:55:04 1460053406
Снимок экрана 2[...].png (166Кб, 1576x620)
1576x620
>>1460048
Загадали мне загадку, которую никак не могу раздуплить. Основная сложность в том, что если человек перемещался между станциями в последовательности 1-2-3-1, то как вот отловить минимальное время второго захода на станцию 1?
Аноним 24/08/19 Суб 17:08:46 1460069407
Аноним 24/08/19 Суб 17:11:55 1460073408
>>1460069
ОМГ, даже не знаю, как это гуглить, но спасибо за подсказку в любом случае
Аноним 24/08/19 Суб 17:51:07 1460091409
>>1460069
Какие, блять, графы, не путай его.
Все решается обычным SQL.
Аноним 24/08/19 Суб 18:01:01 1460094410
query.png (163Кб, 1218x728)
1218x728
Снимок экрана 2[...].png (77Кб, 672x746)
672x746
>>1460091
Че делать то, анон? Я пока нафигачил вот так. Верно хоть иду? Дальше, поди надо какие-то сравнения сделать через CASE? Или я вообще хуйни наворотил, и решать надо не так?
Аноним 24/08/19 Суб 18:03:41 1460096411
>>1460053
lag lead должны решить твою проблему.
Аноним 24/08/19 Суб 18:03:47 1460097412
>>1460073

Твоя "основная сложность" обходится простым способом - тебе нужно посмотреть на предыдущую запись по времени для данного абонента и если БС в ней другая, то выбрать дату и время, иначе взять null.

Попробуй рекурсивные запросы, почитай про LAG/LEAD, можешь попробовать решить с подзапросами - способов тут несколько.
Аноним 24/08/19 Суб 18:07:41 1460099413
>>1459718
Самый пиздец - это названия по-русски транслитом.
Аноним 24/08/19 Суб 18:09:05 1460101414
>>1460097
Посмотрел про LAG/LEAD - похоже, то, что надо, спасибо
Аноним 24/08/19 Суб 18:18:37 1460107415
>>1460101
Запости потом что получилось.
Аноним 24/08/19 Суб 18:20:54 1460110416
>>1460107
Это будет не скоро, потому что мой SQL исключительно базовый. Пока разберусь, как это работает, несколько часов точно пройдет, но как решу, запощу. Или если не решу, завтра опять приду помощи просить. Надо решить к понедельнику мне эту загадку
Аноним 24/08/19 Суб 19:13:52 1460158417
>>1460053
Что там написано про "необязательно решать за один"?
Не обязательно одним запросом?
Хули тогда, отсортируй данные по юзеру, времени, потом в процедуре цикл напиши

В результате требуется _построить таблицу_
Аноним 24/08/19 Суб 19:17:18 1460162418
>>1460099
Нет. Это не пиздец.
Если все понимают, что означает Cheburashka, то так и надо называть. А не пытаться искать перевод.

Самый пиздец - названия по-русски БЕЗ транслита. Просто по-русски.
Видел оракловую базу в солдиной компании, где половина таблиц называется "пользователь" и "счет", а другая половина - по-английски латиницей.
Аноним 24/08/19 Суб 19:37:51 1460175419
>>1459963
Да блядь, таблица о сущности "жопа".
А если это таблица, в которой несколько столбцов вроде "ширина", "глубина", "количество хуев", то называть ее верно будет жопа_properties.
Но если ты решишь сделать её вертикальной и у тебя в этой таблице свойств будут строки типа "жопа, глубина, 15", "жопа, ширина, 10", "жопа, хуи, 42", то назвать ее надо "жопа_property".
Верно тебе говорил анон, что ты просто ещё не дошел до этого, раз не понимаешь такие простые вещи.
Аноним 24/08/19 Суб 19:52:14 1460181420
>>1460158
Ага, не обязательно решать за 1 запрос, возможны промежуточные таблицы. Он и так вроде отсортирован по юзеру и времени. Посмотрю и про циклы, спасибо
Аноним 24/08/19 Суб 21:55:58 1460255421
>>1458125
Ну окей, поставил ты индекс на город, имя и т.д. И вот тебе приходит запрос:
Найти всех Олегов из ДС которым от 31 до 35 лет. И че блять? С этими индексами ты можешь быстро найти либо всех Олегов (а ВК еще как - то учитывает написание, то есть там Олег, Олежко, Олеган это все одни имена), либо всех, кто живет в ДС, либо тех, кому от 31 до 35 лет. После этого тебе надо линейно сканировать весь результат на соответствие другим фильтрам. Понятно, что это пиздец как медленно учитывая кол-во пользователей Впараше. Плюс у них еще распределенная БД, поэтому добавляется еще задержка на передачу пакетов от кластеров БД к серверу. Как у них так получается быстро сука все искать блять? Я тоже так хочу уметь. Понятно, что у них как - то еще пагинация юзается, то есть они не возвращают тебе сразу весь результат (и не считают его разом на сервере). Но блин, даже допустим если у нас пагинация в 50 элементов. Сервер находит всех Олегов (допустим), начинает бежать по результату поиска, пока не наберет 50 Олегов, соответствующих фильтру (ДС и возраст 31-35). Это все равно будет пиздец как долго мне кажется. Ну а скажем если я поменяю в запросе ДС на мухосрань. Тогда наверное выгоднее будет в начале найти людей из мухосрани и уже их линейно сканировать.

Короче, я думаю, что они действительно юзают индекс на каждую колонку. Но они не просто тупо его применяют как в sql запросе (WHERE a=x AND b=y AND c=z), а ведут какую - то статистику по каждой из колонок. Наверное, в эту статистику входит кол-во записей, у которых в этой колонке стоит такое - то значение. Допустим людей из ДС дохуя, а из мухосрани мало. Тогда БД уже может в начале применить индекс, который максимально сузит круг поиска (то бишь индекс по городу, в случае мухосрани). А потом уже просканирует этот результат и вернет 50 людей. Или допустим я ищу какого - нибудь Лаврентия из ДС, тогда можно в начале применить индекс по имени.

Но все равно непонятно, как это работает в случае с такими городами как ДС. И у этого решения я уверен есть куча граничных случаев, которые могут сильно загрузить сервер и ему придется сканировать весь результат, пока он не найдет 50 людей. Короче хз...
Аноним 24/08/19 Суб 23:42:35 1460315422
>>1460107
Решил. В числе прочего пригодилась функция lead, спасибо! Двач - воистину помогач
Аноним 24/08/19 Суб 23:51:13 1460321423
>>1460255
>Ведут какую-то статистику по каждой из колонок
Здравствуйте, вы только что оптимизатор.
Аноним 25/08/19 Вск 01:12:02 1460343424
>>1460315
Ну дык пости запрос сюда. Для истории.
Аноним 25/08/19 Вск 05:39:28 1460368425
>>1460255
>учитывает написание, то есть там Олег, Олежко, Олеган это все одни имена
Ты не поверишь, но бывают и индексы на функцию

А еще бывает тейбл-партишенинг

А еще бывает кэширование

Короче, до хера всего бывает.

Вылези уже с двача, да почитай про оптимизацию хранения и оптимизацию выборки
Аноним 26/08/19 Пнд 10:57:15 1461001426
Норм ли юзать триггеры, процедуры для логики помещения записей в таблицу историй?
Аноним 26/08/19 Пнд 11:11:34 1461012427
image.png (94Кб, 1360x768)
1360x768
Аноним 26/08/19 Пнд 11:22:54 1461021428
>>1461012
1) select p.name, p.surname
from people p
where exists (select 1 from people_nationalities pn where p.person_id = pn.person_id and pn.nationality = 'RU')

2) select a.name, a.surname
from actors a
where a.age = (select max(aa.age) from actors aa)
fetch first 1 row only;

fetch first - это оракловый синтаксис, у других вендоров свой.
актеров с макс. возрастом может быть много.

3) select p.name, p.surname
from people p
join people_nationalities pn on p.person_id = pn.person_id
group by p.name, p.surname
having count(pn.nationality) > 1;
Аноним 26/08/19 Пнд 11:24:27 1461022429
Аноним 26/08/19 Пнд 11:30:07 1461030430
>>1461001
Разве что для проектов уровня лаба.
В промышленном коде триггеры для этого не используются, исторические записи создаются в прикладном коде в нужных местах.
Аноним 26/08/19 Пнд 11:56:23 1461049431
Аноним 26/08/19 Пнд 15:20:17 1461220432
>>1461049
Во-первых, тот анон тебя наебал.
Потому что за "прикладной код" он считает только то, что пишет лично он на своем сраном питоне.
Процедуры вполне могут быть частью прикладного кода.
Триггеры вполне могут использоваться для целей, что ты указал.
С очевидными ограничениями (например, триггер, в общем случае, не узнает, какая сволочь удаляет запись).

Во-вторых, триггеры могут использоваться для обеспечения целостности данных. В тех случаях, когда правила сложнее, чем просто ФК. Например, нельзя иметь четное число в поле А, если в таблице Х нечетное количество записей.
Конечно, такие правила должны быть реализованы на стороне клиентского кода.
Но все знают, что клиентский код пишут уебаны, не чурающиеся питона и пхп, поэтому доверять им нельзя.
Посему в нормальной базе максимально закрываются возможность в нее насрать. Констрейнт это самый очевидный и простой способ, триггер - более сложный и редко нужный.

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

Другое дело, что это не очень прозрачно.

Но, когда у тебя есть легаси система, где база одна, а прикладной код может быть написан не просто в разных архитектурах, но и на разных языках, у тебя особо и нет другого выхода - единственный общий знаменатель это именно база.
Аноним 27/08/19 Втр 01:49:37 1461559433
>>1461220
спасибо,

я уже несколько дней думаю над такой штукой,

толи я чего то не понимаю, то ли еще что
managed//cloud DB действительно выходят в разы дороже чем если просто арендовать железные сервера и самим на них строить кластер?
Аноним 27/08/19 Втр 01:53:50 1461561434
>>1461559
Дороже потому что они тебе гарантируют отказоустойчивость.
С тем что настроил сам и ебаться будешь сам когда упадет.
Аноним 27/08/19 Втр 03:25:28 1461570435
Аноним 27/08/19 Втр 03:30:33 1461571436
>>1410061
Django со встроенной админкой
Аноним 27/08/19 Втр 04:40:32 1461578437
>>1461220
Если все манипуляции с данными написать на хранимых процедурах, то легко можно обойтись без триггеров.
Аноним 27/08/19 Втр 14:23:31 1461831438
>>1461578
Можно.
За исключением триггеров для обеспечения целостности.
Это относится к ЕРД, скорее, чем к прикладному коду. Как любой констрейнт.
Но, опять же, у тебя могут быть пять процедур, которые модифицируют какую-то таблицу, и от этого должна добавляться запись в историю. Сразу вопрос: что лучше, проще, надежнее и удобнее:
1. написать один и тот же код в пяти процедурах?
2. оформить этот код процедурой/функцие и вызывать ее из пяти процедур?
3. подвесить один триггер?
Для мне ответ очевиден, если триггер позволяет реализовать все, что мне надо в истории.
Аноним 27/08/19 Втр 15:18:22 1461868439
>>1461831
Триггер не узнает кем было сделано изменение. А в хранимку можно передать такую инфу.
Аноним 27/08/19 Втр 15:59:42 1461888440
>>1461831
Я с тобой согласен, все верно, с той лишь оговоркой, что если данные меняются исключительно через хранимки, то сложные констрейнты (типа количества актуальных в один момент записей, проверки допустимости значения в зависимости от содержимого в другой таблице и т.п.) реализованные в процедуре проще в сопровождении и в отладке, чем вариант с триггерами - но ты и сам сказал выше, что это не очень прозрачно.

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

Если отвечать на вопрос анона
>>1461001
То да, нормально, есть такой подход и он вполне рабочий.
Аноним 27/08/19 Втр 17:10:46 1461934441
>>1406455 (OP)
Помогите, пожалуйста. Никак не могу придумать как нормально задизайнить таблицу.

Грубо говоря, есть объект Message и у него есть поле action_type т.е. возможные значения этого поля уже известны заранее). В зависимости от этого поля, меняется структура полей, которые нужно хранить.

Как нужно задизайнить схему, чтобы можно было хранить это все в каком-то связанном виде?
Аноним 27/08/19 Втр 18:18:53 1461975442
>>1461934
Можешь завести нужные поля в Message для всех action_type, если их число жестко определено и не будет меняться. Можешь сделать EAV (см. Entity-Attribute-Value). Можешь оставить в Message общие поля, а остальные разнести по разным таблицам.

Зависит от природы данных и твоих задач - насколько велик справочник action_type (3 значения или 30), будет ли он изменяться пользователями,предполагается ли поиск по различающимся полям, участвует ли таблица в тяжелых запросах, будет ли изменяться структура полей. У каждого решения есть плюсы и минусы.
Аноним 27/08/19 Втр 19:13:17 1462029443
>>1461868
Да. об этом я писал где-то выше.
Увы, нельзя все и сразу сделать хорошо. Чем-то где-то придется пожертвовать.
Аноним 27/08/19 Втр 19:20:29 1462039444
>>1461975
Я бы сказал, что если общее число уникальных для каждого типа полей невелико, то надо их все в одну таблицу пихать.
Оверхед на пусоту в записях будет невелик, а удобство написания и выполнения запросов вырастет в разы. Про адпейты и делиты не говорю уж.
Ну и, опять же, будет гораздо удобнее месседж одного типа превратить в месседж другого руками.

Есть одно но - как правильно поддержать целостность данных - not nullы требуемые лишь для одного типа, и как не насрать в поля, этому типу нехарактерные.
Аноним 28/08/19 Срд 00:33:43 1462194445
>>1461559
Суммарно за все время - конечно больше, в ближайшей перспективе - нет.
Как написал оратор выше, плюс ко всему облако подразумевает отказоустойчивость.
Аноним 28/08/19 Срд 04:13:31 1462237446
>>1462194
>облако подразумевает отказоустойчивость
Пока оператор не обанкротился, ркн не закрыл доступ, хуй знает кто не влез в твои данные, и т. д.

Вам дай волю, вы и мамку свою в облако запихнете
Аноним 28/08/19 Срд 04:46:00 1462240447
>>1462237
Два чаю этому реалисту.
Аноним 28/08/19 Срд 08:27:51 1462286448
>>1460343
На работу устроюсь сперва, потом обязательно запощу. Пока что могу сказать, что работу приняли, сказали "малаца", сегодня следущий этап собеседования
Аноним 28/08/19 Срд 15:54:11 1462653449
В одной таблице хранится два типа документов, которые связаны между собой. Нужно сделать селект по type1.status и type2.status. Как это сделать?
Аноним 28/08/19 Срд 17:35:05 1462707450
>>1462653
Анончик, если хочешь получить хороший ответ - задавай хороший вопрос. Например, структуру таблицы напиши, что с чем связано и по какой колонке, что ты хочешь выбрать.
Имей уважение к людям, не пости несвязный бред.
Аноним 28/08/19 Срд 18:09:45 1462726451
image.png (14Кб, 452x169)
452x169
image.png (12Кб, 452x169)
452x169
>>1462707
Есть две таблицы. Все документы хранятся в DOCUMENT, а связи между ними - в BIND. Например, первая запись в BIND - это документ с id 333 из DOCUMENT, который связан с документом 111.

Мне нужно получить список связанных пар документов с определенными статусами. Пример: из пикрила мне нужно получить пару (или несколько пар) связанных документов, у которых у первого TYPE=ebalo, STATUS=vsrato, а у второго TYPE=hui, STATUS=tiny.

Надеюсь, понятно раскрыл вопрос.

Аноним 28/08/19 Срд 18:18:31 1462728452
BigQuery - Afri[...].png (13Кб, 513x146)
513x146
Аноны, помогите кусок запроса составить. Вот кусок схемы таблицы. Нужно во вьюху вытянуть конкретный user_properties.key в качестве поля, а в качестве значения поля нужно вытащить user_properties.value.string_value из record user_properties.value
Аноним 29/08/19 Чтв 12:55:43 1463136453
>>1462726
Тебе нужно заджойнить document с bind по global_id, а затем bind снова заджойнить с document но уже по doc_id. Затем написать условие where для ведущих и связанных документов, различить их помогут алиасы.

Читай про inner join, where. В разборе join обрати внимание, как используются алиасы для таблиц. Пиши код, пробуй.
Аноним 29/08/19 Чтв 13:17:55 1463146454
>>1462728
Какая у тебя СУБД? Как ты пробовал решить самостоятельно? Что именно вызвало затруднения? Документацию читал?
Аноним 29/08/19 Чтв 20:39:12 1463407455
>>1457034
Бля, понял!
Они просто сливают всю инфу по пользователю в одну строку и ее индексируют. Вот так короче
Аноним 29/08/19 Чтв 20:47:09 1463415456
>>1463407
Ну и пагинация конечно, и перед этим мердж-джоин
Аноним 29/08/19 Чтв 21:50:44 1463501457
>>1460255
Почитай, как работают колоночные индексы. Они строятся не по каким-то столбикам, а в целом меняют структуру хранения данных в табличке.
Аноним 30/08/19 Птн 01:10:42 1463580458
>>1463501
>индексы меняют структуру хранения данных в табличке
Ооооооок
Аноним 30/08/19 Птн 01:55:52 1463591459
>>1463407
Пощады, там в базе всего несколько миллионов строк(смехота), собранная статистика и хороший оптимизатор запросов - вот и работает все быстро.
Да и фетч происходит порциями, а не всех строк сразу.
Аноним 30/08/19 Птн 10:42:31 1463698460
>>1463580
Индексы columnstore — это стандарт хранения и запрашивания больших объемов данных в таблицах фактов. В этом индексе используется хранение данных и обработка запросов по столбцам, что позволяет практически в 10 раз увеличить производительность запросов к хранилищу данных по сравнению с традиционным хранилищем, в котором данные хранятся по строкам, и практически в 10 уменьшить размеры данных по сравнению с несжатыми данными.
https://docs.microsoft.com/ru-ru/sql/relational-databases/indexes/columnstore-indexes-overview?view=sql-server-2017
Аноним 30/08/19 Птн 17:59:24 1464055461
Аноны, ньюфаг в треде, такая задачка, нужно вывести id предпоследнего нанятого сотрудника, используя подзапрос.
Наваял вот это, но не работает, так как типа ничего не известно о subQuery (какого черта, я же подписал). Помогите, кто чем может

SELECT EmployeeID
FROM (SELECT EmployeeID, HireDate
FROM Employees
WHERE HireDate < (SELECT MAX(HireDate)
FROM employees)) AS subQuery
WHERE HireDate = (SELECT MAX(HireDate)
FROM subQuery);
Аноним 30/08/19 Птн 18:46:18 1464085462
>>1464055
Потому что нельзя обращаться в подзапросе к блоку запроса выше таким образом. К его полю - пожалуйста, но не селектить из него.

select coalesce(
(select id from
(select id from employees order by hiredate desc)
where rownum = 2),
(select id from employees))
--from dual

Мне после оракла кажется безумным такой запрос без from dual, но если бд другая - нужно без него.
Берешь второго по hiredate сотрудника, если такого нет - то он всего один, выводишь его.
Если задача подразумевает, что если сотрудник один, то ничего не выводить - то тебе нужен первый аргумент coalesce только.
Аноним 30/08/19 Птн 18:55:04 1464092463
>>1406455 (OP)
Господа, не подскажете, в каких случаях distinct работает быстрее group by в posgres?
Я читал где-то, что distinct всегда под капотом юзает group by, так ли это?
Есть у кого бенчмарки или примеры, линканите, плиз
Аноним 30/08/19 Птн 23:20:56 1464302464
>>1463698
Цитаты из документации на русском языке...
Ооооок

Это, конечно, все очень хорошо. Только columnstore index это не индекс даже в понимании МС
Если ты там повыше поднимешься в этой доке, то увидишь, что

An index is an on-disk structure associated with a table or view that speeds retrieval of rows from the table or view. An index contains keys built from one or more columns in the table or view. These keys are stored in a structure (B-tree) that enables SQL Server to find the row or rows associated with the key values quickly and efficiently.

А в описании колумнсториндекса будет написано:
A columnstore index is a technology for storing, retrieving, and managing data by using a columnar data format, called a columnstore.

Так что слово "индекс" там только в названии. Типа "морской свинки".

Но ладно, настаивать, что ты не прав, не стану.
Аноним 31/08/19 Суб 09:08:48 1464471465
>>1464092
Distinct - это group by по всем полям с сортировкой, потому работать будет дольше, тут и за тестами не ходи.
Union, minus, intersect - та же шляпа, по факту.
Аноним 31/08/19 Суб 14:34:10 1464634466
Аноним 31/08/19 Суб 15:45:28 1464675467
>>1464471
>Distinct - это group by по всем полям с сортировкой
Конечно же, ты сейчас приведешь выдержку из документации, которая подтверждает это безумное утверждение, да?
Конечно, нет.
DISTINCT в ADODB и Management Studio Аноним 31/08/19 Суб 16:37:01 1464697468
Анончик-программист, помоги разобраться. Ситуация:
Скрипт на VBS отправляет запрос Q к MS SQL Server 2008R2 посредством ADODB (Provider = "SQLOLEDB"
).
Q = "SELECT DISTINCT A FROM Table"
В результате исполнения ADODB.Recordset возвращается пустой.

Этот же запрос Q, исполненный в MS SQL Server Management Studio возвращает 51 строку.

Таблица содержит кириллицу и в наименовании столбцов и в полях.

Момент: если из Q убрать DISTINCT, ADODB.Recordset возвращается непустым.

Вопрос: почему реакция ADODB на ключевое слово DISTINCT кардинально отличается от реакции самого SQL Server?
Аноним 31/08/19 Суб 18:43:04 1464804469
Тут давеча на хабре нашел статейку, там чел с пруфами вроде как пояснил, что UNION быстрее будет отрабатывать, нежели OR. Правда шоль?
Аноним 31/08/19 Суб 19:02:17 1464821470
>>1464804
От случая к случаю. Если у тебя в OR стоят условия на индексированные поля и оптимизатор может раскрутить этот запрос на union с этими условиями, то да, это будет быстрее и он выберет этот вариант. То есть пишешь OR, а на самом деле получится два чтения индекса.
А если поля не индексированные, то в одном случае у тебя два чтения таблицы и проверка одного поля, а во втором одно чтение таблицы и проверка двух полей - больше затрат CPU.
Если таблица широкая, то вариант с OR предпочтительнее, чтобы ценой вычислительных затрат уменьшить количество чтений с диска, если в таблице 1-2 столбца(условно, конечно - может, в пределах 10-15 столбцов в зависимости от типов данных), то в самом деле будет быстрее прочесть дважды таблицу и сделать union.

Вангую, что при написании статьи тот парень использовал тестовую среду или домашнюю базу, в которой из буферного кэша(сиречь место в оперативе, где какое-то время хранятся доставаемые с диска блоки, чтобы можно было быстро обратиться к ним повторно) никто другими запросами не вытолкнул его таблицу. На боевой базе такое вряд ли получится.
Аноним 31/08/19 Суб 22:30:27 1464913471
>>1464302
Вопрос был в том, как у вк устроен поиск. Есть термин - кологочный индекс. Ты доебался до его названия, умница. По существу есть, что сказать?
Аноним 01/09/19 Вск 04:54:58 1464988472
>>1464913
>По существу есть, что сказать?
Конечно: ты тупой мудак, который не понимает, о чем говорит с умным видом.
Ты даже на дваче умудряешься обосраться, знаток баз данных.
Послезавтра к первому уроку, не проспи.
Аноним 01/09/19 Вск 22:09:06 1465452473
Дата-инженеры тут сидят, м?
Аноним 01/09/19 Вск 23:55:09 1465491474
>>1465452
Тут тоже сидят, но, вообще, отдельный тред есть про нейроночки и машобчик
Аноним 02/09/19 Пнд 00:04:25 1465495475
>>1465491

Там датасайнтисты, вроде бы. А меня больше интересует сам процесс обработки и подготовки больших массивов данных под задачи этих ребят.
Аноним 02/09/19 Пнд 10:52:09 1465611476
>>1465495
Спрашивай тут, в таком случае.
Если вопрос про SQL, то скорее всего тебе помогут.
Аноним 02/09/19 Пнд 21:31:56 1466015477
>>1465452
Есть начинающие, что хотел?
Аноним 04/09/19 Срд 19:16:54 1467244478
>>1466015

Какие знания нужно иметь, чтобы попасть джуномидлом к вам? Во всяких спарках и хадупах дома полноценно не поразбираешься.
Есть пара лет опыта в бэкенд-разработке
Аноним 05/09/19 Чтв 15:04:32 1467746479
14837863472760.jpg (246Кб, 1280x1004)
1280x1004
Анонче, на что он ругается? Я уже голову сломал.

CASE CP_LastInstallationError
when '8007045D' then 'Delete all SCCM folders and rebuilt wmi Repository'
when '-2147023174' then 'Check out firewall or AntiVirus'
when '2147024891' then 'NONE'
END AS 'SOLUTION'

ERROR: Conversion failed when converting the value '' to data type .

Я только недавно вкатился и учусь писать запросы, пока что.
Аноним 05/09/19 Чтв 15:21:08 1467757480
>>1467746
ты уверен, что в CP_LastInstallationError у тебя строка, а не число?
Аноним 05/09/19 Чтв 15:23:27 1467759481
>>1467757
У меня там и числа, и просто значения, вроде 8007045D.
Аноним 05/09/19 Чтв 15:57:12 1467776482
>>1467244
помимо хадупчика с питончиком есть и дургие технологии:
MS SQL + SSIS, например.
Куда приятнее и понятнее лично мне, используется для наполнения хранилищ данных.

>>1467746
>Conversion failed when converting the value '' to data type .

to data type КАКОЙ? нахуя ты обрезал последнее слово из ошибки?

Ты уверен, что проблема, вообще, в этой части запроса? Пробовал выполнить запрос с селектом только одного этого кейса?
Аноним 05/09/19 Чтв 16:19:17 1467789483
>>1467776
Там ошибка такая, он астериски не показал, просто.
Изначально, выглядело это так: the value to data type .
Пробовал кейсы по одиночке, а результат был тем же.
Аноним 05/09/19 Чтв 16:20:08 1467790484
>>1467789
Понятно, борда преобразовала с двух сторон слов в шрифт.
Аноним 05/09/19 Чтв 18:35:34 1467904485
>>1467244
На чем писал бэкэнд?
Аноним 05/09/19 Чтв 19:00:13 1467915486
>>1467759
на хуя тогда ты их в кавычки берешь?
Аноним 05/09/19 Чтв 19:26:47 1467936487
Аноним 05/09/19 Чтв 20:01:29 1467966488
Аноним 05/09/19 Чтв 20:46:09 1467990489
Аноним 05/09/19 Чтв 21:03:43 1468003490
>>1467990

Я ещё на Си пишу (есть код в опенсорсе)
Аноним 06/09/19 Птн 23:41:42 1469131491
Ребята, вы тут самые нормальные, так что у вас спрошу:
Где на этой борде аналитики сидят?
Аноним 07/09/19 Суб 04:42:37 1469214492
Аноним 07/09/19 Суб 16:43:54 1469475493
>>1469131
Тут спрашивай, что хотел.
Аналитики, которые рисуют отчеты, тут.
Сам такую должность занимал пару лет назад, да и сейчас этим занимаюсь факультативно.
Аноним 07/09/19 Суб 17:18:30 1469483494
>>1469475

Как к вам перекатиться из разработать?
Аноним 07/09/19 Суб 17:19:24 1469484495
>>1469483
> из разработать

Из разрабов. Ебучий т9
Аноним 08/09/19 Вск 08:51:49 1469754496
Извечный вопрос об оптимизации запросов.

Что лучше: сделать 2 SELECT в SQL и программно ужать в программе, или сделать один SELECT + JOIN?

Интересует именно нагрузка на SQL
Аноним 08/09/19 Вск 08:54:03 1469756497
>>1469754
При выборке в 100 элементов и при выборке 100к
Аноним 08/09/19 Вск 09:29:51 1469764498
>>1469756

Второе. Потому что СУБД может знать о твоих данных такие вещи, о которых ты со своим кодом не подозреваешь.
Аноним 08/09/19 Вск 09:51:03 1469770499
>>1469764
Только эффект может проявиться при накоплении статистики, поэтому ньюфаги с синтетикой на чистой базе могут объебаться.
Аноним 08/09/19 Вск 09:51:39 1469771500
>>1469770
Так что нужно самому проверять на конкретных выборках...
Аноним 08/09/19 Вск 14:38:26 1469912501
>>1469475
Как в таких аналитиков вкатиться?
Я двухмесячный курс на курсере по анализу данных прошёл, но на собеседованиях меня нахуй посылают. Вот только и пишу постановочки-таски
Аноним 08/09/19 Вск 23:15:06 1470149502
>>1469912
Нужно уметь 3 штуки:
1. Понимать требования и быстро вкатываться в то, что от тебя хочет заказчик. На собеседовании могут предложить решить алгоритмическую задачку, чтобы это чекнуть. Без шуток они бывают сложными. Есть 2 яйца и 100-этажное здание, яйца бьются с какого-то определенного этажа (один и тот же этаж для любого яйца). За какое минимальное количество бросков яиц можно понять, какой это этаж?
2. Уметь в язык запросов, самое распространенное - SQL. На собесе 100% дадут решать запросы: для каждого менеджера выберете 3 самых продаваемых товара.
3. Уметь визаулизировать данные - PowerBi, Tableu, SSRS и т.п.
На собеседовании никак не чекают.

Аноним 08/09/19 Вск 23:16:24 1470151503
Аноним 09/09/19 Пнд 19:47:08 1470580504
В общем, подаюсь на работу.

В вакансии основным и жирным выделенным были SQL и Power BI

Какие бы Ты, Анон, поставил мне вопросы?

Позиция для начичнающего.
Аноним 10/09/19 Втр 00:46:42 1470800505
>>1470580
Первым делом я бы дал тебе тест на знание скл с вопросами типа этого (п.1, п.2)
>>1470149

Всякие там join, apply, union

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

Собственно, все. От рисователя отчетов много и не требуется.
Аноним 10/09/19 Втр 14:43:10 1471038506
>>1470800

> Собственно, все. От рисователя отчетов много и не требуется.

А денег сколько платят такому рисователю?
Аноним 10/09/19 Втр 17:38:24 1471164507
Аноним 10/09/19 Втр 21:27:26 1471403508
>>1471164
Да ну? Чет не верится, что на 9 порядков от программерской отличается!
Аноним 10/09/19 Втр 23:15:05 1471469509
>>1460343
Кароч меня берут. Как обещал, выкладываю решение

/ Нельзя просто взять и сгруппировать станции, потому что пользователь может на них вернуться,
и тогда я потеряю время второго захода. Мне нужны уникальные идентификаторы сессии пользователя на каждой станции,
по ним я вычислю самое раннее время активности пользователя при каждом заходе на каждую станцию
/

WITH rank_data AS(
SELECT
id,
bs,
time,
RANK() OVER (PARTITION BY id, bs ORDER BY time) AS bs_hit, -- Проранжирую каждый хит пользователя на каждой станции
RANK() OVER (PARTITION BY id ORDER BY time) AS user_activity -- Проранжирую все хиты пользователя по всем станциям
FROM `database.test.bigdata`
ORDER BY time
),

sessions AS (
SELECT id,
bs,
time,
bs_hit,
user_activity,
user_activity - bs_hit AS session_id -- Получу уникальный идентификатор сессии пользователя на станции
FROM rank_data
ORDER BY id, time
),

/ Соберу в отдельную таблицу время начала каждой сессии на каждой станции /
session_start AS (
SELECT
DISTINCT(id),
bs,
MIN(time) OVER(PARTITION BY id, bs, session_id ORDER BY id, time) as time
FROM sessions
ORDER BY id, time),

/ Соберу в отдельную таблицу время последнего появления пользователя на станции,
последнее время сессии мне не интересно по условиям задачи
/
leaving_station as (
SELECT DISTINCT(id), bs,
MAX(time) OVER(PARTITION BY id, bs ORDER BY id, time DESC) as time
FROM sessions
ORDER BY id, bs)

/ Вывод требуемой траблицы /
SELECT
session_start.id as ID, -- идентификатор пользователя
session_start.bs as BS, -- базования станция
session_start.time as time_start, -- начало сессии на станции
CASE
WHEN LEAD(session_start.id) OVER(ORDER BY session_start.id, session_start.time) = session_start.id
/ Если идентификатор пользователя на следущей строке тот же, что и на предыдущей,
то конец его сессии на одной станции равен началу сессии на следующей
/
THEN LEAD(session_start.time) OVER(ORDER BY session_start.id, session_start.time)
ELSE
/ Иначе: конец сессии - это конец активности пользователя на станции /
leaving_station.time
END AS time_end
FROM session_start
LEFT JOIN leaving_station
ON session_start.id = leaving_station.id AND session_start.bs = leaving_station.bs
Аноним 11/09/19 Срд 00:33:41 1471503510
>>1471038
В ДС ~ 100к/месяц

Сам участвовал в составлении вакансии.

Тока sql надо правда хорошо знать, а не врать, что хорошо знаешь.
Аноним 11/09/19 Срд 08:52:41 1471625511
>>1406455 (OP)
Анон, есть одна таблица в бд на mssql2016, в ней varchar(1000) поле, внутри которого json, по полям которого нужно искать с помощью json_field(column, '$.someField').

Но такая функция появилась только в mssql2016, а нам на один из новых боевых контуров могут дать только mssql2014.

Нет ли у тебя реализации чего-то вроде json_field на чистом tsql?
Аноним 11/09/19 Срд 09:16:56 1471632512
>>1471503

Это на джуна-недомидла?
Аноним 11/09/19 Срд 13:45:41 1471755513
Аноны, бизнес/системные аналитики тут водятся?

Я закончил год назад вуз по прикладной информатике в экономике и это вроде как раз оно - основной упор на автоматизацию бизнес-процессов с помощью баз данных. Был во время учебы и олимпиадный опыт на командном всеросе, когда за несколько дней по данной условием теме стартапа моделировали бизнес-процессы as-is, оптимизировали и придумывали to-be с проектом автоматизации, потом проектировали БД и реализовывали прототип и представляли "якобы инвестору".

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

Вопроса основных два (спасибо, кто прочитал до конца):
1. Как примерно строится обычно рост?
2. Насколько всё хуёво с возможностью переезда по сравнению с разработчиками? Я пока никчёмный хуй с горы, но когда-нибудь очень хочется завести трактор, может лучше сразу пытаться перейти на разработчика или, упаси Боже, дата саентиста? (кстати, очень похожая на дата саенс математика у меня в обилии была в вузе, только я многое уже забыл)

Спасибо, аноны, заранее за ответы. Нахуй тоже схожу, если пошлёте.
Аноним 11/09/19 Срд 16:21:52 1471836514
>>1471755
>Я пока никчёмный хуй с горы, но когда-нибудь очень хочется завести трактор, может лучше сразу пытаться перейти на разработчика или, упаси Боже, дата саентиста?

Вы приняты
Свободная касса
Аноним 11/09/19 Срд 16:22:44 1471838515
>>1471755
Бизнес/системные аналитики это документная хуита, где описывать словами программы в 100 раз больше, чем строчек кода в твоей работе
СТАЖЕР 11/09/19 Срд 22:29:40 1472048516
image.png (16Кб, 791x255)
791x255
Сап, аноны, нужна помощь с хитрым (для меня) запросом.
Нужно вывести таблицу, содержащую имя курса (course.name) и кол-во человек, прошедших соответствующий курс за условный период.
Дата окончания хранится в history.cend, если history.status = 1, то курс считается пройденным. Т.е. сосчитать такие history.history_id, что history.cend=x и history.status = 1 для каждого course.name. Собственно на этом и застрял. Помогите пожалуйста. Структура бд пикрилейтед.
Аноним 12/09/19 Чтв 00:35:42 1472083517
>>1471632
Вакансия называется аналитик. Не еби себе мозги джунами мидлами и т.п.

>>1471625
>Sql Server 2014
Поддерживает CLR.
Так что советую написать на C# парсер джейнсона и встроить получившуюся либу в SQL Server в виде сборки (Assembly). Получится то же самое, что умеют функции JSON_VALUE и JSON_QUERY в Sql Server 2016. Если с этим проблемы, могу помочь.
Аноним 12/09/19 Чтв 01:26:48 1472088518
>>1472083
> CLR
Посмотрел и отказался - усложнит и без того неидеальные сборку и деплой с версионированием. Но все равно спасибо.
Решил написанием скалярной фции, которая работает только с моим частным случаем.
Аноним 12/09/19 Чтв 11:02:03 1472181519
>>1472048
Я бы сделал вот так:

select c.name, COUNT(h.trainee_id)
from history h
left join course c
on h.course_id = c.course_id
where h.cstart = my_start_date and h.cend = my_end_date
and h.status = 1
group by c.name

анон, учти - я полнейший нуб. завтра иду на собес. надеюсь, что меня не обоссут с ТАКИМИ ЗНАНИЯМИ SQL
Аноним 12/09/19 Чтв 11:33:39 1472192520
>>1472181
Анон, спасибо, ты чудо, все работает.
Аноним 12/09/19 Чтв 11:47:13 1472201521
>>1472181
А не подскажешь ещё, как вывести ВЕСЬ список курсов (course_id) в первом столбце, а во втором все так же?
Аноним 12/09/19 Чтв 12:15:23 1472206522
>>1472088
Ну да. Тока скалярные функции у тебя убьют многопоточность навсегда и твои запросы будут работать миллиард лет.

А CLR позволит работать в многопоточном режиме.
Аноним 12/09/19 Чтв 12:15:52 1472207523
>>1472181
Все нормально, бро, желаю удачи!
Аноним 12/09/19 Чтв 19:21:26 1472405524
Хай БД, нужна литература по созданию реальной БД для клиент-серверного приложения (тупа в C# накидаю формы). А то создаю БД, но все не то (MYSQL).
Аноним 12/09/19 Чтв 20:59:39 1472467525
>>1472405

В чем конкретно проблема?
Аноним 12/09/19 Чтв 22:14:59 1472502526
>>1472467
Бд для турфирмы.
Условно базы отдыха могут предоставлять жилье и развлечения и еще что нибудь (по прайс листам), цена на жилье может быть варьироваться от дня недели, каникул и т.д.
Есть музеии которые просто предоставляют что-то одно.
А некоторые турбазы предоставляют вертолет самолет параход и нужно знать что за модель и сколько вмещает эта техника людей.
Питание как и жилье может быть при парке как услуга или в отдельном заведении.


Аноним 13/09/19 Птн 10:57:15 1472698527
>>1412057
Почитай «реляционные базы данных» там очень хорошо основы описанв
Аноним 13/09/19 Птн 15:30:11 1472841528
>>1412057
Можно, если в фап-тредах и рулетках не сидеть, а заниматься.
Аноним 13/09/19 Птн 16:06:41 1472856529
Какой нормальный софт есть для рисования UML и ER диаграмм. Чтоб бесплатно (не возиться с кряками), не тяжелый (гигабайты качать-ставить нет желания), не онлайн (ну или чтоб веб-версию можно было сохранить и использовать автономно) ? Генерация sql желатеьна но не обязательна.

В интернетах сотни решений, но либо онлайн, либо платное монстроузное. А пробовать все подряд - времени нет.
Аноним 15/09/19 Вск 12:30:25 1473634530
Почему все так обожают Oracle DB?
Обычная бд как бд, как postgresql или Mysql
Просто дороха.
Это ведь как бренд Apple
Аноним 15/09/19 Вск 14:05:30 1473673531
>>1473634
Чем она как мускул или постгре?
Аноним 15/09/19 Вск 14:18:21 1473679532
>>1473634
А ты еще, небось, с ксияоми пишешь, да?
Аноним 15/09/19 Вск 17:23:54 1473784533
>>1473673
Также запрос делаешь - так же быстро отвечает.
Главное, бд посадить на SSD
Аноним 15/09/19 Вск 17:24:14 1473785534
>>1473679
Ты это говоришь так, как будто это что-то плохое!
Аноним 15/09/19 Вск 17:29:45 1473789535
Аноним 15/09/19 Вск 17:43:30 1473793536
>>1473789
ты из ТЕХ админов 2003го года, у которых ссд умирают через месяц работы, да?
Аноним 15/09/19 Вск 18:38:13 1473820537
Посоветуйте книги. Я полный ноль в бд
Аноним 16/09/19 Пнд 15:29:16 1474378538
>>1473820
Книги по русскому языку, помогают.
Аноним 18/09/19 Срд 22:42:32 1476463539
Никто тред перекатить не хочет?
Аноним 19/09/19 Чтв 03:58:58 1476582540
>>1472502
Тебе не нужна литература по БД
Она тебе не понадобится до тех пор, пока ты не сможешь на человеческом языке хотя бы для тебя сформулировать задачу
Просто садишься и расписываешь на бумажке, что и как бывает у тебя в жизни, и что с чем связано
Аноним 19/09/19 Чтв 04:00:25 1476583541
>>1473634
>Oracle как mysql
Ахахахахахаха
Все так, анон, все так.
Вообще на монгу переходи, все классные поцаны уже ее пользуют
Аноним 19/09/19 Чтв 04:03:27 1476584542
>>1473673
Ну, посмотрим правде в глаза, у оракла много общего с постгресом.
Ну, кроме цены.
Аноним 19/09/19 Чтв 07:51:14 1476600543
Аноним 20/09/19 Птн 11:45:15 1477475544
Может ли быть 2 FK на одну и ту же таблицу? Нопример:

Table Battle
battle_id: bigint
player1_id: bigint
player2_id: bigint
map_id: bigint
begin_time: timestump
end_time: timestump
result: enum("player1_won", "player2_won", "draw")

Вот если мне надо чтобы 2 игрока были оба из таблицы(но разные записи) "player". Так можно?
Аноним 20/09/19 Птн 17:05:32 1477701545
>>1477475
Это MySQL ?

Можно:
create table Battle (
...
b_player1_id INT NOT NULL,
b_player2_id INT NOT NULL,
...
foreign key(b_player1_id, b_player2_id)
references player(player1_id, player2_id)
)

Вполне возможно, что я обосрался. Тут уже извини
Аноним 20/09/19 Птн 17:33:40 1477722546
>>1477475
Почему нельзя? Можно, конечно.
Можно даже чтобы таблица имела FK на саму себя.
Аноним 20/09/19 Птн 19:48:34 1477778547
>>1477701
Не, это постгрес. Но там тоже походу можно.
Аноним 21/09/19 Суб 05:32:02 1478187548
Хотел спросить тут. Вычитывал понятие "Хорошое знание маскуэл/постгресс". Вот вопросы: в чем сложность баз данных? Что там изучается такого на отдельную категорию? Что отличает хорошего базданщика от плохого?
Ну хранится там инфа по столбцам и что дальше?
Аноним 21/09/19 Суб 10:26:46 1478221549
>>1478187
Ничего, в принципе, смело можешь идти на собеседование.
Главное, что ты знаешь, что в базе хранится инфа по столбцам, в 99% этого хватает, чтобы взяли.
Аноним 21/09/19 Суб 12:00:00 1478244550
Я не понимаю, почему обычный индекс для текстовых полей в монге работает медленно, а текстовый индекс для полнотекстового поиска работает быстро.
Аноним 21/09/19 Суб 14:37:44 1478315551
>>1478244

Запрос покажи, зая.
Аноним 21/09/19 Суб 14:41:01 1478317552
>>1478315
Вообще запрос выглядит как $or по всем полям с каким-то текстовым значением. Про медленные индексы в интернете пишут.
Аноним 22/09/19 Вск 03:53:23 1478790553
Нужно в монгоДБ отсортировать инфу по минутам.
Как это сделать?
Аноним 22/09/19 Вск 20:50:57 1479389554
По hbase сюда писать?
Аноним 23/09/19 Пнд 16:28:21 1479912555
certificate-all[...].jpg (111Кб, 650x920)
650x920
Аноним 23/09/19 Пнд 18:27:43 1480066556
>>1479912
За эту цену - говно.
Я в резюме на хх просто ссылку на профиль вставил 7 лет назад, кому надо было - смотрели сами.
Аноним 24/09/19 Втр 21:34:33 1481026557
Привет!
Есть учебная задача: реализовать базу данных на ~20 таблиц + клиент-серверное приложение для доступа к ней.
Язык важен, концепция (реляционная бд или NOsql) тоже.

Пока что есть идея сделать реляционную базу данных и приложение на питоне в силу его простоты (работал с питоном немного, но бд на нем не трогал). Насколько я знаю, в питоне есть встроенная поддержка SQLite. Стоит ли пользоваться им или лучше накатить какую-нибудь SQLAlchemy и делать через нее?

У кого есть опыт такой разработки? Какие подводные? Какие можете дать советы?
Буду рад любой критике/комментариям, спасибо.
Аноним 25/09/19 Срд 20:42:39 1481709558
Сап, датабазычи.
Есть один проект в котором надо хранить реальный граф (пока маленький, около 10-15к строк). В процессе появления первой версии, родилось решение и использованием Postgres, и для уже сейчас DAO слой вышел достаточно нагруженным - граф вытягивается по 4 таблицам (таблица с метаданными по графу, таблица с гранями, таблица с узлами, таблица с метаданными по узлам), вместе с кучкой промежуточных преобразований в коде. В последствии будет ещё больше, например n2n связь между узлами и графами или вложенные графы

Возникла идея перевести все на графовую БД (пока смотрю на neo4j и dgraph). Есть здесь у кого-нибудь опыт использования такой вуду-техники? Был бы рад увидеть сравнения или отзывы
Аноним 25/09/19 Срд 20:49:57 1481713559
>>1481709
Fix. В начале речь идёт не о размере графа, а о размере проекта. Собственно, графы большого размера не ожидаются, так что в произвольность постгри я скорее всего не упрусь. Другое дело - сложность поддержки кода
Аноним 25/09/19 Срд 22:38:12 1481781560
>>1481709
использовал нео4ж в связке с реляционной базой
хранил деревья: информацию о графе в нео, всю информацию об объектах - в реляционной
как только выяснил, что деревья у меня не могут быть глубже 5 уровней, выкинул на хер нео
в паре мест пятиэтажные селекты (был какой-то мускл, поэтому без иерархических запросов)
зато все аккуратно с транзакциями, не надо вытирать сопли за нео4ж, который время от времени что-то терял
Аноним 28/09/19 Суб 23:43:58 1484166561
Может кто нибудь за 2 килорубля помочь с тестеком по SQL?
Аноним 28/09/19 Суб 23:56:10 1484181562
>>1484166
Тест для более - менее шарящих людей будет не сложным.
Вряд ли потратите на него более двух часов (а скорее всего лишь час)
Писать сюда [email protected]
Аноним 29/09/19 Вск 18:55:28 1484720563
>>1461571
Двачую этого господина.
Аноним 03/10/19 Чтв 10:09:08 1487711564
image.png (10Кб, 504x87)
504x87
USE testdata;
DECLARE @i INT;
SET @i = 0;
WHILE @i < 10 DO
SET @i= @i + 1;
END;
SELECT @i;

Почему ругается на вторую строку? MariaDB
Аноним 03/10/19 Чтв 10:39:32 1487719565
>>1487711
Насколько помню в этой уебищной субд инту тоже надо длину в скобках указывать.
Аноним 03/10/19 Чтв 10:51:46 1487722566
>>1487719
INT(100) что-ли? Да там даже просто DECLARE @i; ругается без инта
Аноним 03/10/19 Чтв 23:05:57 1488312567
Аноним 08/10/19 Втр 14:38:37 1491668568
Суп программач. Подскажи неопытному, есть ли проверенный и правильный способ (алгоритм, метод, подход) для реализации графов в SQL базах данных. У меня postgres, если очень грубо, стоит задача реализации склада. Пример простой. Есть товар в штуках, штуки могут разделяться и объединяться, соответственно у каждого товара может быть как один так и много родителей (в случае если это объединение). Вот вопрос, как правильно сделать граф и не накостылять при этом. Спасибо.
Аноним 08/10/19 Втр 16:48:56 1491758569
Как реализовать if-then в запросе?

Типа
IF (SELECT %возвращает булево выражение%)
THEN UPDATE %что-нибудь%
Аноним 08/10/19 Втр 17:29:17 1491778570
Антуаны, посоветуйте, пожалуйста, что-нибудь толковое почитать про недостатки (и, возможно, достоинства) SQL/NoSQL СУБД. Интересует прежде всего набор граблей, который обязательно прилагается к SQL/NoSQL (ну там простая/нереализуемая горизонтальная масштабируемость, простая/геморная расширяемость и т. п.). Также приветствуются кулстори от всяких компаний, которые попробовали использовать <вставить название СУБД> для своих целей и дико облажались из-за недостатков 1), 2), 3) данной СУБД.
Аноним 09/10/19 Срд 20:25:47 1492567571
Есть ли какие-то правила/практики указания порядка ключей в джойнах?

https://pastebin.com/k8BrraWB
Настройки X
Ответить в тред X
15000 [S]
Макс объем: 40Mб, макс кол-во файлов: 4
Кликни/брось файл/ctrl-v
Стикеры X
Избранное / Топ тредов