Используйте 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 ничего не нужно кэшировать
Существует несколько способов объявления переменных в сценариях 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>
Иногда необходимо использовать макро-переменную, не прося, чтобы пользователь ввел значение. Чаще всего это должно быть сделано с дополнительными параметрами сценария. Следующий код полностью функционален
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 каталоге.
Попробуйте использовать двойные кавычки, если это переменная типа 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