Как объявить переменную и использовать ее в том же сценарии Oracle SQL?

Используйте ObjectReader FastMember для создания IDataReader поверх любой коллекции, например:

var student = new List();
...
using(var bcp = new SqlBulkCopy(connection)) 
using(var reader = ObjectReader.Create(student, "Id", "Name", "Email","PhoneNumber")) 
{ 
    bcp.DestinationTableName = "SomeTable"; 
    bcp.WriteToServer(reader); 
}

SqlBulkCopy может использовать либо DataTable, либо IDataReader. ObjectReader.Create создает объект, который оборачивает любую коллекцию и предоставляет его через интерфейс IDataReader, который можно использовать с SqlBulkCopy.

Также можно использовать методы расширения Linq-to-Dataset CopyToDataTable или MoreLinq ToDataTable для создания DataTable из IEnumerable. Они должны будут прочитать весь IEnumerable и кэшировать все данные в DataTable. Это может быть дорого, если есть много строк.

С другой стороны, ObjectReader ничего не нужно кэшировать

119
задан jww 19 February 2019 в 13:36
поделиться

3 ответа

Существует несколько способов объявления переменных в сценариях SQL * Plus.

Первый - использовать VAR для объявления связываемой переменной. Механизм присвоения значений переменной - это вызов EXEC:

SQL> var name varchar2(20)
SQL> exec :name := 'SALES'

PL/SQL procedure successfully completed.

SQL> select * from dept
  2  where dname = :name
  3  /

    DEPTNO DNAME          LOC
---------- -------------- -------------
        30 SALES          CHICAGO

SQL>

Переменная особенно полезна, когда мы хотим вызвать хранимую процедуру, которая имеет параметры OUT или функцию.

В качестве альтернативы мы можем использовать подстановочные переменные. Они хороши для интерактивного режима:

SQL> accept p_dno prompt "Please enter Department number: " default 10
Please enter Department number: 20
SQL> select ename, sal
  2  from emp
  3  where deptno = &p_dno
  4  /
old   3: where deptno = &p_dno
new   3: where deptno = 20

ENAME             SAL
---------- ----------
CLARKE            800
ROBERTSON        2975
RIGBY            3000
KULASH           1100
GASPAROTTO       3000

SQL>

Когда мы пишем сценарий, который вызывает другие сценарии, может быть полезно заранее определить переменные. Этот фрагмент выполняется без запроса ввода значения:

SQL> def p_dno = 40
SQL> select ename, sal
  2  from emp
  3  where deptno = &p_dno
  4  /
old   3: where deptno = &p_dno
new   3: where deptno = 40

no rows selected

SQL>

Наконец, есть анонимный блок PL / SQL. Как видите, мы все еще можем назначать значения объявленным переменным в интерактивном режиме:

SQL> set serveroutput on size unlimited
SQL> declare
  2      n pls_integer;
  3      l_sal number := 3500;
  4      l_dno number := &dno;
  5  begin
  6      select count(*)
  7      into n
  8      from emp
  9      where sal > l_sal
 10      and deptno = l_dno;
 11      dbms_output.put_line('top earners = '||to_char(n));
 12  end;
 13  /
Enter value for dno: 10
old   4:     l_dno number := &dno;
new   4:     l_dno number := 10;
top earners = 1

PL/SQL procedure successfully completed.

SQL>
130
ответ дан 24 November 2019 в 01:51
поделиться

Иногда необходимо использовать макро-переменную, не прося, чтобы пользователь ввел значение. Чаще всего это должно быть сделано с дополнительными параметрами сценария. Следующий код полностью функционален

column 1 noprint new_value 1
select '' "1" from dual where 2!=2;
select nvl('&&1', 'VAH') "1" from dual;
column 1 clear
define 1

, Подобный код был так или иначе найден в rdbms/sql каталоге.

0
ответ дан 24 November 2019 в 01:51
поделиться

Попробуйте использовать двойные кавычки, если это переменная типа char:

DEFINE stupidvar = "'stupidvarcontent'";

или

DEFINE stupidvar = 'stupidvarcontent';

SELECT stupiddata  
FROM stupidtable  
WHERE stupidcolumn = '&stupidvar'

upd:

SQL*Plus: Release 10.2.0.1.0 - Production on Wed Aug 25 17:13:26 2010

Copyright (c) 1982, 2005, Oracle.  All rights reserved.

SQL> conn od/od@etalon
Connected.
SQL> define var = "'FL-208'";
SQL> select code from product where code = &var;
old   1: select code from product where code = &var
new   1: select code from product where code = 'FL-208'

CODE
---------------
FL-208

SQL> define var = 'FL-208';
SQL> select code from product where code = &var;
old   1: select code from product where code = &var
new   1: select code from product where code = FL-208
select code from product where code = FL-208
                                      *
ERROR at line 1:
ORA-06553: PLS-221: 'FL' is not a procedure or is undefined
25
ответ дан 24 November 2019 в 01:51
поделиться
Другие вопросы по тегам:

Похожие вопросы: