wpf+access 一个小项目的总结

1、Access中与MS sql的不同之处

  1、exists用法,if(exists(select 1 from a)) 这种用法在ms sql中判断是否有数据,使用也很方便,但在access中不支持这种写法,如果有需要另行别法!

  2、我用ADO.NET读取access库中的数据,不支持多个结果集,无法一次性返回多个表中的数据,只能一个一个获取!

  3、access表中的字段(假设Birthday DateTime 可空),不能手动插入null,你可以不插入这个字段,但不能为该字段插入null;之前在ms sql中插入这类字段的时间,一个insert a(birthday) values({0}) 语句就行,无非判断一下birthday是否有值,如果没有值赋值为null即可,但在Access中像这种情况可能需要拼接了!

  4、关联删除语句中,在access中必须添加distinctrow关键字,如:

deletedistinctrowf.* from
(select FID from Re_Customer_Family where CID=1) r
inner join(select ID from Family) f on r.FID= f.ID

  5、还有一中就是access中,没有row_number()函数,如果想实现分页的话,需要使用top n 来实现!下面是查询第11条到第20条记录的语句:

select a.* from
(select top 20 * from student ) a
left join ( select top 10 * from student ) b on a.ID=b.ID
where iif(b.ID,'0','1')='1'

  access中没if,但有iif(表达式,值1,值2);如果表达式为真,返回值1,否则 返回值2!

2、有关Wpf与winform的差别

  1、WPF应用程序,遇到的第一个问题就是,我没有找到Program类和Main方法!这个让我很郁闷,难到WPF已经不用Main了,那入口点再哪啊?后来Google一翻,发现它隐藏在App.g.cs中,wpf+access 一个小项目的总结_第1张图片

后来自己又添加了一个Program类,里面写了Main方法实现一台机器只能运动一个实例,这时生成 提示出错:已经有一个入口点了!

复制代码
class Program
    {
        [STAThread]
        public static void Main(string[] agrs)
        {
            bool createdNew;
            using (Mutex mutex = new Mutex(false, "025CFB63-2148-44D3-BA12-E4ADDA183B7F", out createdNew))
            {
                if (createdNew)
                {
                    App app = new App();
                    app.InitializeComponent();
                    app.Run();
                }
                else
                {
                    MessageBox.Show("已经启动了一个程序,请先退出!", "系统提示", MessageBoxButton.OK, MessageBoxImage.Error);
                }
            }
        }
    }
复制代码

解决方法:右键项目--》应用程序--》启动对象--》选择刚才添加的Program类即可!

  2、PasswordBox控件,之前在winForm中只需要调协TextBox控件的PassworkChar属性就行了,而在wpf中确是单独的密码控件!

  3、动态绑定显示CheckBox控件问题,

    前台界面xaml代码:

复制代码
<WrapPanel>
                <ItemsControl x:Name="itemsControlSport">
                    <ItemsControl.ItemsPanel>
                        <ItemsPanelTemplate>

                            <WrapPanel Orientation="Horizontal">WrapPanel>
                        ItemsPanelTemplate>
                    ItemsControl.ItemsPanel>
                    <ItemsControl.ItemTemplate>
                        <DataTemplate>
                            <Border Padding="5">
                                <WrapPanel>
                                    <CheckBox  IsChecked="{Binding Checked}"  Tag="{Binding ID}" Content="{Binding Name}"/>
                                WrapPanel>
                            Border>
                        DataTemplate>
                    ItemsControl.ItemTemplate>
                ItemsControl>
            WrapPanel>
复制代码

    后台绑定代码相对简单:

//运动
            DataTable dt = BLL.PBase.GetSportList();
            if (dt == null)
                return;
            itemsControlSport.ItemsSource = dt.DefaultView;

    这一切正确,数据显示也很正常

    获取界面哪些被选中也没问题,得到这个CheckBox集合后随你怎么操作!

复制代码
/// 
        /// 获取DataTemplate控件的函数,返回的是一个集合
        /// 
        /// 
        /// 
        /// 表示查找所有指定类型的控件
        /// 
        public List GetChildObjects(DependencyObject obj, string name) where T : FrameworkElement
        {
            DependencyObject child = null;
            List childList = new List();
            for (int i = 0; i <= VisualTreeHelper.GetChildrenCount(obj) - 1; i++)
            {
                child = VisualTreeHelper.GetChild(obj, i);
                if (child is T && (((T)child).Name == name || string.IsNullOrEmpty(name)))
                {
                    childList.Add((T)child);
                }
                childList.AddRange(GetChildObjects(child, ""));//指定集合的元素添加到List队尾   
            }
            return childList;
        }


//获取所有CheckBox
 List collection = GetChildObjects(itemsControlSport, "");
复制代码

到目前为止这个动态绑定CheckBox显示,获取CheckBox集合都没问题!

但接下来出现了一个问题,小第我Google了两翻也没查到问题的原因,详细说明一下问题:

我做了一个窗体,该窗体用于添加用户信息和修改用户信息,

  wpf+access 一个小项目的总结_第2张图片

当添加用户时一切正常,也可以正常保存,但是当修改用户信息时,窗体首先加载基础数据也就是上面看到的(潜水、航海...),接下来就是读取该用户选择了 哪些选项,让Checkbox选中,

在我绑定基础数据后,直接用上面的方法去获取CheckBox集合循环判断哪个是该用户所拥有的就选中,但是CheckBox集合总是为空(绑定显示Checkbox和获取CheckBox都在窗体加载事件中),

我认为是这样,当我们动态绑定控件时,Window_Load事件没执行完成就去获取,是无法获取的,后来我修改为:如果是添加直接如上方式来绑定显示,如果是修改的话,那让基础数据添加一列是否选中列,再绑定。

  下面一点就不是专指WPF了,我们把程序打包后在win7/vista中安装在系统盘中,如果有些IO的操作是没有权限的,需要我以管理权限运行才行!而且我们打包时创建的快捷方式右键也没有“以管理员身份运行”这个选项,

解决方法是,右键项目,添加一个应用程序描述文件,如:app.manifest 打开后

复制代码
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v2">
    <security>
      <requestedPrivileges xmlns="urn:schemas-microsoft-com:asm.v3">
        
        <requestedExecutionLevel level="asInvoker" uiAccess="false" />
      requestedPrivileges>
    security>
  trustInfo>
复制代码

把level="asInvoker"改成level="requireAdministrator"管理员权限就OK啦。

建议将该文件拖入Properties目录下,如下所示:

wpf+access 一个小项目的总结_第3张图片

这个之后,我们再把这个项目打包后,安装运行时,它就会自动以管理员的身份运行了。

你可能感兴趣的:(wpf+access 一个小项目的总结)