Форум программистов, компьютерный форум, киберфорум
Наши страницы
C#: Web, ASP.NET
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
Ruia
4 / 4 / 7
Регистрация: 21.02.2013
Сообщений: 71
1

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

25.04.2013, 13:09. Просмотров 506. Ответов 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
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.04.2013, 13:09
Ответы с готовыми решениями:

Удаление данных из Repeater
Есть Repeater наполненный данными. На странице пользователь редактирует эти данные и есть значение ...

Объясните где ошибка с Repeater
Репитер берет с XML файла данные и помещает их в div. Но XML атрибуты logo color img должны бить...

Вывод данных из Xml используя Repeater
Имеется XML файл, в котором содержатся вопросы(есть три типа вопросов: с одним вариантом ответа, с...

Как реализовать постраничный вывод данных из xml-файла через Repeater
Добрый вечер. Подскажите, как реализовать постраничный вывод данных из xml файла через repeater.

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

2
sau
2022 / 1635 / 271
Регистрация: 22.07.2011
Сообщений: 6,212
Завершенные тесты: 1
25.04.2013, 14:51 2
В данном случае условие не сработает для <%# 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
Ruia
4 / 4 / 7
Регистрация: 21.02.2013
Сообщений: 71
07.05.2013, 14:05  [ТС] 3
Спасибо огромное, раньше тоже пытался работать с оператором ?:, но постоянно были какие-то ошибки, хотя на вид писал код такой же, что и сейчас.

И ещё небольшой вопрос вдогонку, почему в этом коде не срабатывает условие:
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
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
07.05.2013, 14:05

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

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

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


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

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

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