今天在调试程序的时候想使用最新版本的企业库,原先公司使用的是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中。