Oracle
 sql >> Baza danych >  >> RDS >> Oracle

Grupuj wiele instrukcji SELECT podczas wywoływania Oracle z ADO.NET

Przykład w C# z wieloma kursorami i parametrem wejściowym:

string ConnectionString = "connectionString";
OracleConnection conn = new OracleConnection(ConnectionString);
StringBuilder sql = new StringBuilder();

sql.Append("begin ");
sql.Append("open :1 for select * from table_1 where id = :id; ");
sql.Append("open :2 for select * from table_2; ");
sql.Append("open :3 for select * from table_3; ");
sql.Append("end;");

OracleCommand comm = new OracleCommand(sql.ToString(),_conn);

comm.Parameters.Add("p_cursor_1", OracleDbType.RefCursor, DBNull.Value, ParameterDirection.Output);

comm.Parameters.Add("p_id", OracleDbType.Int32, Id, ParameterDirection.Input);

comm.Parameters.Add("p_cursor_2", OracleDbType.RefCursor, DBNull.Value, ParameterDirection.Output);

comm.Parameters.Add("p_cursor_3", OracleDbType.RefCursor, DBNull.Value, ParameterDirection.Output);

conn.Open();

OracleDataReader dr = comm.ExecuteReader();


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Najlepsze praktyki:.NET:Jak zwrócić PK w bazie danych Oracle?

  2. Czy „Wybierz” zawsze porządkuje według klucza podstawowego?

  3. ADD_MONTHS() Funkcja w Oracle

  4. ORA-12705:Nie można uzyskać dostępu do plików danych NLS lub nieprawidłowego środowiska

  5. różnica między NLS_NCHAR_CHARACTERSET i NLS_CHARACTERSET dla Oracle