您的位置:首页 > 数据库 > Oracle

Oracle.DataAccess 驱动使用因为SQL语句缓存报错问题解决办法

2017-02-16 09:09 585 查看
看一个简单的例子

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using Oracle.ManagedDataAccess.Client;

public partial class ptest : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
using (OracleConnection connection = new OracleConnection(Common.connstr))
{
connection.Open();
OracleCommand cmd = new OracleCommand("select * from v_tmp ", connection);
OracleDataAdapter sa = new OracleDataAdapter(cmd);
DataTable dt = new DataTable();
sa.Fill(dt);
cmd.Parameters.Clear();
Response.Write(dt.Rows.Count.ToString());
}
}
}

 v_tmp 视图脚本如下

create or replace  view v_tmp as  

select 1 a,2 b from dual 

不改变视图情况下,执行是正常的,单我们改变V_TMP视图结构的时候会报错,如:

create or replace  view v_tmp as  

select 1 a,2 b ,1 c from dual  

  

create or replace  view v_tmp as  

select sysdate a,2 b from dual
 

这个问题主要是因为Oracle.DataAccess 为了提高性能,增加了SQL语句的高速缓存,如果后台表是动态的,可以去掉这个功能,在数据库连接里增加 Metadata Pooling=false 配置就可以了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐