Ошибка при чтении Recordset'а

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
burik
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 514
Зарегистрирован: 03.11.2005 (Чт) 22:04
Откуда: Беларусь, Рогачев

Ошибка при чтении Recordset'а

Сообщение burik » 30.09.2006 (Сб) 16:36

Сдравствуйте!

Мне нужно посчитать средний балл и таблицы в базе.

Код: Выделить всё

y=0
b=0
For x = 1 To rc1.RecordCount
    If rc1.Fields(2) <> Null Then y = y + rc1.Fields(2): b = b + 1 Else
    rc1.MoveNext
Next x



Хотя в таблице только в одной записи из 3-х Fields(2) равен Null, а остальные - 10 и 9, программа выдаёт b = 0 и y = 0 :( .

Полный код:

Код: Выделить всё

Dim x As Integer, y As Integer, z As Integer, b As Integer
Set rc1 = bd.OpenRecordset("SELECT*FROM CLASS" & ClassID & " WHERE FIO='" & PName & "'")
rc1.MoveLast
rc1.MoveFirst
For x = 1 To rc1.RecordCount
    If rc1.Fields(2) <> Null Then y = y + rc1.Fields(2): b = b + 1 Else Debug.Print "null"
    rc1.MoveNext
Next x
x = y / b
SBall = x
rc1.Close



Помогите пожалуйста! Заранее спасибо!
Между слухов, сказок, мифов,
просто лжи, легенд сомнений
мы враждуем жарче скифов
за несходство заблуждений
Игорь Губерман

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

Сообщение GSerg » 30.09.2006 (Сб) 17:58

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

BasiС
Обычный пользователь
Обычный пользователь
Аватара пользователя
 
Сообщения: 64
Зарегистрирован: 16.02.2006 (Чт) 23:34
Откуда: Koenigsberg

Сообщение BasiС » 01.10.2006 (Вс) 0:48

Может так будет проще?

Код: Выделить всё
Dim SBall AS long

Set rc1 = bd.OpenRecordset("SELECT SUM(Balls)/COUNT(Balls) AS Fld FROM CLASS" & ClassID & " WHERE FIO='" & PName & "'")

SBall = rc1.Fields(0)
rc1.Close
Set rc1=Nothing

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

Сообщение alibek » 01.10.2006 (Вс) 13:20

BasiС, проще будет с AVG.
Lasciate ogni speranza, voi ch'entrate.

burik
Постоялец
Постоялец
Аватара пользователя
 
Сообщения: 514
Зарегистрирован: 03.11.2005 (Чт) 22:04
Откуда: Беларусь, Рогачев

Сообщение burik » 01.10.2006 (Вс) 23:10

GSerg

RecordCount = 3

BasiС

Щас так и сделаю, просто не силен в SQL... :cry:

alibek, BasiС, GSerg, спасибо за участие. Все заработало:

If rc1.Fields(2) <> "" Then y = y + rc1.Fields(2): b = b + 1 :)

Но щас SQL запрос изменю, как предложил BasiС. Так проще будет..
Между слухов, сказок, мифов,
просто лжи, легенд сомнений
мы враждуем жарче скифов
за несходство заблуждений
Игорь Губерман

Konst_One
Член-корреспондент академии VBStreets
Член-корреспондент академии VBStreets
Аватара пользователя
 
Сообщения: 3041
Зарегистрирован: 09.04.2004 (Пт) 13:47
Откуда: Химки

Сообщение Konst_One » 02.10.2006 (Пн) 11:56

isnull() ,однако надо юзать

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

Сообщение alibek » 02.10.2006 (Пн) 11:58

Если использовать Count(field), а не Count(*), то даже IS NULL не нужен.
Lasciate ogni speranza, voi ch'entrate.

Nicky
Постоялец
Постоялец
 
Сообщения: 519
Зарегистрирован: 12.08.2004 (Чт) 12:14

Сообщение Nicky » 03.10.2006 (Вт) 16:24

burik писал(а):Но щас SQL запрос изменю, как предложил BasiС. Так проще будет..

Лучше так, как предложил alibek. Так правильнее будет..


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

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

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

    TopList