zoukankan      html  css  js  c++  java
  • 解决“未能加载文件或程序集“Microsoft.Practices.EnterpriseLibrary.Data,Version=4.1.0.0, Culture=neutral, PublicKeyToken=58a508d96b29b237”

            今天在调试程序的时候想使用最新版本的企业库,原先公司使用的是4.0版本的。没想到,在新功能中加入了4.1版本的企业库时候出现了如上的错误。在网上搜到了一些答案,但是很多都没有用。

           网上有两种方法:

                 1)将PublicKeyToken=58a508d96b29b233去掉

                 2)将PublicKeyToken=58a508d96b29b233改成PublicKeyToken=null

           但是这两种方法都没有效果。

          那就继续使用4.0版本的吧。因为公司的东西签过名,所以就直接将PublicKeyToken=58a508d96b29b233删掉了,以后再做签名处理。这样之后,还是会出现以上问题。那就直接到EL的官网下载了4.0的版本,将所有的添加企业库的地方都替换为现在新下载过来的版本。结果是不报这个错了。原因已经很明白了。那就是不同版本或者不同签名的企业库在同时使用。

           企业库的这个错没了,又来了另外的错。

          “failed: System.Data.OracleClient.OracleException : ORA-01036: 非法的变量名/编号”

          查看了下这里,才知道,这个是Oracle里面的变量名要用 “=:”来连接的。在这里记录一下。

      SqlClient参数表达式:@ParameterName  
      OracleClient参数表达式::ParameterName  
      OleDB.Net参数表达式:? 

    简单给个例子:

    OracleClient:

    public DataTable GetRepairRecordData(string DeviceHierarchyId) {
                Database db = DatabaseFactory.CreateDatabase();
                string sql = "select * from fpi_repairrecord where hierarchyid=:hierarchyid";
                DbCommand command = db.GetSqlStringCommand(sql);
                db.AddInParameter(command, "hierarchyid", DbType.String, DeviceHierarchyId);
                return db.ExecuteDataSet(command).Tables[0];
            }

    红色的符号按照上面的方式修改,在不同的数据库Provider中。

  • 相关阅读:
    SQL中的max()函数用法
    C#多线程
    C#操作redis
    spring+mybatis 多数据库事务
    实战项目中 :一个业务对多个数据库操作的同步的处理办法(要么都成功,要么都失败)Threadlocal 数据库事务
    redis之数据操作详解
    C# 两个数组取交集/补集 Intersect()
    MySQL创建索引
    MySQL每日执行
    MySQL删除重复数据
  • 原文地址:https://www.cnblogs.com/UpThinking/p/1585327.html
Copyright © 2011-2022 走看看