zoukankan      html  css  js  c++  java
  • WPF DataGrid 数据绑定、样式、分页、增删改查,连接Access数据库

    先上效果图:

    XAML:

    <UserControl
                 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                 xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
                 xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
                 xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
                 xmlns:local="clr-namespace:WpfAppFirst"
                 xmlns:dxg="http://schemas.devexpress.com/winfx/2008/xaml/grid" xmlns:dxprg="http://schemas.devexpress.com/winfx/2008/xaml/propertygrid" xmlns:dxe="http://schemas.devexpress.com/winfx/2008/xaml/editors" x:Class="WpfAppFirst.CheckList"
                 mc:Ignorable="d" 
                 d:DesignHeight="300" d:DesignWidth="1000">
        <Grid>
            
            <!--#region 网线-->
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="*"/>
                <ColumnDefinition Width="3*"/>
                <ColumnDefinition Width="3*"/>
                <ColumnDefinition Width="3*"/>
                <ColumnDefinition Width="3*"/>
                <ColumnDefinition Width="*"/>
            </Grid.ColumnDefinitions>
    
            <Grid.RowDefinitions>
                <RowDefinition Height="40*"/>
                <RowDefinition Height="60*"/>
                <RowDefinition Height="140*"/>
                <RowDefinition Height="60*"/>
            </Grid.RowDefinitions>
            <!--#endregion-->
    
            <!--#region 标题-->
            <Border Grid.Column="1" Grid.Row="0" Grid.ColumnSpan="4" Grid.RowSpan="1">
                <Label Content="核查单位管理" Foreground="#000" FontSize="24" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></Label>
            </Border>
            <!--#endregion-->
    
            <!--#region 单位名称-->
            <Label Content="单位名称" Grid.Column="1" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" VerticalContentAlignment="Center" FontSize="18"></Label>
            <TextBox x:Name="Users_Company" Width="120" Height="30" Grid.Column="1" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" VerticalAlignment="Center" HorizontalAlignment="Right" Margin="0,0,10,0"></TextBox>
            <!--#endregion-->
    
            <!--#region 负责人-->
            <Label Content="负责人" Grid.Column="2" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" VerticalContentAlignment="Center" FontSize="18"></Label>
            <TextBox x:Name="Users_Name" Width="120" Height="30" Grid.Column="2" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" VerticalAlignment="Center" HorizontalAlignment="Right" Margin="0,0,10,0"></TextBox>
            <!--#endregion-->
    
            <!--#region 状态-->
            <Label Content="状态" Grid.Column="3" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" VerticalContentAlignment="Center" Padding="50,0,0,0" FontSize="18"></Label>
            <ComboBox x:Name="Users_IsDelete" Width="80" Height="30" Grid.Column="3" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" VerticalAlignment="Center" HorizontalAlignment="Right" Margin="0,0,10,0">
                <ComboBoxItem IsSelected="True">全部</ComboBoxItem>
                <ComboBoxItem>有效</ComboBoxItem>
                <ComboBoxItem>无效</ComboBoxItem>
            </ComboBox>
            <!--#endregion-->
    
            <!--#region 查询 添加-->
            <Border Grid.Column="4" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" Background="#2862AD" Height="30" Width="65" CornerRadius="2,2,2,2"  HorizontalAlignment="Left" MouseLeftButtonDown="Border_MouseLeftButtonDown" Cursor="Hand">
                <Label Content="查询" FontSize="18" Foreground="#fff" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></Label>
            </Border>
            <Border Grid.Column="4" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" Background="#2862AD" Height="30" Width="65" CornerRadius="2,2,2,2"  HorizontalAlignment="Right" MouseLeftButtonDown="Border_MouseLeftButtonDown_1" Cursor="Hand">
                <Label Content="添加" FontSize="18" Foreground="#fff" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></Label>
            </Border>
            <!--<Border Grid.Column="4" Grid.Row="1" Grid.ColumnSpan="1" Grid.RowSpan="1" Background="Red" ></Border>-->
            <!--#endregion-->
    
            <!--#region 表格-->
            <DataGrid x:Name="dataGrid1" Grid.Column="1" Grid.Row="2" Grid.ColumnSpan="4" CanUserAddRows="False" AutoGenerateColumns="False" SelectionUnit="FullRow" ColumnHeaderHeight="40" Background="Transparent" SelectionMode="Single">
    
                <!--数据网格的样式属性-->
                <DataGrid.Style>
                    <!--DataGrid样式-->
                    <Style TargetType="DataGrid">
                        <!--设置HeadersVisibility:头部可见性,Column-->
                        <Setter Property="HeadersVisibility" Value="Column"/>
                        <!--水平网格线刷能见度-->
                        <Setter Property="HorizontalGridLinesBrush">
                            <Setter.Value>
                                <SolidColorBrush Color="#333" Opacity="0.2"/>
                            </Setter.Value>
                        </Setter>
    
                        <!--垂直网格线刷-->
                        <Setter Property="VerticalGridLinesBrush">
                            <Setter.Value>
                                <SolidColorBrush Color="#333" Opacity="0.2"/>
                                <!--Transparent-->
                            </Setter.Value>
                        </Setter>
                    </Style>
                </DataGrid.Style>
    
                <!--数据网格的列标题样式属性-->
                <DataGrid.ColumnHeaderStyle>
                    <!--样式类型:DataGridColumnHeader(数据网格列标题)-->
                    <Style TargetType="{x:Type DataGridColumnHeader}">
                        <Setter Property="Background" Value="#E1F1FF"/>
                        <Setter Property="Foreground" Value="#000"/>
                        <Setter Property="HorizontalContentAlignment" Value="Center"/>
                        <!--设置边框笔刷(BorderBrush)-->
                        <Setter Property="BorderBrush">
                            <!---->
                            <Setter.Value>
                                <!--色刷,Opacity:透明度-->
                                <SolidColorBrush Color="#333" Opacity="0.2"></SolidColorBrush>
                            </Setter.Value>
                        </Setter>
                    </Style>
                </DataGrid.ColumnHeaderStyle>
    
                <!--DataGrid的Rowstyle属性(数据表格的行样式)-->
                <DataGrid.RowStyle>
                    <!--设置样式,类型:DataGridRow(数据表格行)-->
                    <Style TargetType="DataGridRow">
                        <!--设置BorderThickness:边框粗细,value:值0-->
                        <Setter Property="BorderThickness" Value="0"/>
                        <!--<Setter Property="Background" Value="Transparent"/>Transparent:透明-->
                        <!--创建样式触发器-->
                        <Style.Triggers>
                            <!--是否是鼠标经过触发-->
                            <Trigger Property="IsMouseOver" Value="True">
                                <!--触发:背景颜色-->
                                <Setter Property="Background">
                                    <!--Color:背景颜色值;Opacity:透明度-->
                                    <Setter.Value>
                                        <SolidColorBrush Color="#E1F1FF" Opacity="1"></SolidColorBrush>
                                    </Setter.Value>
                                </Setter>
                            </Trigger>
                            <!--是否选中时触发-->
                            <Trigger Property="IsSelected" Value="True">
                                <!--触发:Foreground(字体颜色);Value:颜色值:Red-->
                                <Setter Property="Foreground" Value="Red"/>
                            </Trigger>
                        </Style.Triggers>
                    </Style>
                </DataGrid.RowStyle>
    
                <!--DataGrid的CellStyle属性(数据表格的单元格样式)-->
                <DataGrid.CellStyle >
                    <!--设置样式,类型:DataGridCell(数据表格的单元格)-->
                    <Style TargetType="DataGridCell">
                        <!--设置BorderThickness:边框粗细,value:值0-->
                        <Setter Property="BorderThickness" Value="0"/>
                        <!--样式的触发器-->
                        <Style.Triggers>
                            <!--是否选中是触发-->
                            <Trigger Property="IsSelected" Value="True">
                                <!--触发:背景-->
                                <Setter Property="Background">
                                    <!--设置触发背景的值-->
                                    <Setter.Value>
                                        <!--Color:颜色,Opacity:透明度-->
                                        <SolidColorBrush Color="AntiqueWhite" Opacity="0.9"/>
                                    </Setter.Value>
                                </Setter>
                                <!--设置字体颜色(Foreground):红色(Red)-->
                                <Setter Property="Foreground" Value="Red"></Setter>
                            </Trigger>
                        </Style.Triggers>
                    </Style>
                </DataGrid.CellStyle>
    
                <DataGrid.Columns>
    
                    <!--用这种的话,单元格不能放多个可点击的控件,这个可以:DataGridTemplateColumn-->
                    <!--<DataGridTextColumn Header="单位" Width="*" Binding="{Binding Company}" IsReadOnly="True">
                        <DataGridTextColumn.ElementStyle>
                            <Style TargetType="TextBlock">
                                <Setter Property="HorizontalAlignment" Value="Center"></Setter>
                                <Setter Property="FontSize" Value="14" />
                                <Setter Property="FontFamily" Value="微软雅黑" />
                                <Setter Property="Height" Value="40" />
                            </Style>
                        </DataGridTextColumn.ElementStyle>
                    </DataGridTextColumn>-->
    
                    <!--数据表格模板列;Header:标题,Width:{比例(*),固定值(int)}-->
                    <DataGridTemplateColumn Header="编号" Width="*">
                        <!--数据表格模板列的单元格模板属性-->
                        <DataGridTemplateColumn.CellTemplate>
                            <!--数据模板-->
                            <DataTemplate>
                                <!--堆叠盘-->
                                <StackPanel VerticalAlignment="Center" HorizontalAlignment="Center">
                                    <TextBlock Text="{Binding Id}"></TextBlock>
                                </StackPanel>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
                    </DataGridTemplateColumn>
    
                    <DataGridTemplateColumn Header="负责人" Width="*">
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <StackPanel VerticalAlignment="Center" HorizontalAlignment="Center">
                                    <TextBlock Text="{Binding Name}"></TextBlock>
                                </StackPanel>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
                    </DataGridTemplateColumn>
    
                    <DataGridTemplateColumn Header="单位" Width="*">
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <StackPanel VerticalAlignment="Center" HorizontalAlignment="Center">
                                    <TextBlock Text="{Binding Company}"></TextBlock>
                                </StackPanel>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
                    </DataGridTemplateColumn>
    
                    <DataGridTemplateColumn Header="状态" Width="*">
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <StackPanel VerticalAlignment="Center" HorizontalAlignment="Center">
                                    <TextBlock Text="{Binding IsDelete}"></TextBlock>
                                </StackPanel>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
                    </DataGridTemplateColumn>
    
                    <DataGridTemplateColumn Header="操作" Width="*">
                        <DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Height="40">
                                    <!---->
                                    <Border x:Name="borderEdit" HorizontalAlignment="Center" VerticalAlignment="Center" MouseLeftButtonDown="s_MouseLeftButtonDown">
                                        <Label Content="编辑" FontSize="14" VerticalAlignment="Center" Cursor="Hand"></Label>
                                    </Border>
    
                                    <Border x:Name="borderDelete" HorizontalAlignment="Center" VerticalAlignment="Center" MouseLeftButtonDown="Label_MouseDoubleClick" Cursor="Hand">
                                        <Label Content="删除" FontSize="14" VerticalAlignment="Center"></Label>
                                    </Border>
    
                                </StackPanel>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>
    
                        <!--<DataGridTemplateColumn.CellTemplate>
                            <DataTemplate>
                                <Label Content="修改" MouseDoubleClick="s_MouseLeftButtonDown" HorizontalContentAlignment="Center" VerticalContentAlignment="Center"></Label>
                            </DataTemplate>
                        </DataGridTemplateColumn.CellTemplate>-->
    
                    </DataGridTemplateColumn>
    
                </DataGrid.Columns>
    
            </DataGrid>
            <!--#endregion-->
    
            <!--#region 总记录数据-->
            <Border Grid.Column="1" Grid.Row="3">
                <Label x:Name="count" FontSize="16" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></Label>
            </Border>
            <!--#endregion-->
    
            <!--#region 转到第几页-->
            <Border Grid.Column="4" Grid.Row="3">
                <Label Content="转到       页" VerticalContentAlignment="Center" HorizontalContentAlignment="Center" Padding="0,0,15,0"></Label>
            </Border>
            <Border Grid.Column="4" Grid.Row="3">
                <TextBox x:Name="Page" Width="30" Height="20" InputMethod.IsInputMethodEnabled="False" PreviewTextInput="Page_PreviewTextInput"></TextBox>
            </Border>
            <Border Grid.Column="4" Grid.Row="3" VerticalAlignment="Center" HorizontalAlignment="Right">
                <Button Content="确定" Width="60" Height="20" VerticalContentAlignment="Center" Click="Button_Click"></Button>
            </Border>
            <!--#endregion-->
    
            <!--#region 上一页-->
            <Border Grid.Column="3" Grid.Row="3">
                <Image Source="Img右2.png" Width="20" Height="20" VerticalAlignment="Center" HorizontalAlignment="Left" Cursor="Hand" MouseUp="Image_MouseUp"></Image>
            </Border>
            <Border Grid.Column="3" Grid.Row="3">
                <Image Source="Img右1.png" Width="20" Height="20" VerticalAlignment="Center" HorizontalAlignment="Left" Margin="20,0,0,0" Cursor="Hand" MouseUp="Image_MouseUp_1"></Image>
            </Border>
            <!--#endregion-->
    
            <!--#region 页数-->
            <Border Grid.Column="3" Grid.Row="3">
                <Label x:Name="CurrentPage" Content="1" Foreground="Red" FontSize="12" Width="30" Height="30" VerticalContentAlignment="Center" HorizontalContentAlignment="Center" Margin="0,0,100,0" Cursor="Hand"></Label>
            </Border>
            <Border Grid.Column="3" Grid.Row="3">
                <Label x:Name="CurrentPage2" Content="1" FontSize="12" Width="30" Height="30" VerticalContentAlignment="Center" HorizontalContentAlignment="Center" Margin="0,0,70,0" Cursor="Hand"></Label>
            </Border>
            <Border Grid.Column="3" Grid.Row="3">
                <Label x:Name="CurrentPage3" Content="1" FontSize="12" Width="30" Height="30" VerticalContentAlignment="Center" HorizontalContentAlignment="Center" Margin="0,0,40,0" Cursor="Hand"></Label>
            </Border>
    
            <Border Grid.Column="3" Grid.Row="3">
                <Label Content="...." FontSize="12" Width="20" Height="30" VerticalContentAlignment="Center" HorizontalContentAlignment="Center" Cursor="Hand"></Label>
            </Border>
            <Border Grid.Column="3" Grid.Row="3">
                <Label x:Name="MaxPage" FontSize="12" Width="30" Height="30" VerticalContentAlignment="Center" HorizontalContentAlignment="Center" Margin="50,0,0,0" Cursor="Hand"></Label>
            </Border>
            <!--#endregion-->
    
            <!--#region 下一页-->
            <Border Grid.Column="3" Grid.Row="3">
                <Image Source="Img左1.png" Width="20" Height="20" VerticalAlignment="Center" HorizontalAlignment="Right" Margin="0,0,20,0" Cursor="Hand" MouseUp="Image_MouseUp_3"></Image>
            </Border>
            <Border Grid.Column="3" Grid.Row="3">
                <Image Source="Img左2.png" Width="20" Height="20" VerticalAlignment="Center" HorizontalAlignment="Right" Cursor="Hand" MouseUp="Image_MouseUp_2"></Image>
            </Border>
            <!--#endregion-->
    
        </Grid>
    </UserControl>

    后台隐藏代码:

    using ExerciseModel;
    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Data.OleDb;
    using System.Linq;
    using System.Text;
    using System.Text.RegularExpressions;
    using System.Threading.Tasks;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Imaging;
    using System.Windows.Navigation;
    using System.Windows.Shapes;
    
    namespace WpfAppFirst
    {
        /// <summary>
        /// CheckList.xaml 的交互逻辑
        /// </summary>
        public partial class CheckList : UserControl
        {
            /// <summary>
            /// 当前页数
            /// </summary>
            private int Currentpage = 1;
            /// <summary>
            /// 每页数据行
            /// </summary>
            private int pageRecord = 2;
    
            /// <summary>
            /// 构造函数
            /// </summary>
            public CheckList()
            {
                InitializeComponent();
                this.count.Content = "" + conns().Count() + "条数据";
                SetCurrentPage(Currentpage.ToString());
                this.MaxPage.Content = MaxPaging();
                this.Page.Text = Currentpage.ToString();
            }
    
            #region 连接数据库
            OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\用户目录\我的文档\Access\Organization.mdb"); //Jet OLEDB:Database Password=
            #endregion
    
            #region 事件
    
            /// <summary>
            /// 修改
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void s_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
            {
                GetSelectedRow();
                UpdateUser uu = new WpfAppFirst.UpdateUser();
                uu.Ids.Content = SubRowsId().Id;
                uu.ShowDialog();
                Paging(pageRecord, Currentpage);
                //UpdateUser(SubRowsId().Name, SubRowsId().Company, SubRowsId().IsDelete, SubRowsId().Id);
            }
    
            /// <summary>
            /// 点击删除
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Label_MouseDoubleClick(object sender, MouseButtonEventArgs e)
            {
                MessageBoxResult result = MessageBox.Show("请确认删除此条数据?", "", MessageBoxButton.YesNo);
                if (result == MessageBoxResult.Yes)
                {
                    DeleteUser(SubRowsId().Id);
                    Paging(pageRecord, Currentpage);
                    this.MaxPage.Content = MaxPaging();
                    this.Page.Text = MaxPaging().ToString();
                    this.count.Content = conns().Count();
                }
            }
    
            /// <summary>
            /// 条件查询
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Border_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
            {
                SeleteWhere(GetName(), GetCompany(), GetIsDelete());
            }
    
            /// <summary>
            /// 添加
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Border_MouseLeftButtonDown_1(object sender, MouseButtonEventArgs e)
            {
                AddUser(GetName(), GetCompany(), GetIsDelete());
                int max = Convert.ToInt32(MaxPaging());
                Paging(pageRecord, max);
                Currentpage = max;
                this.MaxPage.Content = MaxPaging();
                this.Page.Text = MaxPaging().ToString();
                this.count.Content = conns().Count();
            }
    
            /// <summary>
            /// 跳转页数
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Button_Click(object sender, RoutedEventArgs e)
            {
                var page = this.Page.Text;
                var maxpage = MaxPaging();
                if (Convert.ToDouble(page) > maxpage)
                {
                    Paging(pageRecord, Convert.ToInt32(maxpage));
                    SetCurrentPage(maxpage.ToString());
                    Currentpage = Convert.ToInt32(maxpage);
                    Setpage(maxpage.ToString());
                }
                if (Convert.ToDouble(page) < 0)
                {
                    Paging(pageRecord, 1);
                    SetCurrentPage("1");
                    Currentpage = 1;
                    Setpage("1");
                }
                else if (Convert.ToDouble(page) <= maxpage && Convert.ToDouble(page) > 0)
                {
                    Paging(pageRecord, Convert.ToInt32(page));
                    SetCurrentPage(page);
                    Currentpage = Convert.ToInt32(page);
                    Setpage(page);
                }
            }
    
            /// <summary>
            /// 利用正则表达式禁用英文的写入
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Page_PreviewTextInput(object sender, TextCompositionEventArgs e)
            {
                Regex re = new Regex("[^0-9.-]+");
                e.Handled = re.IsMatch(e.Text);
            }
    
            /// <summary>
            /// 第一页
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Image_MouseUp(object sender, MouseButtonEventArgs e)
            {
                if (Currentpage != 1)
                {
                    Setpage("1");
                    SetCurrentPage("1");
                    Paging(pageRecord, 1);
                    Currentpage = 1;
                }
            }
    
            /// <summary>
            /// 上一页
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Image_MouseUp_1(object sender, MouseButtonEventArgs e)
            {
                if (Currentpage != 1)
                {
                    Setpage((Currentpage - 1).ToString());
                    SetCurrentPage((Currentpage - 1).ToString());
                    Paging(pageRecord, --Currentpage);
                }
            }
    
            /// <summary>
            /// 最后一页
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Image_MouseUp_2(object sender, MouseButtonEventArgs e)
            {
                double MaxPage = MaxPaging();
                if (Currentpage != MaxPage)
                {
                    Setpage(MaxPage.ToString());
                    SetCurrentPage(MaxPage.ToString());
                    Paging(pageRecord, (int)MaxPage);
                    Currentpage = (int)MaxPage;
                }
            }
    
            /// <summary>
            /// 下一页
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Image_MouseUp_3(object sender, MouseButtonEventArgs e)
            {
                double MaxPage = MaxPaging();
                if (Currentpage != MaxPage)
                {
                    Setpage((Currentpage + 1).ToString());
                    SetCurrentPage((Currentpage + 1).ToString());
                    Paging(pageRecord, ++Currentpage);
                }
            }
    
            #endregion
    
            #region 方法
    
            private DataRowView GetSelectedRow()
            {
    
                /*优化 
                 * 无论 DataGrid的SelectionUnit跟SelectionMode两个属性取任何值
                 * 都存在选中的单元格
                 * 可以根据选中的单元格做统一处理,获取选中的行
                 *  GetSelectedRows()方法获取选中多行原理相同
                */
    
                if (dataGrid1 != null && dataGrid1.SelectedCells.Count != 0)
                {
                    //只选中一个单元格时:返回单元格所在行
                    //选中多个时:返回第一个单元格所在行
                    return dataGrid1.SelectedCells[0].Item as DataRowView;
                }
    
                return null;
            }
    
            #region 连接开关
            public void ConnOpen()
            {
                if (conn.State == System.Data.ConnectionState.Closed)
                {
                    conn.Open();
                }
            }
            public void ConnClose()
            {
                if (conn.State == System.Data.ConnectionState.Open)
                {
                    conn.Close();
                }
            }
            #endregion
    
            #region 设置当前页
            /// <summary>
            /// 设置当前页
            /// </summary>
            /// <param name="page">当前页数</param>
            public void SetCurrentPage(string page)
            {
                this.CurrentPage.Content = page;
                int max = Convert.ToInt32(MaxPaging());
                if (Convert.ToInt32(page) <= max - 1)
                {
                    this.CurrentPage2.Content = Convert.ToInt32(page) + 1;
                }
                else
                {
                    this.CurrentPage2.Content = "";
                }
                if (Convert.ToInt32(page) <= max - 2)
                {
                    this.CurrentPage3.Content = Convert.ToInt32(page) + 2;
                }
                else
                {
                    this.CurrentPage3.Content = "";
                }
            }
            /// <summary>
            /// 设置文本框中的当前数值
            /// </summary>
            /// <param name="page"></param>
            public void Setpage(string page)
            {
                this.Page.Text = page;
            }
            #endregion
    
            #region 最大页
            /// <summary>
            /// 获取最大页
            /// </summary>
            /// <returns></returns>
            public double MaxPaging()
            {
                double count = conns().Count();
                return Math.Ceiling(count / pageRecord);
            }
            #endregion 
    
            #region 获取选中行的原始值
            /// <summary>
            /// 获取选中行的原始值
            /// </summary>
            /// <param name="rowindex"></param>
            private Users1 SubRowsId()
            {
                return (Users1)dataGrid1.SelectedItem;
            }
            #endregion
    
            #region 获取文本
            /// <summary>
            /// 获取负责人
            /// </summary>
            public string GetName()
            {
                return this.Users_Name.Text;
            }
    
            /// <summary>
            /// 获取负责人单位
            /// </summary>
            /// <returns></returns>
            public string GetCompany()
            {
                return this.Users_Company.Text;
            }
    
            /// <summary>
            /// 获取状态值
            /// </summary>
            /// <returns></returns>
            public bool? GetIsDelete()
            {
                var bl = this.Users_IsDelete.Text.ToString();
                if (bl == "全部")
                {
                    return null;
                }
                else if (bl == "有效")
                {
                    return true;
                }
                else
                {
                    return false;
                }
            }
            #endregion 
    
            #region 查询全部数据
            /// <summary>
            /// 查询全部数据
            /// </summary>
            public List<Users1> conns()
            {
                OleDbCommand cmd = conn.CreateCommand();
                cmd.CommandText = "select * from Users";
                ConnOpen();
                OleDbDataReader dr = cmd.ExecuteReader();
                DataTable dt = new DataTable();
                if (dr.HasRows)
                {
                    for (int i = 0; i < dr.FieldCount; i++)
                    {
                        dt.Columns.Add(dr.GetName(i));
                    }
                    dt.Rows.Clear();
                }
                while (dr.Read())
                {
                    DataRow row = dt.NewRow();
                    for (int i = 0; i < dr.FieldCount; i++)
                    {
                        row[i] = dr[i];
                    }
                    dt.Rows.Add(row);
                }
                cmd.Dispose();
                ConnClose();
    
                List<Users1> lus1 = new List<Users1>();
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    lus1.Add(new Users1 { Id = Convert.ToInt32(dt.Rows[i][0]), Name = dt.Rows[i][1].ToString(), Company = dt.Rows[i][2].ToString(), IsDelete = Convert.ToBoolean(dt.Rows[i][3]) });
                }
                return lus1;
                //this.dataGrid1.ItemsSource = lus1;
            }
            #endregion
    
            #region 分页
            /// <summary>
            /// 
            /// </summary>
            /// <param name="pageSize">页大小</param>
            /// <param name="currentPage">当前页数</param>
            /// <param name="totalCount">总页数</param>
            public void Paging(int pageSize, int currentPage)
            {
                //pageSize 每页显示多少条数据
                //pageNumber 页数 从客户端传来
                //pages = pageSize * (currentPage - 1) + 1
                int pages = pageSize * (currentPage - 1) + 1;
                string sql = string.Format("select top {0} * from Users where id>=(select max(id) from (select top {1} id from Users order by id asc ) t )", pageSize, pages);
                OleDbCommand cmd = conn.CreateCommand();
                cmd.CommandText = sql;
                ConnOpen();
                OleDbDataReader dr = cmd.ExecuteReader();
                DataTable dt = new DataTable();
                if (dr.HasRows)
                {
                    for (int i = 0; i < dr.FieldCount; i++)
                    {
                        dt.Columns.Add(dr.GetName(i));
                    }
                    dt.Rows.Clear();
                }
                while (dr.Read())
                {
                    DataRow row = dt.NewRow();
                    for (int i = 0; i < dr.FieldCount; i++)
                    {
                        row[i] = dr[i];
                    }
                    dt.Rows.Add(row);
                }
                cmd.Dispose();
                ConnClose();
    
                List<Users1> lus1 = new List<Users1>();
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    lus1.Add(new Users1 { Id = Convert.ToInt32(dt.Rows[i][0]), Name = dt.Rows[i][1].ToString(), Company = dt.Rows[i][2].ToString(), IsDelete = Convert.ToBoolean(dt.Rows[i][3]) });
                }
                this.dataGrid1.ItemsSource = lus1;
            }
            #endregion
    
            #region 条件查询
            private void SeleteWhere(string Name, string Company, bool? IsDelete)
            {
                OleDbCommand cmd = conn.CreateCommand();
                string sql1 = string.Format("select * from Users where Name='{0}' or Company='{1}' and IsDelete={2}", Name, Company, IsDelete);
                string sql2 = string.Format("select * from Users where Name='{0}' or Company='{1}'", Name, Company);
                if (IsDelete != null) { cmd.CommandText = sql1; } else { cmd.CommandText = sql2; }
                ConnOpen();
                OleDbDataReader dr = cmd.ExecuteReader();
                DataTable dt = new DataTable();
                if (dr.HasRows)
                {
                    for (int i = 0; i < dr.FieldCount; i++)
                    {
                        dt.Columns.Add(dr.GetName(i));
                    }
                    dt.Rows.Clear();
                }
                while (dr.Read())
                {
                    DataRow row = dt.NewRow();
                    for (int i = 0; i < dr.FieldCount; i++)
                    {
                        row[i] = dr[i];
                    }
                    dt.Rows.Add(row);
                }
                cmd.Dispose();
                ConnClose();
    
                List<Users1> lus1 = new List<Users1>();
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    lus1.Add(new Users1 { Id = Convert.ToInt32(dt.Rows[i][0]), Name = dt.Rows[i][1].ToString(), Company = dt.Rows[i][2].ToString(), IsDelete = Convert.ToBoolean(dt.Rows[i][3]) });
                }
                this.dataGrid1.ItemsSource = lus1;
            }
            #endregion 
    
            #region 删除
            private void DeleteUser(int Id)
            {
                try
                {
                    ConnOpen();
                    string strSql = string.Format("delete from Users where Id={0}", Id);
                    OleDbCommand cmd = new OleDbCommand(strSql, conn);
                    int a = cmd.ExecuteNonQuery();
                    ConnClose();
                    if (a > 0)
                    {
                        conns();
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
            #endregion
    
            #region 修改
            private void UpdateUser(string Name, string Company, bool IsDelete, int Id)
            {
                try
                {
                    ConnOpen();
                    string strSql = string.Format("update Users set Name='{0}',Company='{1}',IsDelete={2} where Id={3}", Name, Company, IsDelete, Id);
                    OleDbCommand cmd = new OleDbCommand(strSql, conn);
                    int a = cmd.ExecuteNonQuery();
                    ConnClose();
                    if (a > 0)
                    {
                        conns();
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
    
    
            //一个单元格结束编辑后
            //private void dataGrid1_CellEditEnding(object sender, DataGridCellEditEndingEventArgs e)
            //{
            //    MessageBox.Show("123123");
            //}
    
            //一行结束编辑后
            //private void dataGrid1_RowEditEnding(object sender, DataGridRowEditEndingEventArgs e)
            //{
            //    MessageBox.Show("345345");
            //}
            #endregion
    
            #region 添加
            public void AddUser(string Name, string Company, bool? IsDelete)
            {
                try
                {
                    ConnOpen();
                    //如果为空,默认设置为有效(未删除)
                    if (IsDelete == null) IsDelete = false;
                    string strSql = string.Format("insert into Users(Name,Company,IsDelete) values('{0}','{1}',{2})", Name, Company, IsDelete);
                    OleDbCommand cmd = new OleDbCommand(strSql, conn);
                    int a = cmd.ExecuteNonQuery();
                    ConnClose();
                    if (a > 0)
                    {
                        conns();
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
    
    
    
    
    
            #endregion
    
            #region gridcontrol设置
            public void set()
            {
                //dataGrid1.OptionsView.ShowGroupPanel = false;
    
                //dataGrid1.Columns[0].AppearanceHeader.TextOptions.HAlignment = DevExpress.Utils.HorzAlignment.Center;
                //dataGrid1.Columns[0].AppearanceCell.TextOptions.HAlignment = DevExpress.Utils.HorzAlignment.Center;
            }
            #endregion 
    
            #endregion
    
        }
    }

    Users1类:

    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    
    namespace ExerciseModel
    {
        public class Users1 : INotifyPropertyChanged
        {
            private int id;
            private string name;
            private string company;
            private bool isDelete;
    
            public event PropertyChangedEventHandler PropertyChanged;
            protected void OnPropertyChanged(string propertyName)
            {
                if (PropertyChanged != null)
                {
                    PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
                }
            }
    
            public int Id
            {
                get
                {
                    return id;
                }
    
                set
                {
                    id = value;
                    OnPropertyChanged("Id");
                }
            }
    
            public string Name
            {
                get
                {
                    return name;
                }
    
                set
                {
                    name = value;
                    OnPropertyChanged("Name");
                }
            }
    
            public string Company
            {
                get
                {
                    return company;
                }
    
                set
                {
                    company = value;
                    OnPropertyChanged("Company");
                }
            }
    
            public bool IsDelete
            {
                get
                {
                    return isDelete;
                }
    
                set
                {
                    isDelete = value;
                    OnPropertyChanged("IsDelete");
                }
            }
        }
    }

    点击修改运行的窗体效果图:

    这个窗体的XAML:

    <Window x:Class="WpfAppFirst.UpdateUser"
            xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
            xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
            xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
            xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
            xmlns:local="clr-namespace:WpfAppFirst"
            mc:Ignorable="d"
            Title="UpdateUser" Height="327.988" Width="349.854" Loaded="Window_Loaded">
        <Grid>
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="*"/>
                <ColumnDefinition Width="*"/>
            </Grid.ColumnDefinitions>
            <Grid.RowDefinitions>
                <RowDefinition Height="*"/>
                <RowDefinition Height="*"/>
                <RowDefinition Height="*"/>
                <RowDefinition Height="*"/>
                <RowDefinition Height="*"/>
                <RowDefinition Height="*"/>
            </Grid.RowDefinitions>
            <Border Grid.ColumnSpan="2">
                <Label Content="修改" Foreground="#000" FontSize="24" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></Label>
            </Border>
    
            <Border Grid.Row="1" Grid.ColumnSpan="2">
                <Label Content="编号:" FontSize="16" Foreground="#000" VerticalContentAlignment="Center" Padding="50,0,0,0"></Label>
            </Border>
            <Border Grid.Row="1" Grid.Column="1" Grid.ColumnSpan="2">
                <Label x:Name="Ids" FontSize="14" Foreground="#000" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></Label>
            </Border>
    
            <Border Grid.Row="2" Grid.ColumnSpan="2">
                <Label Content="负责人:" FontSize="16" Foreground="#000" VerticalContentAlignment="Center" Padding="50,0,0,0"></Label>
            </Border>
            <Border Grid.Row="2" Grid.Column="1" Grid.ColumnSpan="2">
                <TextBox x:Name="UName" Background="AliceBlue" Height="30" Width="160"></TextBox>
            </Border>
    
            <Border Grid.Row="3" Grid.ColumnSpan="2">
                <Label Content="负责人单位:" FontSize="16" Foreground="#000" VerticalContentAlignment="Center" Padding="50,0,0,0"></Label>
            </Border>
            <Border Grid.Row="3" Grid.Column="1" Grid.ColumnSpan="2">
                <TextBox x:Name="UCompany" Background="AliceBlue" Height="30" Width="160"></TextBox>
            </Border>
    
            <Border Grid.Row="4" Grid.ColumnSpan="2">
                <Label Content="状态:" FontSize="16" Foreground="#000" VerticalContentAlignment="Center" Padding="50,0,0,0"></Label>
            </Border>
            <Border Grid.Row="4" Grid.Column="1" Grid.ColumnSpan="2">
                <ComboBox x:Name="UIsDelete" Background="AliceBlue" Height="30" Width="160">
                    <ComboBoxItem IsSelected="True">有效</ComboBoxItem>
                    <ComboBoxItem>无效</ComboBoxItem>
                </ComboBox>
            </Border>
    
            <Border Grid.Row="5" Grid.ColumnSpan="1">
                <Border Background="Aquamarine" CornerRadius="2,2,2,2" Width="100" Height="30" Cursor="Hand" MouseLeftButtonDown="Border_MouseLeftButtonDown">
                    <Label Content="确定" FontSize="16" Foreground="#000" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></Label>
                </Border>
            </Border>
            <Border Grid.Row="5" Grid.Column="5" Grid.ColumnSpan="1">
                <Border Background="Aquamarine" CornerRadius="2,2,2,2" Width="100" Height="30" Cursor="Hand" MouseLeftButtonDown="Border_MouseLeftButtonDown_1">
                    <Label Content="取消" FontSize="16" Foreground="#000" VerticalContentAlignment="Center" HorizontalContentAlignment="Center"></Label>
                </Border>
            </Border>
    
        </Grid>
    </Window>

    然后后台隐藏代码:

    using ExerciseModel;
    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Data.OleDb;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Imaging;
    using System.Windows.Shapes;
    
    namespace WpfAppFirst
    {
        /// <summary>
        /// UpdateUser.xaml 的交互逻辑
        /// </summary>
        public partial class UpdateUser : Window
        {
            public UpdateUser()
            {
                InitializeComponent();
                
            }
    
            #region 连接开关
            OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=D:\用户目录\我的文档\Access\Organization.mdb"); //Jet OLEDB:Database Password=
            public void ConnOpen()
            {
                if (conn.State == System.Data.ConnectionState.Closed)
                {
                    conn.Open();
                }
            }
            public void ConnClose()
            {
                if (conn.State == System.Data.ConnectionState.Open)
                {
                    conn.Close();
                }
            }
            #endregion
    
            private void UUser(string Name, string Company, bool IsDelete, int Id)
            {
                try
                {
                    ConnOpen();
                    string strSql = string.Format("update Users set Name='{0}',Company='{1}',IsDelete={2} where Id={3}", Name, Company, IsDelete, Id);
                    OleDbCommand cmd = new OleDbCommand(strSql, conn);
                    int a = cmd.ExecuteNonQuery();
                    ConnClose();
                    if (a > 0)
                    {
                        MessageBox.Show("已修改");
                    }
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message);
                }
            }
    
            #region 查询
    
            public DataTable SelectUser(int id)
            {
                OleDbCommand cmd = conn.CreateCommand();
                string sql = string.Format("select * from Users where id={0}", id);
                cmd.CommandText = sql;
                ConnOpen();
                OleDbDataReader dr = cmd.ExecuteReader();
                DataTable dt = new DataTable();
                if (dr.HasRows)
                {
                    for (int i = 0; i < dr.FieldCount; i++)
                    {
                        dt.Columns.Add(dr.GetName(i));
                    }
                    dt.Rows.Clear();
                }
                while (dr.Read())
                {
                    DataRow row = dt.NewRow();
                    for (int i = 0; i < dr.FieldCount; i++)
                    {
                        row[i] = dr[i];
                    }
                    dt.Rows.Add(row);
                }
                cmd.Dispose();
                ConnClose();
                return dt;
                //List<Users1> lus1 = new List<Users1>();
                //for (int i = 0; i < dt.Rows.Count; i++)
                //{
                //    lus1.Add(new Users1 { Id = Convert.ToInt32(dt.Rows[i][0]), Name = dt.Rows[i][1].ToString(), Company = dt.Rows[i][2].ToString(), IsDelete = Convert.ToBoolean(dt.Rows[i][3]) });
                //}
            }
            #endregion
    
            /// <summary>
            /// 修改
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Border_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
            {
                bool bl = false;
                if (this.UIsDelete.Text == "有效")
                    bl = true;
                UUser(this.UName.Text, this.UCompany.Text, bl, Convert.ToInt32(this.Ids.Content));
            }
    
            /// <summary>
            /// 取消
            /// </summary>
            /// <param name="sender"></param>
            /// <param name="e"></param>
            private void Border_MouseLeftButtonDown_1(object sender, MouseButtonEventArgs e)
            {
                this.Close();
            }
    
            private void Window_Loaded(object sender, RoutedEventArgs e)
            {
                var sour = SelectUser(Convert.ToInt32(this.Ids.Content));
                this.UName.Text = sour.Rows[0]["Name"].ToString();
                this.UCompany.Text = sour.Rows[0]["Company"].ToString();
                this.UIsDelete.SelectedItem = sour.Rows[0]["IsDelete"].ToString();
            }
        }
    }
  • 相关阅读:
    关于自动分裂的思考 | Solrex 杨文博的博客,记录我的生活、技术、思想和梦想
    在STL中,map按值来排序的实现方法_永不言弃是生命的基调!_百度空间
    C/C++学习路线(教材推荐)_Hello World!_百度空间
    Google C++ Style中允许使用的Boost库(1) 程序即人生 博客频道 CSDN.NET
    STL中map按值(value)排序
    程序即人生 » 移动平台现在可用的C++ 11特性
    开发者应该了解的 12 款 Eclipse 插件 编程语言 ITeye资讯
    Lisp的给力特性(V.S. Python3) 第二篇 程序即人生 博客频道 CSDN.NET
    Solidot | 地球上有多少Java程序员?
    在STL中,map按值来排序的实现方法
  • 原文地址:https://www.cnblogs.com/SeNaiTes/p/9414143.html
Copyright © 2011-2022 走看看