- 01
- 02
- 03
- 04
- 05
- 06
- 07
- 08
- 09
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
//Николай
//проверяем артикул и если его нет, то генерируем
Если ПустаяСтрока(Артикул) Тогда
Запрос = Новый Запрос("ВЫБРАТЬ
| МАКСИМУМ(Номенклатура.Артикул) КАК ТекАртикул
|ИЗ
| Справочник.Номенклатура КАК Номенклатура");
Выборка = Запрос.Выполнить().Выбрать();
Выборка.Следующий();
ТекКод = ?(Выборка.ТекАртикул = NULL, 1, Мин(ОбщегоНазначения.ПривестиСтрокуКЧислу(Выборка.ТекАртикул) + 8000, 9999999));
ТекАртикул = Формат(ТекКод, "ЧЦ=7; ЧВН=; ЧГ=");
//проверяем дальше
Выход=0;
Пока Выход=0 Цикл
Запрос = Новый Запрос("ВЫБРАТЬ
| Номенклатура.Артикул КАК ТекАртикул
|ИЗ
| Справочник.Номенклатура КАК Номенклатура
|ГДЕ
| Номенклатура.Артикул = &Артикул");
Запрос.УстановитьПараметр("Артикул", ТекАртикул);
Выборка = Запрос.Выполнить().Выбрать();
Нашли = Выборка.Следующий();
Если Нашли Тогда
ТекАртикул=Мин(ОбщегоНазначения.ПривестиСтрокуКЧислу(ТекАртикул) + 1, 9999999);
ТекАртикул = Формат(ТекАртикул, "ЧЦ=7; ЧВН=; ЧГ=");
Иначе
Выход=1;
КонецЕсли
КонецЦикла;
Артикул=ТекАртикул;
КонецЕсли;
//Николай
Задача: сформировать артикул (число) из 7и знаков по формуле "максимальный артикул + 1". при этом тип реквизита - строка(7). В базе встречаются значения "945784 ", "98763443".
istem 15.01.2011 07:32 # +11
tr00_gr1m_doomster 15.01.2011 14:32 # 0
eee_qqq 15.01.2011 19:07 # +14
...
КонецНиколай
Анонимус 16.01.2011 09:16 # +3
и нервный припадок
topilnik 13.03.2011 02:50 # −1
Анонимус 16.01.2011 09:15 # 0
//сиди дома, не гуляй
скажите, они SQL тоже на русский перевели?
guest 16.01.2011 20:49 # +2
Lure Of Chaos 17.01.2011 00:11 # 0
bugmenot 17.01.2011 00:41 # +6
...
<неколай>
istem 17.01.2011 01:21 # +8
<ЯРГТ>
<голова>
<надмозг> </надмозг>
</голова>
<тело>
</тело>
<!-- <тэги вырезаны цензурой> -->
</ЯРГТ>
eee_qqq 17.01.2011 00:24 # −1
Анонимус 18.01.2011 08:24 # 0
g00d 01.03.2011 02:16 # 0
guest 14.06.2013 21:59 # 0
fdkslaf 19.01.2011 05:51 # +3
Остается только удивляться, почему бухгалтерия всё время бегает к айтишникам с жалобами на тормоза. И с чего бы им жаловаться на такой замечательный код? Уж не потому ли, что при определенной комбинации номеров, процедура будет в цикле перебирать все номера базы? Нет! Конечно же нет!
...Ну почему нельзя было написать что-то вроде:
g00d 01.03.2011 02:18 # −3
g00d 01.03.2011 02:14 # −2