Форум программистов, компьютерный форум, киберфорум
Наши страницы
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
 
Алибек Умаров
3 / 8 / 3
Регистрация: 13.02.2014
Сообщений: 162
1

Долго считываются данные из БД

20.12.2016, 17:07. Просмотров 212. Ответов 5
Метки нет (Все метки)

Почему данные долго открывается
0
Вложения
Тип файла: rar pr.rar (1.27 Мб, 14 просмотров)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.12.2016, 17:07
Ответы с готовыми решениями:

Не считываются данные с ячейки excel 2010
Есть проект на vb 2010 express, цель автоматизировать рутину: копирование одних...

Не считываются данные с БД
Есть БД "DataBase",в которой есть таблица "Actors" (Id(smallint...

Неправильно считываются данные
readln(n,m); for i:=1 to n do begin for j:=1 to m do begin ...

Почему на считываются данные ?
Почему не считываються данные ? Парни помогите!!! Вроде все правильно, но он...

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

5
bd_13
107 / 91 / 40
Регистрация: 05.11.2015
Сообщений: 430
20.12.2016, 17:35 2
Алибек Умаров, наверно потому, что их просто много. Возможно можно как то оптимизировать процедуру вывода данных из таблицы БД в DataGridView
0
Kulma
437 / 376 / 62
Регистрация: 25.07.2015
Сообщений: 685
20.12.2016, 20:28 3
Алибек Умаров, попробуйте результат ваших циклов с запросами заливать в datatable,
а по окончании присвоить DataGridView2.DataSource=datatable
Должно быть быстрее , чем построчная перерисовка grid.
Касаемо БД , там оптимизировать мало что можно, разве что проиндексировать поле id_table,
но большого ускорения это не даст ...все лаги, как мне кажется , в перерисовке заключаются.
0
OwenGlendower
Супер-модератор
Эксперт .NET
9311 / 8174 / 3488
Регистрация: 17.03.2014
Сообщений: 16,219
Записей в блоге: 1
20.12.2016, 20:50 4
Алибек Умаров, это происходит из неэффективной работы с БД. Вот код метода LoadAll
Кликните здесь для просмотра всего текста
vb.net
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
    Sub LoadAll()
        Dim df As Double = 0
        Dim connection As OleDb.OleDbConnection = New OleDbConnection
        connection.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" & Application.StartupPath & "\1.mdb;Jet OLEDB:Database Password=123"
        connection.Open()
        Dim da As OleDb.OleDbDataAdapter = New OleDbDataAdapter("SELECT [id_rabota] FROM [TB2]", connection)
        Dim ds As New DataSet
        da.Fill(ds, "ne1")
        For i = 0 To ds.Tables(0).Rows.Count - 1
            Dim da1 As OleDb.OleDbDataAdapter = New OleDbDataAdapter("SELECT  [F_1], [F_2], [F_3] FROM [TB1] WHERE id_table like '" & ds.Tables(0).Rows(i).Item(0) & "'", connection)
            da1.Fill(ds, "ne2")
            For j = 0 To ds.Tables(1).Rows.Count - 1
                df += CDbl(ds.Tables(1).Rows(j).Item(0))
            Next
            DataGridView2.Rows.Add(df)
            df = 0
            ds.Tables(1).Clear()
        Next
        connection.Dispose()
        connection = Nothing
 
    End Sub

Он получает все строки из таблицы TB2 (N штук) и затем для каждой строки делает новый запрос к таблице TB1. То есть в итоге мы делаем 1+N запросов. Свою лепту в замедление вносит ручной подсчет и использование классов DataSet. Вместо этого нужно написать один запрос который сразу вернет все необходимые данные. Например так:

vb.net
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Using connection As New OleDbConnection
 
    connection.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" & Application.StartupPath & "\1.mdb;Jet OLEDB:Database Password=123"
 
    Dim command As New OleDbCommand
    command.CommandText = "SELECT SUM([F_1]) FROM TB1 GROUP BY id_table"
    command.Connection = connection
 
    connection.Open()
    Using reader As OleDbDataReader = command.ExecuteReader()
        Do While reader.Read()
            DataGridView2.Rows.Add(If(reader.IsDBNull(0), 0, reader.GetDouble(0)))
        Loop
    End Using
 
End Using
Данный метод на моей машине работает примерно в 8 раз быстрее первоначального. Правда он делает не совсем тоже самое из-за того что в таблице TB2 есть одинаковые строки назначение которых лично мне непонятно.
2
Алибек Умаров
3 / 8 / 3
Регистрация: 13.02.2014
Сообщений: 162
22.12.2016, 16:06  [ТС] 5
OwenGlendower, Спасибо за полезную информацию!

У меня возникла такой вопрос: имеется ли код похожие на этот "SELECT SUM([F_1]) FROM TB1 GROUP BY id_table"
чтобы можно было выполнит согласно таблицу приведённую на ЕXCEL.
Образец программу я вам отправлю.
Благодарю за ранее!
0
Вложения
Тип файла: rar pr1.rar (1.28 Мб, 0 просмотров)
OwenGlendower
Супер-модератор
Эксперт .NET
9311 / 8174 / 3488
Регистрация: 17.03.2014
Сообщений: 16,219
Записей в блоге: 1
22.12.2016, 16:08 6
Алибек Умаров, насколько мне известно к Excel можно подключаться как к БД и делать SQL запросы, но я этим никогда не занимался. Поищите информацию самостоятельно.
0
22.12.2016, 16:08
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.12.2016, 16:08

Не считываются данные с формы
function sendCallBackData(){ var name =...

Какой командой считываются данные ?
Какой командой считываются данные из элементов HTML в ява скрипт... Например......

Не считываются данные с полей ввода
В общем, необходимо было чтобы данные которые вводит пользователь в поля...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru