Diskuze: Repeater - data ze 2 tabulek
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 9 zpráv z 9.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Jestli jsem to dobře pochopil, chceš podle té buňky (OsCislo) vytahovat data z jiné tabulky. V první řadě musí být Bind, ne Eval a pak si jednoduše přidáš další SqlDataSource přímo do toho výpisu repeateru a vytáhneš z něj data.
Ano, pochopil jsi to správně....
Co se týče Eval, potřebuju jenom zobrazit data uživateli.
Příklad:
Mám dvě tabulky, jedna je "Města" druhá "Ulice". Tabulky jsou propojené
ID_Mesto. Přes repeater chci vypsat všechna města a u každého města
všechny ulice daného města.
Je správná cesta, řešit to Repeatrem a nebo by se hodilo jiné řešení, ještě mě napadlo vložiz repeater do repeatru.
Mohl by jsi trochu rozvést přidání SqlDataSource do repeatru a jeho následný vytažení dat, který chci zobrazit?
Díky
Nějak jsem nepochopil, jak jsou tabulky propojené "ID_Mesto"? Nicméně
máš SqlDataSource, kterým vytahuješ data Měst. To následně zobrazíš v
repeateru. Někam do toho repeateru si uděláš hiddenfield s tím ID_Mesto,
ale to musí být Bind, ne Eval a tetno fiddenfield pak dáš jako parametr do
dalšího SqlDataSource, který umístíš dovnitř toho repeateru a budeš s
ním vytahovat údaje o ulicích...
Kdyby ten hiddenfield byl taky jen Eval, nic by se ti nepředalo do toho
dalšího SqlDataSource...
Bohužel, ale při zakládání dalšího SqlDataSource, nemohu najít HiddemField v kontrolkach ve WHERE.
<asp:HiddenField ID="HiddenFieldDic" runat="server" Value="<%# Bind("ID_Mesto") %>" />
u HiddemField se zobrazuje tohle upozornění:** A call to Bind must be assigned to a property of a control inside a template.**
Tak si to nejdříve celé (ten vnořený SqlDataSource) udělej mimo repeater a pak to jen vlož do repeateru
Mám tohle a nefachá to:
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString='<%$ ConnectionStrings:zamest %>' SelectCommand="SELECT [ID_Dic] FROM [T_Dic]"></asp:SqlDataSource>
<asp:HiddenField ID="HiddenField1" runat="server" Value="<%# Eval("ID_Dic") %>"/>
<asp:SqlDataSource ID="SqlDataSource2" runat="server" ConnectionString='<%$ ConnectionStrings:zamest %>' SelectCommand="SELECT [Obdobi] FROM [T_Obdobi] WHERE ([ID_Dic] = @ID_Dic)">
<SelectParameters>
<asp:ControlParameter ControlID="HiddenField1" PropertyName="Value" Name="ID_Dic" Type="Int32"></asp:ControlParameter>
</SelectParameters>
</asp:SqlDataSource>
<asp:Repeater ID="Repeater1" runat="server">
<ItemTemplate>
<div class="accordion">
<div class="hlavni">
<%# Eval("Dic") %>
</div>
<div class="rozbalovany">
<table>
<tr>
<td>Osobní číslo:</td>
<td><%# Eval ("OsCislo") %></td>
</tr>
<tr>
<td>Řešitel:</td>
<td><%# Eval("Resitel") %> </td>
</tr>
<tr>
<td>Založení záznamu:</td>
<td><%# Eval("DatumZalozeni") %></td>
</tr>
<tr>
<td>DIČ (VAT ID):</td>
<td><%# Eval("Dic") %></td>
</tr>
<tr>
<td>Poznámka:</td>
<td><%# Eval("Poznamka") %></td>
</tr>
<tr>
<td>Šetřené zdaňovací období:</td>
<td>
<%# Eval("Obdobi") %>
</td>
</tr>
</table>
</div>
</div>
</ItemTemplate>
</asp:Repeater>
nějaká další rada?
Ten druhej SqlDataSource s tím hiddenfieldem musíš mít až v tom ItemTemplate a ten HiddenField, jak jsem psal výše, musí být Bind, protože Eval je jen jednosměrný
Zobrazeno 9 zpráv z 9.