Форум программистов, компьютерный форум, киберфорум
C#: Web, ASP.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
4 / 4 / 7
Регистрация: 21.02.2013
Сообщений: 71

Ошибка при связывании данных в Repeater

25.04.2013, 13:09. Показов 927. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток
Снова обращаюсь к вам за помощью. Ни как не могу понять, почему возникает ошибка.

Есть такой код разметки:
Кликните здесь для просмотра всего текста

HTML5
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
<form id="requestForm" name="requestForm" action="Default.aspx" method="get">
    <fieldset>
        <legend>Форма запроса</legend>
        <label>Тип запроса:</label>
        <select id="nType" name="nType">
             <option value="1" selected="selected">Первый</option>
             <option value="2">Второй</option>
             <option value="3">Третий</option>
             <option value="4">Четвёртый</option>
             <option value="5">Пятый</option>
             <option value="6">Шестой</option>
              <option value="7">Седьмой</option>
        </select>
        <label>Начальная дата:</label>
        <input id="szDateStart" name="szDateStart" type="text" readonly="readonly">
        <label>Конечная дата:</label>
        <input id="szDateEnd" name="szDateEnd" type="text" readonly="readonly">
        <button id="button" type="submit">Отправить</button>
    </fieldset>
</form>
<asp:Repeater ID="Repeater1" runat="server" DataSourceID="SqlDataSource1" Visible="false">
    <HeaderTemplate>
        <table>
            <thead>
                <tr>
                    <td>Офис</td>
                    <td><% if (nType == 6) { %>Ячейки<% } else { %>Подготовленные поставки<% } %></td>
                    <% if (nType == 4 || nType == 5 || nType == 7) { %>
                    <td>Выданные поставки</td>
                    <% } %>
                </tr>
            </thead>
            <tbody>
    </HeaderTemplate>
    <ItemTemplate>
        <tr>
            <td><%# Eval("value1") %></td>
            <td><%# Eval("value2") %></td>
            <% if (nType == 4 || nType == 5 || nType == 7) { %>
            <td><%# Eval("value3") %></td>
            <% } %>
           </tr>
    </ItemTemplate>
    <FooterTemplate>
        </tbody>
        <tfoot>
            <tr>
                <td>Офис</td>
                <td><% if (nType == 6) { %>Ячейки<% } else { %>Подготовленные поставки<% } %></td>
                <% if (nType == 4 || nType == 5 || nType == 7) { %>
                <td>Выданные поставки</td>
                <% } %>
            </tr>
        </tfoot>
        </table>
    </FooterTemplate>
</asp:Repeater>
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:crmConnectionString %>" ProviderName="<%$ ConnectionStrings:crmConnectionString.ProviderName %>"></asp:SqlDataSource>


И такой код обработчика:
Кликните здесь для просмотра всего текста

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
28
29
30
31
32
33
34
35
36
37
38
39
40
public partial class WebForm1 : System.Web.UI.Page
{
    protected int nType = 0;
 
    protected void Page_Load(object sender, EventArgs e)
    {            
        NameValueCollection requestForm = Request.QueryString;
        nType = Convert.ToInt32(requestForm["nType"]);
        string szDateStart = Convert.ToDateTime(requestForm["szDateStart"]).ToString("yyyy-MM-dd");
        string szDateEnd = Convert.ToDateTime(requestForm["szDateEnd"]).ToString("yyyy-MM-dd");
 
        switch (nType)
        {
            case 1:
                SqlDataSource1.SelectCommand = String.Format("SELECT office as 'value1', COUNT(*) as 'value2' FROM raw WHERE office IN ('1', '2', '3', '4') AND date_move BETWEEN '{0}' AND '{1}' GROUP BY office", szDateStart, szDateEnd);
                break;
            case 2:
                SqlDataSource1.SelectCommand = String.Format("SELECT postavka as 'value1', COUNT(*) as 'value2' FROM raw WHERE date_move BETWEEN '{0}' AND '{1}' GROUP BY postavka", szDateStart, szDateEnd);
                break;
            case 3:
                SqlDataSource1.SelectCommand = String.Format("SELECT office as 'value1', COUNT(*) as 'value2' FROM raw WHERE office IN ('1', '2', '3', '4') AND sertum_original_docs = 'нет' AND date_move BETWEEN '{0}' AND '{1}' GROUP BY office", szDateStart, szDateEnd);
                break;
            case 4:
                SqlDataSource1.SelectCommand = String.Format("SELECT table1.office as 'value1', table1.count1 as 'value2', table2.count2 as 'value3' FROM (SELECT office, COUNT(*) AS count1 FROM raw WHERE office IN ('1', '2', '3', '4') AND date_podgotovka BETWEEN '{0}' AND '{1}' GROUP BY office) table1, (SELECT office, COUNT(*) AS count2 FROM raw WHERE office IN ('1', '2', '3', '4') AND date_vydacha BETWEEN '{0}' AND '{1}' GROUP BY office) table2 WHERE table1.office = table2.office", szDateStart, szDateEnd);
                break;
            case 5:
                SqlDataSource1.SelectCommand = String.Format("SELECT table1.manager_vydacha as 'value1', table1.count1 as 'value2', table2.count2 as 'value3' FROM (SELECT manager_vydacha, COUNT(*) AS count1 FROM raw WHERE office IN ('1', '2', '3', '4') AND date_podgotovka BETWEEN '{0}' AND '{1}' GROUP BY manager_vydacha) table1, (SELECT manager_vydacha, COUNT(*) AS count2 FROM raw WHERE office IN ('1', '2', '3', '4') AND date_vydacha BETWEEN '{0}' AND '{1}' GROUP BY manager_vydacha) table2 WHERE table1.manager_vydacha = table2.manager_vydacha", szDateStart, szDateEnd);
                break;
            case 6:
                SqlDataSource1.SelectCommand = String.Format("SELECT office as 'value1', COUNT(*) as 'value2' FROM raw WHERE office IN ('1', '2', '3', '4') AND date_move BETWEEN '{0}' AND '{1}' AND gp = '1' GROUP BY office", szDateStart, szDateEnd);
                break;
            case 7:
                SqlDataSource1.SelectCommand = String.Format("SELECT table1.product as 'value1', table1.count1 as 'value2', table2.count2 as 'value3' FROM (SELECT product, COUNT(*) AS count1 FROM raw WHERE office IN ('1', '2', '3', '4') AND date_podgotovka BETWEEN '{0}' AND '{1}' GROUP BY product) table1, (SELECT product, COUNT(*) AS count2 FROM raw WHERE office IN ('1', '2', '3', '4') AND date_vydacha BETWEEN '{0}' AND '{1}' GROUP BY product) table2 WHERE table1.product = table2.product", szDateStart, szDateEnd);
                break;
        }
        
        Repeater1.DataBind();
        Repeater1.Visible = true;
    }
}


В итоге: когда я делаю запросы, которые возвращают таблицу с 3 столбцами, то всё работает, когда с 2, то вылетает ошибка:

Кликните здесь для просмотра всего текста

Ошибка сервера в приложении '/'.

DataBinding: 'System.Data.DataRowView' не содержит свойство с именем value3.

Описание: Необработанное исключение при выполнении текущего веб-запроса. Изучите трассировку стека для получения дополнительных сведений о данной ошибке и о вызвавшем ее фрагменте кода.

Сведения об исключении: System.Web.HttpException: DataBinding: 'System.Data.DataRowView' не содержит свойство с именем value3.

Ошибка источника:


Строка 88: <td><%# Eval("value2") %></td>
Строка 89: <% if (nType == 4 || nType == 5 || nType == 7) { %>
Строка 90: <td><%# Eval("value3") %></td>
Строка 91: <% } %>
Строка 92: </tr>


Хотя по идее, при запросах таблицы с 2 столбцами, код <%# Eval("value3") %> выполняться не должен.

Подскажите, как можно поправить код в данной ситуации? Может есть как в PHP какой-то оператор типа @? (при написании перед функцией не выводит сообщений об ошибках)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.04.2013, 13:09
Ответы с готовыми решениями:

Ошибка при связывании БД
Не получается связать делпфи с БД Access 2003 в ConnectionString прописал все что нужно, пароль на бд не стоит, пользователь бд -Admin ...

Ошибка при связывании БД с сервлетом
Доброго времени суток! Начал знакомиться с сервлетами, но никак не могу разобраться с проблей: при подключении базы в отдельном методе и...

Тип данных при позднем связывании
Меняю раннее связывание на позднее, вот такой код работает отлично: Dim g_WordApp As New Word.Application Dim Pic As Shape ...

2
 Аватар для sau
2773 / 2073 / 386
Регистрация: 22.07.2011
Сообщений: 7,820
25.04.2013, 14:51
В данном случае условие не сработает для <%# Eval("value3") %>
Нужно условие делать в рамках биндинга, примерно так:
HTML5
1
<%# (nType == 4 || nType == 5 || nType == 7) ? string.Format("<TD>{0}</TD>",Eval("value3")) : "" %>
P/S Если будет на Eval ругаться, то достаете через Container.DataItem as DataRowView

Добавлено через 3 минуты
Или же, можно стандартизировать набор полей - т.е всегда получать 3 поля , а уже в представление , в зависимости от наличия значения - скрывать или показывать TD через стили.
1
4 / 4 / 7
Регистрация: 21.02.2013
Сообщений: 71
07.05.2013, 14:05  [ТС]
Спасибо огромное, раньше тоже пытался работать с оператором ?:, но постоянно были какие-то ошибки, хотя на вид писал код такой же, что и сейчас.

И ещё небольшой вопрос вдогонку, почему в этом коде не срабатывает условие:
C#
1
2
3
4
5
6
7
8
9
10
11
12
public partial class WebForm1 : System.Web.UI.Page
{
    protected int nType = 0;
 
    protected void Page_Load(object sender, EventArgs e)
    {            
        if (IsPostBack)
        {
            // код Page_Load из первого поста
        }
    }
}
Страница же перезагружается с новыми данными, разве это не PostBack? Форма-то отправлена.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.05.2013, 14:05
Помогаю со студенческими работами здесь

Ошибка при связывании dateTimePicker и DataGridView
В Access есть таблица, в которой 4 столбца(ФИО, дата рождения, адрес, телефон) для заполнения. Я планировала записать дату рождения через...

Ошибка при связывании таблиц в Delphi 7
Есть 2-е таблицы в Access В Delphi 7 пытаюсь создать зависимость от Сотрудники, поля Код сотрудника до РобочееВремя Табельный...

Ошибка при связывании параметров в подготовленном выражении
помогите увидеть ошибку при связывании параметров. if (!($stmt = $mysqli-&gt;prepare(&quot;UPDATE `ldqx1` SET `ftext` = `ftext` where `id` = ...

Ошибка при связывании Юнит-Теста с решением
Друзья, столкнулся с таким нехорошим явлением при попытке добавить ссылку на тестируемый namespace из теста Ошибка: в результате...

AV при связывании IBQ и IBDb
Доброе утро! Столкнулся с проблемой связывания IBQuery и IBDatabase при динамической работе. Выбивает AV и причину понять не могу. Код...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru