Oracle.DataAccess 드라이브 사용 SQL 문 캐 시 오류 해결 방법

1490 단어 c#oralce
간단 한 예 를 보다
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 설정 하면 됩 니 다.

좋은 웹페이지 즐겨찾기