zoukankan      html  css  js  c++  java
  • Enterprise Library通过程序修改数据库链接的问题

    最近在做一个项目,用到了Enterprise Library,其中用户登陆以后,修改数据库链接,代码如下:
     
               Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
                ConfigurationSection section = config.ConnectionStrings;

                config.ConnectionStrings.ConnectionStrings[0].ConnectionString = connectionString;

                config.Save(ConfigurationSaveMode.Full);

    其中connectionString是新的链接字符串,保存修改后,再次链接数据库,却发现并没有改变。为了测试问题出在甚么地方,我添加了一个检测congfig文件修改的事件,代码如下:

                Configuration config = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
                ConfigurationSection section = config.ConnectionStrings;

                fileWatcher = new ConfigurationChangeFileWatcher(config.FilePath, section.SectionInformation.Name);
                fileWatcher.ConfigurationChanged += new ConfigurationChangedEventHandler(fileWatcher_ConfigurationChanged);

                fileWatcher.StartWatching();


            void fileWatcher_ConfigurationChanged(object sender, ConfigurationChangedEventArgs e)
            {
                richTextBox.AppendText(Environment.NewLine + "数据库连接地址已改变!");
            }

    实际测试中发现,点击保存后,可能过了5,6秒的样子,congfig文件才发生改变,我想这可能是缓存的问题,但是怎么让她立即更新呢,请大家多多帮忙。

  • 相关阅读:
    C#零相位数字滤波器,改写自Matlab函数filtfilt
    [收藏]C语言格式化字符串
    C#调用PMAC运动控制卡的pcomm32动态链接库的数据类型转换
    [收藏]常见逻辑电平标准
    主要软件作品展示
    新一年希望做的事情
    单元测试的思维导图
    SQLite简单教程
    关于动态执行SQL Statement on ISeries
    突然发现一个 IBM.Data.DB2.ISeries的一个小问题,也是很头痛的问题
  • 原文地址:https://www.cnblogs.com/soonssa/p/782896.html
Copyright © 2011-2022 走看看