Фильтрация в Silverlight с помощью RIA Services - PullRequest
0 голосов
/ 03 декабря 2009

У меня есть небольшое приложение SL, которое использует службы RIA для отображения данных о сотрудниках (база данных Northwind) в сетке данных. У меня есть текстовый фильтр, который отлично работает против столбцов varchar, но не фильтрует против обнуляемого столбца int. Вот этот xaml:

<UserControl xmlns:riaControls="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Ria" 
         xmlns:riaData="clr-namespace:System.Windows.Data;assembly=System.Windows.Controls.Ria"  
         xmlns:data="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data" x:Class="FilteringSample.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:web="clr-namespace:FilteringSample.Web"
xmlns:converter="clr-namespace:FilteringSample"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
mc:Ignorable="d" d:DesignWidth="640" d:DesignHeight="480">
<UserControl.Resources>
    <converter:StringToIntConverter x:Key="MyConverter"></converter:StringToIntConverter>
</UserControl.Resources>
    <Grid x:Name="LayoutRoot">
<StackPanel Orientation="Vertical" Height="Auto" Grid.Column="0">
        <StackPanel Orientation="Horizontal">
            <Button x:Name="saveButton" Width="75" Height="30" Content="Save" Margin="5" Click="saveButton_Click"/>
            <Button x:Name="rejectButton" Width="75" Height="30" Content="Reject" Margin="5" Click="rejectButton_Click"/>
            <TextBlock x:Name="changeText" VerticalAlignment="Center" Width="Auto"/>
            <TextBox x:Name="Filter" Width="100" Text="" />
            <riaControls:DomainDataSource x:Name="DataSource1" QueryName="GetEmployeesQuery" LoadingData="DataSource1_LoadingData"   >
                <riaControls:DomainDataSource.DomainContext>
                    <!--<web:CustomerContext></web:CustomerContext>-->
                    <web:EmployeeContext></web:EmployeeContext>
                </riaControls:DomainDataSource.DomainContext>

                <riaControls:DomainDataSource.FilterDescriptors>
                    <riaData:FilterDescriptorCollection LogicalOperator="Or">                                                
                        <riaData:FilterDescriptor PropertyPath="FirstName" Operator="Contains">
                            <riaControls:ControlParameter ControlName="Filter" PropertyName="Text" RefreshEventName="TextChanged" />
                        </riaData:FilterDescriptor>
                        <riaData:FilterDescriptor PropertyPath="Title" Operator="Contains">
                            <riaControls:ControlParameter ControlName="Filter" PropertyName="Text" RefreshEventName="TextChanged" />
                        </riaData:FilterDescriptor>
                        <riaData:FilterDescriptor PropertyPath="TestFilter" Operator="Contains">
                            <riaControls:ControlParameter ControlName="Filter" PropertyName="Text" RefreshEventName="TextChanged"/>
                        </riaData:FilterDescriptor>

                    </riaData:FilterDescriptorCollection>
                </riaControls:DomainDataSource.FilterDescriptors>
            </riaControls:DomainDataSource>

        </StackPanel>
        <data:DataGrid Name="MyGrid" ItemsSource="{Binding Data, ElementName=DataSource1}">
        </data:DataGrid>
        <!--<data:DataPager PageSize="20" Source="{Binding Data, ElementName=DataSource1}" Margin="0,-1,0,0" />--> 
    </StackPanel>

Любая помощь будет оценена. Спасибо

Ответы [ 2 ]

1 голос
/ 03 февраля 2010

Вы должны иметь возможность смешивать и сопоставлять типы в фильтрах без каких-либо проблем. Вам также не нужен конвертер значений для преобразования из строки в int, FilterDescriptor автоматически проанализирует значение.

XAML, который вы показываете, не показывает никаких полей int. Какой оператор вы пытаетесь использовать для фильтра? Это должен быть числовой оператор, такой как IsEqualTo, IsGreaterThan и т. Д.

Каков результат? Он загружается без данных, не загружается или игнорирует фильтр?

Возможно, вы захотите попробовать обработать событие LoadingData и посмотреть на EntityQuery, выставленный в аргументах события, чтобы увидеть, что было составлено для запроса.

1 голос
/ 21 января 2010

Я думаю, что вам нужен ValueConverter, который преобразует текст TestFilter в int перед его передачей в LINQ.

...