Поиск по двум реквизитам |
Я |
05.01.10 — 13:45
А есть ли поиск по двум реквизитам в справочники а точнее по наименованию и + еще один реквизит ?
1 — 05.01.10 — 13:46
(0)Хоть 10.
Юзай найти строки и стуктуру
2 — 05.01.10 — 13:46
Да хоть по всем. Запросом.
3 — 05.01.10 — 13:46
есть запросом, есть НайтиСтроки (FindRows)
Табличная часть
НайтиСтроки (FindRows)
Синтаксис:
НайтиСтроки(<Параметры отбора>)
Параметры:
<Параметры отбора> (обязательный)
Тип: Структура. Задает условия поиска: ключ структуры определяет имя колонки, по которой будет осуществляться поиск, а значение структуры — искомое значение.
Возвращаемое значение:
Тип: Массив. Массив из строк табличной части, соответствующих заданному условию поиска.
Замечание! Массив хранит ссылки на строки табличной части, то есть при изменении строки в табличной части, значение в массиве тоже будет изменено.
4 — 05.01.10 — 13:47
(1) Злой ты.
5 — 05.01.10 — 13:47
а при чем здесь табличная часть?
6 — 05.01.10 — 13:47
запрос — раз
два?
7 — 05.01.10 — 13:48
(4)Клевета!:))
8 — 05.01.10 — 13:49
(6) (3) и есть два.
Или это экзамен по копипасту с СП?
СправочникМенеджер.<Имя справочника> (CatalogManager.<Имя справочника>)
Выбрать (Select)
Синтаксис:
Выбрать(<Родитель>, <Владелец>, <Отбор>, <Порядок>)
9 — 05.01.10 — 13:50
(8) Лень снеговика открывать, но имхается мне, что в Отборе — только одно значение задать можно…
10 — 05.01.10 — 13:51
(9) а, ну да
<Отбор> (необязательный)
Тип: Структура. Задает поле и значение отбора открываемой выборки. Ключ структуры описывает имя поля, а значение структуры — значение отбора по этому полю. В качестве полей для отбора могут задаваться только поля «Код», «Наименование» и реквизиты справочника, для которых в конфигураторе признак индексирования установлен в значение «Индексировать» или в значение «Индексировать с доп. упорядоч.».
Важно! Структура может содержать только один элемент.
Если параметр не указан, то отбор не используется
11 — 05.01.10 — 13:51
<Отбор> (необязательный)
Тип: Структура. Задает поле и значение отбора открываемой выборки. Ключ структуры описывает имя поля, а значение структуры — значение отбора по этому полю. В качестве полей для отбора могут задаваться только поля «Код», «Наименование» и реквизиты справочника, для которых в конфигураторе признак индексирования установлен в значение «Индексировать» или в значение «Индексировать с доп. упорядоч.».
Важно! Структура может содержать только один элемент.
Если параметр не указан, то отбор не используется.
12 — 05.01.10 — 13:52
ну так запрос — раз
два?
13 — 05.01.10 — 13:54
(12) тоже запрос! да?
14 — 05.01.10 — 13:54
(12) Ну как же! Поиск по одному реквизиту плюс перебор
15 — 05.01.10 — 13:55
вообщем только запрос получается раз и все
16 — 05.01.10 — 13:58
спасибо всем
17 — 05.01.10 — 13:59
(16) А чем запрос-то не устраивает? Самое оно же ведь.
18 — 05.01.10 — 14:00
Выгрузить в ТЗ и (1). Но я ж говорю — злой он
В любом случае это будет запрос к БД, так зачем усложнять?
19 — 05.01.10 — 14:03
(18)Аа!..Точно не добрый:))
20 — 05.01.10 — 14:04
(17) а ни кто не говорит что ни оно, просто забыл про запрос.
21 — 05.01.10 — 14:04
(20) Эт ты зачем так??? Запорс — это первое, что должно в голову приходить при работе с БД…
22 — 05.01.10 — 14:05
не с начало пришло НайтиПоРеквизиту
23 — 05.01.10 — 14:06
(22) Зря…
24 — 05.01.10 — 14:07
может быть
25 — 05.01.10 — 14:07
(24) Да точно!
26 — 05.01.10 — 14:08
(22) Семерочное прошлое говорит. Пройдет
27 — 05.01.10 — 14:14
(26) угу
28 — 05.01.10 — 14:14
(26) А мое семерошное прошлое и настоящее как раз (21) и говорит…
29 — 05.01.10 — 14:24
А вот три:
Выборка = Справочники.Номенклатура.Выбрать();
Пока выборка.Следующий() Цикл
Если Выборка.Наименование = «Супер товар» И
Выборка.Реквизит = СуперРеквизит Тогда
//Ура нашли , но мало ли продолжаем искать )))
Сообщить(Выборка.Код);
КонецЕсли;
КонецЦикла;
30 — 05.01.10 — 14:26
(29) А теперь в (14) загляни…
31 — 05.01.10 — 14:28
(30) Дык у меня сразу перебор .
32 — 05.01.10 — 14:28
(31) Точно… Пардон-с…
33 — 05.01.10 — 14:31
(14) (29) изврат все имхо метод перебор
34 — 05.01.10 — 14:32
(33) Смайлики видишь? А они есть!
YHVVH
35 — 05.01.10 — 14:32
(34)
Стояла задача найти Конрагента в справочнике по ИНН и КПП (кто знает, что такое обособленное подразделение, поймет). Логика проста — найти по ИНН, сверить КПП, если нет добавить.
Найдено=Справочники.Контрагенты.НайтиПоРеквезиту(«ИНН»,ИскомыйИНН);
Если Найден=Справочники.Контрагенты.ПустаяСсылка() Тогда
//СОЗДАТЬ КОНТРАГЕНТА
Иначе
Если Найдено.КПП=ИскомыйКПП Тогда
Сообщить(«Найден филиал контрагента»);
Иначе
//СОЗДАТЬ ФИЛИАЛ КОНТРАГЕНТА
КонецЕсли;
КонецЕсли;
И тут фэйл, мои дорогие, если в справочнике существует и филиал и ГО, то он кого-то по-любому не найдет. А все кроется в:
Возвращаемое
значение:
Тип: СправочникСсылка.
Ссылка на найденный элемент справочника. Если не существует ни одного
элемента с требуемым значением реквизита, то будет возвращена пустая ссылка.
Если найдено более одного, функция вернет только первое вхождение…неприятно, однако…
Пошел искать другие пути и набрел на два варианта:
Выборка()
ПараметрПоискаИННОтбор=Новый Структура;ПараметрПоискаИННОтбор.Вставить(«ИНН»,ИскомыйИНН);
Выборка=справочники.контрагенты.Выбрать(,,ПараметрПоискаИННОтбор);
Пока Выборка.Следующий() Цикл
КППНайден=Ложь;
Если Выборка.КПП=ИскомыйКПП Тогда
Сообщить(«Найден филиал контрагента»);
КППНайден=Истина;
Прервать;
//Мне дальше не нужно
КонецЕсли;
КонецЦикла;
Если КППНайден=Ложь Тогда
//СОЗДАТЬ ФИЛИАЛ КОНТРАГЕНТА
КонецЕсли;
И второй
Новый Запрос
ЗапросПоискИНН=Новый Запрос(«ЗапросПоискИНН»);ЗапросПоискИНН.Текст=«ВЫБРАТЬ
|Контрагенты.Ссылка
|ИЗ
|Справочник.Контрагенты КАК Контрагенты
|ГДЕ
|Контрагенты.ИНН = &ИНН»;
ЗапросПоискИНН.Параметры.Вставить(«ИНН»,ИскомыйКПП);
Выборка=ЗапросПоискИНН.Выполнить().Выбрать();
Пока Выборка.Следующий() Цикл
КППНайден=Ложь;
Если Выборка.КПП=ИскомыйКПП Тогда
Сообщить(«Найден филиал контрагента»);
КППНайден=Истина;
Прервать;
//Мне дальше не нужно
КонецЕсли;
КонецЦикла;
Если КППНайден=Ложь Тогда
//СОЗДАТЬ ФИЛИАЛ КОНТРАГЕНТА
КонецЕсли;
В Запросе можно добавить еще один параметр, чего не сделаешь в Выборке.
Но, у обоих вариантов есть минус, а именно:
Если Выборка.Следующий()=Справочники.Контрагенты.ПустаяСсылка() Тогда
//ЧЕГО ТО ТАМ;
КонецЕсли;
А дальше цикл ПокаЦикл. Блок «если», в этом случае, съест первую итерацию, и потом может кого-то обломать.
Короче, вся эта фигня к тому, что не надо использовать Выборка.Следующий() как условие, можно проверить по Выборка.Количество() или Выборка.Пустой().
Запрос к справочнику по нескольким реквизитам
Автор Keen Gaff, 20 окт 2020, 19:32
0 Пользователей и 1 гость просматривают эту тему.
Доброго дня.
Платформа 8.3.16, конфигурация самописная + БСП 3.
Пытаюсь найти запись в справочнике запросом по нескольким реквизитам.
Запрос1.Текст =
"ВЫБРАТЬ
| Показатели.Ссылка КАК Ссылка
|ИЗ
| Справочник.Показатели КАК Показатели
|ГДЕ
| Показатели.Наименование = &Наименование
| И Показатели.ДопустимыйУровень = &ДопустимыйУровень
| И Показатели.НДНаИзмерения = &НДНаИзмерения
| И Показатели.ГруппаОбразцов = &ГруппаОбразцов";
Запрос1.УстановитьПараметр("Наименование", Показатель); //строка
Запрос1.УстановитьПараметр("ДопустимыйУровень", ДопУровень); //строка
Запрос1.УстановитьПараметр("НДНаИзмерения", НДНаИзмерения); //справочник.ссылка
Запрос1.УстановитьПараметр("ГруппаОбразцов", ГруппаОбразца); //справочник.ссылка
Результат пустой… не находит (хотя точно есть)).
Консоль запросов тоже не находит.
В чем может быть беда?
совет , получите данные сначала без параметров, т.е. это будут очевидно все ссылка этого справочника.
потом добавьте один параметр. Если сработает, добавтье следующий и т.д.
Использую учебную платформу 1С:Предприятие 8.3
Цитата: Keen Gaff от 20 окт 2020, 19:32
Доброго дня.
Платформа 8.3.16, конфигурация самописная + БСП 3.
Пытаюсь найти запись в справочнике запросом по нескольким реквизитам.Запрос1.Текст =
"ВЫБРАТЬ
| Показатели.Ссылка КАК Ссылка
|ИЗ
| Справочник.Показатели КАК Показатели
|ГДЕ
| Показатели.Наименование = &Наименование
| И Показатели.ДопустимыйУровень = &ДопустимыйУровень
| И Показатели.НДНаИзмерения = &НДНаИзмерения
| И Показатели.ГруппаОбразцов = &ГруппаОбразцов";
Запрос1.УстановитьПараметр("Наименование", Показатель); //строка
Запрос1.УстановитьПараметр("ДопустимыйУровень", ДопУровень); //строка
Запрос1.УстановитьПараметр("НДНаИзмерения", НДНаИзмерения); //справочник.ссылка
Запрос1.УстановитьПараметр("ГруппаОбразцов", ГруппаОбразца); //справочник.ссылка
Результат пустой… не находит (хотя точно есть)).
Консоль запросов тоже не находит.
В чем может быть беда?
Показатель.Наименование = &Наименование — это очень скользкий параметр. Ошибетесь в немного и ни чего уже не найдено, используйте уж тогда ПОДОБНО. Так же и с Показатели.ДопустимыйУровень = &ДопустимыйУровень.
Спасибо, попробовал.
в консоли находит по трем (если не использовать параметр «НДНаИзмерения»)
по одному параметру «НДНаИзмерения» тоже не находит… буду смотреть что с ним не так…
Добавлено: 20 окт 2020, 22:34
Цитата: DmitriyF от 20 окт 2020, 19:41
Показатель.Наименование = &Наименование — это очень скользкий параметр…
дублирование убрал… не помогло
выяснилось (через консоль запросов) странно работает условие по реквизиту ссылочного типа НДНаИзмерение,
выбираю одну запись справочника, запрос срабатывает, если другую то пусто… как так?
При работе с таблицами справочника есть методы НайтиПоРеквизиту и НайтиПоКоду в итоге получаем найденную запись и делаем с ней что хотим. Вопрос как найти получить запись поиском по нескольким реквизитам? Т.е. сделать не Выборку, а именно установить курсор на найденной по нескольким реквизитам записи?
1С 8.2 Мне Запрос не нужен. Необходимо получить для редактирования искомую строку.
по идейным соображениям запрос не нужен?
+4 разрешаю искать перебором, раз запрос не нужен
ну так получи. В чём вопрос то? Есть такой метод… НайтиСтроки…
самое оптимальное запрос с параметром подобно
НайтиСтроки вроде бы ищет только в табличных частях справочника, а не сами записи справочника?
подобно — ни разу не отпимально
ещё в ТЗ. пробегись по выборке, засунь всё в ТЗ, потом ищи строки. раз уж религия такая
а… в справочнике… Запрос. Или в лес. Ну или на Привоз
сам запутался в своём СП. Какая ирония
Запросом можно искать, но много писанины (создать запрос, по том перебирать и искать по коду). Этоже самое к примеру в Фоксе можно сделать одной командой (типа Locate for)
зато работает как надо. купи гуся
Выборка конечно лучше получая все поля объекта и помещая в ОЗУ. А запрсом получаем нужные поля. Если поиск по нескольким реквизитам и по трем набранным буквам сделать поиск с помощью объектной модели как то затруднительно.
зачем искать по коду? достаточно правильно создать запрос, тем более текст запроса достаточно «накликать» в конструкторе запросов
потом перебирать? срочно дружись с запросами, у тебя пусто в голове
если ты не любишь Запросы, ты не можешь называть себя одинесником
я! я не люблю! семёрочные. у меня от них начинает кружиться голова и возникает необъяснимое чувство тревоги и страха
таки вперёд на Привоз покупать гуся…
если ты боишься запросов, выпей 50 грамм. Алкоголь притупляет чувство страха
500 будет в самый раз для притупления. только я ж работать не смогу
а ты ещё и работаешь? О_о
поработаешь тут с вами. я в отпуске загораю
бить надо за найтипоКоду и поРеквизиту. Больше ими не пользуйся
Я может чёт не понимаю. После запроса пишем: Выборка=РезультатЗапроса.Выбрать; Выборка — это же виртуальная таблица, а как мне получить реальную запись справочника, не используя Справочник.НайтиПоКоду(Выборка.Код)
Выборка это скорее курсор SQL (ближе к нему) Выборка.Ссылка — если есть конечно поле такое в запросе, дает ссылку на запись справочника
За Выборка.Ссылка спасибо,это понятно. Я не очень 1С — ник. Так что плаваю в структуре языка. А ППЦ в голове у Defender aka
Тэги: 1С 8
Комментарии доступны только авторизированным пользователям
Найти элемент справочника в 1С 8 можно тремя способами:
1) Поиск по коду
Если известен код элемента справочника, и необходимо получить ссылку на него, то можно воспользоваться методом НайтиПоКоду(<Код>, <ПоискПоПолномуКоду>, <Родитель>, <Владелец>) менеджера справочника. В простейшем случае необходимо передать данному методу код элемента справочника и в результате будет получена либо ссылка на элемент справочника, либо пустая ссылка, если элемент с таким кодом не найден. Следует заметить, что если в справочнике присутствует несколько элементов с указанным кодом, то будет возвращен тот, который найден первым.
Пример:
НайденныйЭлемент = Справочники.Номенклатура.НайтиПоКоду("00000011254");
Описание параметров метода НайтиПоКоду:
- <Код> (обязательный). Тип: Число, Строка. Описание: искомый код, строка или число в зависимости от настроек справочника в конфигураторе.
- <ПоискПоПолномуКоду> (необязательный). Тип: Булево. Описание: определяет режим поиска по полному коду, истина — искомый код следует задавать в виде строки, состоящей из последовательности кодов по уровням справочника, разделенных символом “/”. Значение по умолчанию: Ложь.
- <Родитель> (необязательный). Тип: СправочникСсылка. Описание: родитель, в пределах которого нужно выполнять поиск, если не указан, то поиск будет проводиться во всем справочнике.
- <Владелец> (необязательный). Тип: СправочникСсылка. Описание: владелец, в пределах которого нужно выполнять поиск, если не указан, то поиск будет проводиться во всем справочнике.
2) Поиск по наименованию
Наша команда предоставляет услуги по консультированию, настройке и внедрению 1С.
Связаться с нами можно по телефону +7 499 350 29 00.
Услуги и цены можно увидеть по ссылке.
Будем рады помочь Вам!
Если известно наименование элемента справочника и необходимо получить ссылку на него, то можно воспользоваться методом НайтиПоНаименованию(<Наименование>, <ТочноеСоответствие>, <Родитель>, <Владелец>) менеджера справочника. В простейшем случае необходимо передать данному методу наименование элемента справочника и в результате будет получена либо ссылка на элемент справочника, либо пустая ссылка, если элемент с таким наименованием не найден. Следует заметить, что если в справочнике присутствует несколько элементов с указанным наименованием, то будет возвращен тот, который найден первым.
Пример:
НайденныйЭлемент = Справочники.Номенклатура.НайтиПоНаименованию("Аппарат сварочный");
Описание параметров метода НайтиПоНаименованию:
- <Наименование> (обязательный). Тип: Строка. Описание: строка, содержащая искомое наименование.
- ТочноеСоответствие> (необязательный). Тип: Булево. Описание: определяет режим поиска по полному соответствию, поиск будет успешным, если строка поиска: в случае значения параметра Ложь — будет соответствовать левой части наименования, в случае значения параметра Истина — будет полностью совпадать с наименованием (за исключением “хвостовых” пробелов в наименовании). Значение по умолчанию: Ложь.
- <Родитель> (необязательный). Тип: СправочникСсылка. Описание: родитель, в пределах которого нужно выполнять поиск, если не указан, то поиск будет проводиться во всем справочнике.
- <Владелец> (необязательный). Тип: СправочникСсылка. Описание: владелец, в пределах которого нужно выполнять поиск, если не указан, то поиск будет проводиться во всем справочнике.
3) Поиск по произвольному реквизиту
Если известно значение какого либо реквизита справочника и необходимо получить ссылку на него, то можно воспользоваться методом НайтиПоРеквизита(<ИмяРеквизита>, <ЗначениеРеквизита>, <Родитель>, <Владелец>) менеджера справочника. В простейшем случае необходимо передать данному методу имя реквизита, его значение и в результате будет получена либо ссылка на элемент справочника, либо пустая ссылка, если элемент с таким значением указанного реквизита не найден. Следует заметить, что если в справочнике присутствует несколько элементов с таким значением указанного реквизита, то будет возвращен тот, который найден первым.
Пример:
НайденныйЭлемент = Справочники.Номенклатура.НайтиПоРеквизиту("Артикул","А-255");
Описание параметров метода НайтиПоРеквизит:
- <ИмяРеквизита> (обязательный). Тип: Строка. Описание: имя реквизита, как он задан в конфигураторе, по значению которого осуществляется поиск. Тип значения: произвольный, кроме ХранилищеЗначения и строк произвольной длины.
- <ЗначениеРеквизита> (обязательный). Тип: Произвольный. Описание: значение реквизита, по которому должен выполняться поиск.
- <Родитель> (необязательный). Тип: СправочникСсылка. Описание: родитель, в пределах которого нужно выполнять поиск, если не указан, то поиск будет проводиться во всем справочнике.
- <Владелец> (необязательный). Тип: СправочникСсылка. Описание: владелец, в пределах которого нужно выполнять поиск, если не указан, то поиск будет проводиться во всем справочнике.
Помогаю со студенческими работами здесь
Объектно-ориентированный аналог телефонного справочника: поиск по нескольким параметрам одновременно
Здравствуйте! Помогите, пожалуйста, с задачей!
Создать объектно-ориентированный аналог…
Выбор справочника
Добрый день! Пытаюсь реализовать выбор нужного мне справочника, задача стоит если значение…
Хитрый выбор из справочника
Подскажите как сообразить следующий выбор.
Есть вот такой пиклист, с помощью него происходит…
Выбор значаний из справочника
Добрый день!
Скажите, пожалуйста, как решить такую проблему.
Есть документ, в поле которого…
Искать еще темы с ответами
Или воспользуйтесь поиском по форуму:
2
���� ������� �� ���������� �������. ���������� ����� ������, �������� ���� ���������� ������� ��������� � ���������. ����� �� ������ ��������� ���� �����������, ����� ��������, �� ��������� ������������ ���������� ����. ����� ���� �������� ����� ������� �������� ���� �����? ��� ����� ������� — ����������.
��������:
1. ���������� �� 1� �������, ����� ����������� �������
2. � ��������� ������� ������� ����������, �.�. ���������� ���� �� �����, �� ������� �� ���� �����, � �� ������ �����
�� �������:
� 1�++ ������ 2� ���� ������ «��������������� �������» — ��� ����� ��������� ������ � �.�. � �� ���� ��������.
� ���� ��� ���� ����� ������� ����� �������, ��������� ţ ��������, ����������� ��� ���������� ���� �������� ����� � ������ �� ���� ������� ����������� �������.
�������� ��� ���� ������� � ������� � ��� �������� ���� ���� �������:
��.��������� = ��������������������(��.�������1.��������������()) + ��������������������(��.�������2.��������������())
����� ������ �� ���� �������.
��� ������������ ��������������� ��������.
� ������� �� ��������� ������
��������=����� ���������(«��������, ���», �������.����������1, _���);
_�����=_�������.�����������(��������);
��� 8-�� ������, �� ������ � �������� ���� � ����� ���� ��������� !!
������� ���� ��� ������� � 80 �� 81 � ���
����� �������� ���� 2 ������ � 77 — ��� ����� ����� �����������
��� ���� �� SQL, SQL �� ��� ������
��� �� sql, ��� �����
� ��� sql ���� � 77 �������� ���������� ������ ��������, ������� � ������������� � �� ������������������ «�������������» 8�…
���� �� �������� ���������� ���������� 8� ������������� 7.7 ��� 1×10, �� ���������� ���������� ��������, ���� �������� �������� ������ �����…
����� ����� � ������� ���������� �� ���������� ����������?
�� �������������� ������������ ����������?
hjhkjh �����(�)
���� �� �������� ���������� ���������� 8� ������������� 7.7 ��� 1×10
��� ��� ���������� �������� ������, ���� ������ 5 ���������� + ������� + ����� �� 30 �����.
������� ������ �������, ��� �����������, ����� ���� �� ���������� ��������� � �������������� ��.
������� ������� ��������� ����� � �����������. ���� ����� ���� �������, � ����������� ��������� ��� ��������� ���� �� ��� �������������� ��������.
— ��� �� ������� ��� ������? — ������� ���������.
— �������,— ���������� �����.
— � ��� �� ������� ����?
— �������, ����������,— ������� ������.
— � ���� ����� ���� ���������?
— ��, ���������, � ����� �������,— ���������� ������, ����������� �� ������� �� ��� ����������� �������.
��������� ��������� � ����������� �������: — ����������, � ����� �� �� ������� ?
���������� �������� !! ����� ����, �� ���������� ��������� � �������������� ��������� ����, ����� ���� 100 % �������, �������� ���� �� ���� ��� �� ������
���� �� ������������� ���������, �� ������ ������, ��� ��� ����� «��� �������». ���� ���������� ���-�� �����, ������� ����� ������ �� ��������� 8� �� ��������� � 77, �� ��� ��� ����������� ��������. ������������, � ������, ���� �������� ���������� ���� � 10 ��� ������?
����� ����������?
(� 80 ������ «�� �� ��������»)
������ ��� ��������…�� ������ ����� ������ ���������� 1�7.7 ��� ���������� ������������ ���������� ������������� ����� 150…, ��� ����������� ����������������… � ����� �� ��� ������ ����� �������: 6.0 ���� ����� ��������� � ���� ���� «�������» ��������, ������ ������ � ��� ���� ��� ����������
— �����, �������, ������ ������ � sql, ����� 200 �������������
— 60vs77 � 77+sql vs 8� — ��������� �����������
— �� ����� ���������� �� ���������������� ���� �������� ��� � �������� ����������. �� 8� ����� �������������� ����������, �� ��� ���.
���� ������ ������������� ����� ��������� �� 150 �������������, ����� — 8�. ��, �����, � �� ������� � 77! ���������� ��� 77 ����� �������������� � ������������ � �������������� ������� ���������.
�������� 7.7 ������� ���
����� ����� �� �����. ��� � ������� ��� 1 ������ 3.
�ӣ 1� �� 1�, ������ ;).
�� ����������, �����, �� ���� ��������� ������������ ��� ��������� — ������� �������. ��, �������, �� ������ ������� — mercury.tgc6.ru:81/dm/humour/
«PR, Mex ‘������ ���������’.mp3»
� ���� 81-� ���� ������ — �� ����������
������ SQL-������� ��� ������ �������, ��-��-��…
���
��� ����� — �� ��� �����….
…���-�� ������, ��� ����� �� ��� �����… �����!