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

4 篇文章 0 订阅

看一个简单的例子

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 视图脚本如下

  1. create or replace  view v_tmp as  
  2. select 1 a,2 b from dual 

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

  1. create or replace  view v_tmp as  
  2. select 1 a,2 b ,1 c from dual  
  3.   
  4. create or replace  view v_tmp as  
  5. select sysdate a,2 b from dual  

这个问题主要是因为Oracle.DataAccess 为了提高性能,增加了SQL语句的高速缓存,如果后台表是动态的,可以去掉这个功能,在数据库连接里增加 Metadata Pooling=false 配置就可以了。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值