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

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

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

Студворк — интернет-сервис помощи студентам
периодически пытаюсь решить эту проблему и уже порядком задолбался, знаю что эта тема здесь крайне не популярна, 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
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.10.2021, 18:49
Ответы с готовыми решениями:

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

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

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

1
0 / 0 / 0
Регистрация: 22.10.2018
Сообщений: 160
04.10.2021, 13:17  [ТС]
В общем как и предполагал никто не поспешил на помощь, решил все сам, если кому понадобится выкладываю рабочий код привязки 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.10.2021, 13:17
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Полиглотные микросервисы на C# и .NET
ArchitectMsa 30.06.2025
Полиглотная архитектура появилась не из желания усложнить жизнь разработчикам. Она родилась из практической необходимости решать разные задачи наиболее эффективным способом. В одном из проектов. . .
Стратегии кеширования
Javaican 29.06.2025
Кеширование — это хранение часто запрашиваемых данных в быстром хранилище (обычно в памяти), чтобы не обращаться к более медленному первоисточнику. Казалось бы, все просто. Но за этой простотой. . .
Наблюдаемость приложений ASP.NET Core с OpenTelemetry, Prometheus и Grafana
ArchitectMsa 29.06.2025
Наблюдаемость (observability) – это ключевое свойство современной системы, позволяющее понимать её внутреннее состояние на основе внешних данных. Если мониторинг отвечает на вопрос "что случилось?",. . .
Четыре главных модели отношений классов в с++
russiannick 28.06.2025
Продолжаю крестовый поход против c++. ideone. com/ юзаю для проверки валидности кода. Насчитал 4 модели отношений классов: одиночный класс, равноправные классы, слейв - мастер, терминатор. . . .
Вложенные корутины в Unity
GameUnited 28.06.2025
Работа с корутинами в Unity кажется простой до тех пор, пока не начинаешь их вкладывать друг в друга. Я потратил несколько месяцев на изучение этого механизма, и до сих пор иногда ловлю себя на том,. . .
Управление Arduino на C# через последовательный порт
Wired 28.06.2025
Когда я впервые попробовал заставить Arduino общаться с моим C# приложением, казалось, что эти два мира существуют параллельно и никогда не пересекутся. Микроконтроллер упорно моргал встроенным. . .
Основы OpenGL 3.3 и Qt 6.9. Трансформированный треугольник
8Observer8 27.06.2025
Содержание блога На русском https:/ / rutube. ru/ video/ e424497dd6b7ae7e11494027c4b31a54/ https:/ / vkvideo. ru/ video-231040171_456239019 https:/ / www. youtube. com/ watch?v=mfD-ZL7wa_4
Федерация аутентификации на основе JWT-токенов с Keycloak и .NET в гетерогенных инфраструктурах
ArchitectMsa 27.06.2025
Тот самый момент, когда впервые столкнулся с проблемой интеграции десятка разрозненных систем аутентификации в одной корпоративной экосистеме. Кажый сервис жил своей жизнью - тут Basic Auth, там. . .
Гайд по современным СУБД (небесспорный)
Codd 26.06.2025
Когда я только начинал свой путь в IT как рядовой программист, база данных казалась мне чем-то простым и понятным. Ну, серьезно — это же просто место, где лежат данные, верно? Напиши SELECT * FROM. . .
Использование C# с AWS S3: Примеры с AWS SDK для .NET
stackOverflow 26.06.2025
Amazon S3 (Simple Storage Service) уже давно стал стандартом де-факто в мире облачного хранения данных. Особенно приятно, что для разработчиков . NET предусмотрен отличный SDK, который значительно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru