Значение счетчика

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
pstrkim
Новичок
Новичок
 
Сообщения: 30
Зарегистрирован: 03.01.2007 (Ср) 23:53

Значение счетчика

Сообщение pstrkim » 19.02.2007 (Пн) 16:31

Я добавляю новую запись recordset.AddNew. В recordsete есть поле счетчика. Можно ли получить его значение еще до сохранения записи?

Niko
Продвинутый пользователь
Продвинутый пользователь
Аватара пользователя
 
Сообщения: 102
Зарегистрирован: 16.03.2006 (Чт) 14:43

Сообщение Niko » 19.02.2007 (Пн) 16:41

вроде нельзя.
но можно его получить после сохранения и если не устраивает удалить всю запись :lol:

dr.MIG
Гуру
Гуру
Аватара пользователя
 
Сообщения: 1441
Зарегистрирован: 18.12.2004 (Сб) 9:53
Откуда: г.Ярославль

Сообщение dr.MIG » 19.02.2007 (Пн) 17:06

pstrkim писал(а):Можно ли получить его значение еще до сохранения записи?

Выбрать максимальное значение из данного поля (Счётчик) и прибавить к нему 1.
Salus populi suprema lex

GSerg
Шаман
Шаман
 
Сообщения: 14286
Зарегистрирован: 14.12.2002 (Сб) 5:25
Откуда: Магадан

Сообщение GSerg » 19.02.2007 (Пн) 18:13

Да, топор тоже помогает от головы, но стоит ли :)
Как только вы переберёте все варианты решения и не найдёте нужного, тут же обнаружится решение, простое и очевидное для всех, кроме вас

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 20.02.2007 (Вт) 8:25

Что за база?
Если Access, то используй серверный курсор, после rs.AddNew в поле счетчика будет актуальное значение.
Если MSSQL, то используй серверный курсор, после добавления записи в поле счетчика будет актуальное значение. Но в этом случае более правильно использовать хранимую процедуру, которая будет определять значение счетчика по @@IDENTITY и при необходимости возвращать его.
Для остальных СУБД читай документацию.
Lasciate ogni speranza, voi ch'entrate.

Andrey Fedorov
Член-корреспондент академии VBStreets
Член-корреспондент академии VBStreets
 
Сообщения: 3287
Зарегистрирован: 21.05.2004 (Пт) 9:28
Откуда: Москва

Сообщение Andrey Fedorov » 20.02.2007 (Вт) 9:23

alibek писал(а):Что за база?
Если Access, то используй серверный курсор, после rs.AddNew в поле счетчика будет актуальное значение.
Если MSSQL, то используй серверный курсор, после добавления записи в поле счетчика будет актуальное значение.


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

И нафига значение этого поля нужно до Update - все одно в связанную таблицу запись не добавить.

Посему лучше клиентский курсор и:

Код: Выделить всё
r.AddNew
r!... = ...
r.Update
MyID =r!ID


А @@IDENTITY - это в процедурах на стороне сервера удобно пользовать, на клиенте проще значение поля считать, как выше приведено...
Фиг Вам! - Сказал Чебурашка, обгладывая Крокодила Гену...

alibek
Большой Человек
Большой Человек
 
Сообщения: 14205
Зарегистрирован: 19.04.2002 (Пт) 11:40
Откуда: Russia

Сообщение alibek » 20.02.2007 (Вт) 9:31

Andrey Fedorov писал(а):IMHO оно в любом случае будет известно при сервеном курсоре после AddNew, только вот актуальным я бы его не назвал - скорее резервируемое...

Нет, я проверял. В MSSQL оно NULL, значение принимает только после Update.
Lasciate ogni speranza, voi ch'entrate.

Andrey Fedorov
Член-корреспондент академии VBStreets
Член-корреспондент академии VBStreets
 
Сообщения: 3287
Зарегистрирован: 21.05.2004 (Пт) 9:28
Откуда: Москва

Сообщение Andrey Fedorov » 20.02.2007 (Вт) 9:46

alibek писал(а):Нет, я проверял. В MSSQL оно NULL, значение принимает только после Update.


Угу - проверил - так и есть. Сказывается то что с серверным курсором я практически не работаю...
Фиг Вам! - Сказал Чебурашка, обгладывая Крокодила Гену...

shady
Постоялец
Постоялец
 
Сообщения: 461
Зарегистрирован: 09.11.2005 (Ср) 11:03

Сообщение shady » 20.02.2007 (Вт) 10:33

Код: Выделить всё
@@IDENTITY
лучше не возвращать клиенту, потому что она глобальна в пределах MSSQL. Для возвращения значения счетчика в текущей таблице после инсерта лучше использовать
Код: Выделить всё
scope_identity()

Andrey Fedorov
Член-корреспондент академии VBStreets
Член-корреспондент академии VBStreets
 
Сообщения: 3287
Зарегистрирован: 21.05.2004 (Пт) 9:28
Откуда: Москва

Сообщение Andrey Fedorov » 20.02.2007 (Вт) 12:41

shady писал(а):
Код: Выделить всё
@@IDENTITY
лучше не возвращать клиенту, потому что она глобальна в пределах MSSQL. Для возвращения значения счетчика в текущей таблице после инсерта лучше использовать
Код: Выделить всё
scope_identity()


А не проще читать значение поля счетчика - что при этом возвращается, по твоему? А всякие там IDENTITY вообще-то для применения внутри SQL сервера, в его процедурах/триггерах/функциях...
Фиг Вам! - Сказал Чебурашка, обгладывая Крокодила Гену...

shady
Постоялец
Постоялец
 
Сообщения: 461
Зарегистрирован: 09.11.2005 (Ср) 11:03

Сообщение shady » 20.02.2007 (Вт) 16:09

Andrey Fedorov писал(а):А не проще читать значение поля счетчика - что при этом возвращается, по твоему? А всякие там IDENTITY вообще-то для применения внутри SQL сервера, в его процедурах/триггерах/функциях...
Да я и не спорил что это нужно делать на стороне сервера, а просто уточнил, так сказать для справки.


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: Google-бот, Yandex-бот и гости: 111

    TopList