Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 113
1

Локальный отчет в ReportView: Ссылка на объект не указывает на экземпляр объекта

03.10.2021, 18:49. Показов 2061. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
периодически пытаюсь решить эту проблему и уже порядком задолбался, знаю что эта тема здесь крайне не популярна, 90% вопросов заданных остались без ответа, но попробую. Имеется отчет в проекте Report.rdlc, в нем одна таблица, при выводе постоянно получаю ошибку "Ошибка при локальной обработке отчета. Ссылка на объект не указывает на экземпляр объекта"
вот код которым пытаюсь прикрутить отчет к вьюверу:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
this.reportViewer1.LocalReport.DataSources.Clear();
            reportViewer1.Reset();
            reportViewer1.LocalReport.ReportEmbeddedResource = "Report.rdlc";
            SqlConnection con = new SqlConnection();
            con.ConnectionString = "SERVER=" + server + ";" + "DATABASE=" + database + ";" + "UID=" + uid + ";" + "PASSWORD=" + password + ";";
            con.Open();
            SqlCommand cmd = new SqlCommand();
            cmd.Connection = con;
            cmd.CommandType = CommandType.Text;
            cmd.CommandText = "select ... from akttableCLS";
            DataTable akttableCLS = new DataTable();
            akttableCLS.Load(cmd.ExecuteReader());
            con.Close();
            ReportDataSource rprtDTSource = new ReportDataSource();
            rprtDTSource.Name = "DataSet1";
            rprtDTSource.Value = akttableCLS;
            this.reportViewer1.LocalReport.DataSources.Add(rprtDTSource);
            this.reportViewer1.RefreshReport();
вот часть кода Report.rdlc
XML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<?xml version="1.0" encoding="utf-8"?>
<Report xmlns="http://schemas.microsoft.com/sqlserver/reporting/2016/01/reportdefinition" xmlns:rd="http://schemas.microsoft.com/SQLServer/reporting/reportdesigner">
  <AutoRefresh>0</AutoRefresh>
  <DataSources>
    <DataSource Name="bbbDataSet">
      <ConnectionProperties>
        <DataProvider>System.Data.DataSet</DataProvider>
        <ConnectString>/* Local Connection */</ConnectString>
      </ConnectionProperties>
      <rd:DataSourceID>ab30b7d9-7917-440f-b697-ecedb23cd657</rd:DataSourceID>
    </DataSource>
    <DataSource Name="bbbiDataSet1">
      <ConnectionProperties>
        <DataProvider>System.Data.DataSet</DataProvider>
        <ConnectString>/* Local Connection */</ConnectString>
      </ConnectionProperties>
      <rd:DataSourceID>1b87092b-150a-4d68-94c8-7b62029a51fe</rd:DataSourceID>
    </DataSource>
  </DataSources>
  <DataSets>
    <DataSet Name="DataSet1">
      <Query>
        <DataSourceName>bbbiDataSet</DataSourceName>
        <CommandText>/* Local Query */</CommandText>
Добавлено через 5 часов 20 минут
может хотя бы кто подскажет что значит сия ошибка: "Метод не найден: SystemString Microsoft.ReportingSevices.DateTimeUtil.ParseDateToAdditionalSettingFormat(Sysye m.String.System.Gobalization.CultureInfo)??? она вылезла в окне report vyewer, мой код теперь выглядит так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
reportViewer1.ProcessingMode = ProcessingMode.Local;
 
            reportViewer1.LocalReport.ReportPath = "Report1.rdlc";
 
            ReportDataSource rdS = new ReportDataSource("DataSet1", GetData());
 
            reportViewer1.LocalReport.DataSources.Add(rdS);
            this.reportViewer1.RefreshReport();
            DataTable GetData()
 
            {
 
                SqlDataAdapter dta = new SqlDataAdapter();
 
                SqlConnection con = new SqlConnection("SERVER=" + server + ";" + "DATABASE=" + database + ";" + "UID=" + uid + ";" + "PASSWORD=" + password + ";");
            
                DataSet ds = new DataSet();
 
                dta.SelectCommand = new SqlCommand("select from akttableCLS", con);
                
                dta.Fill(ds, "akttableCLS");
 
                return ds.Tables[0];
 
            }
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
03.10.2021, 18:49
Ответы с готовыми решениями:

Ссылка на объект не указывает на экземпляр объекта
Всем доброго времени суток, заранее прошу не ругаться, ибо только учусь) Задача такая: при нажатии...

Ссылка на объект не указывает на экземпляр объекта
Здравствуйте. Выскакивает такая проблема при добавлении нового блога. (скрин). Все поля при...

Ссылка на объект не указывает на экземпляр объекта
При создании проекта в MS VisualStudio 2010 (Silverlight Application) вы лазит ошибка: ...

Ссылка на объект не указывает на экземпляр объекта
В общем, запускаю приложение, как вдруг в методе Touch вылезает ошибка &quot;Ссылка на объект не...

Ссылка на объект не указывает на экземпляр объекта
Ох, сразу скажу, что темы которые выдает поиск я перелистал Код using System; using...

1
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 113
04.10.2021, 13:17  [ТС] 2
В общем как и предполагал никто не поспешил на помощь, решил все сам, если кому понадобится выкладываю рабочий код привязки report view к report.rdlc:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
using Microsoft.Reporting.WinForms;
 
reportViewer1.ProcessingMode = ProcessingMode.Local;
 
            reportViewer1.LocalReport.ReportPath = "Report1.rdlc";
 
            ReportDataSource rdS = new ReportDataSource("DataSet1", GetData());
 
            reportViewer1.LocalReport.DataSources.Add(rdS);
            this.reportViewer1.RefreshReport();
            DataTable GetData()
 
            {
 
                SqlDataAdapter dta = new SqlDataAdapter();
 
                SqlConnection con = new SqlConnection("SERVER=" + server + ";" + "DATABASE=" + database + ";" + "UID=" + uid + ";" + "PASSWORD=" + password + ";");
            
                DataSet ds = new DataSet();
 
                dta.SelectCommand = new SqlCommand("select здесь запрос SQL на выборку из таблице к каторой привязана таблица в отчете from akttableCLS", con);
                
                dta.Fill(ds, "DataSet1");
 
                return ds.Tables[0];
 
            }
Обязательно указывайте именно тот DataSet который у вас указан в отчете, сейчас разбираюсь как привязаться к двум источникам данных, как сделаю - выложу код.
0
04.10.2021, 13:17
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
04.10.2021, 13:17
Помогаю со студенческими работами здесь

Ссылка на объект не указывает на экземпляр объекта
Здравствуйте. Помогите пожалуйста с ошибкой, не имею понятия что с ней делать. Программу делаю в...

Ссылка на объект не указывает на экземпляр объекта
Только начал изучение не судите строго. 30 и 74 строку пометил. Если можно напишите правильный...

Ссылка на объект не указывает на экземпляр объекта
//MyStruct.h struct MyStruct { int aaa = 0; char bbb = &quot;bbb&quot;; char ccc = &quot;ccc&quot;; bool...

Ссылка на объект не указывает на экземпляр объекта
Здравствуйте! Добавил на форму слайдер да текстовое поле. Решил попробовать поработать со...

Ссылка на объект не указывает на экземпляр объекта
Ошибка: &quot;Ссылка на объект не указывает на экземпляр объекта.&quot; Подскажите пожалуйста что я делаю не...

Ссылка на объект не указывает на экземпляр объекта
В проге реализуется распарсивание строки и последующая обратная польская запись. При компиляции...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru