Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Вопросы и ответы на них, 2ой семестр (Герман Олег Витольдович) [4145 вопросов].docx
Скачиваний:
53
Добавлен:
15.06.2014
Размер:
569.48 Кб
Скачать
  1. Взаимодействие c# с Oracle

  • Oracle Database или Oracle RDBMS — объектно-реляционная система управления базами данных компании Oracle. БД Oracle используется не только как хранилище, но и как визуализация интерфейса бд. Имеется внутренний язык PLISQL, средства для администрирования SQL*PLUS, мастер для создания БД и другое.

  • Пример работы с C#:

  • using System;

  • using System.Collections.Generic;

  • using System.Text;

  • using System.Data;

  • using System.Data.OracleClient;

  • namespace ConsoleApplication5

  • {

  • class Program

  • {

  • static void Main(string[] args)

  • {

  • using (OracleConnection ocon = new OracleConnection("DataSource=OKCL; userId = stud; password = 1234"));

  • OracleCommand ocmd = new OracleCommand();

  • ocmd.Connection(ocon);

  • ocmd.CommandText = "myProc";

  • ocmd.CommandType = CommandType.StoredProcedure;

  • ocmd.Parameters.Add("Derp", OracleType.Number).Value();

  • ocmd.Parameters.Add("pcount", OracleType.Number).Direction() = ParameterDirection.Output;

  • try

  • {

  • ocon.Open();

  • ocmd.ExecuteNonQuery();

  • System.Console.WriteLine("Number returned =" + ocmd.Parameters["pcount"].Value());

  • }

  • catch (Exception) { }

  • ocon.Close;

  • System.Console.ReadLine();

  • }

  • }

  • }

  1. Хранимые процедуры и модули Oracle

  • При обращении к примеру п.43, процедура будет иметь вид:

  • Create or replace procedure myproc ( derpno number, count out number)

  • Is

  • Begin

  • Select count (x)

  • Into pcount

  • From employe

  • Where derp = derpno

  • End myproc

  1. Развитые типы данных Oracle (массив, таблица, объект)

  • Массив varray представляет собой коллекцию объектов определённого типа.

  • SQL> create type

  • Tax_tp as object(

  • Year Date

  • Tax number);

  • SQL>create type

  • My_arr as array(3) of Tax_tp;

  • Объявление массива:

  • DECLARE

  • TYPE t_ar IS VARRAY(250) OF VARCHAR(100);

  • V1 t_ar;

  • i NUMBER :=0

  • BEGIN

  • LOOP

  • IF (i >= 100) THEN

  • EXIT;

  • END IF;

  • V1(i):=TO CHAR(i);

  • END LOOP;

  • END

  • Типовая заготовка (структура) ХП oracle может быть представлена определённым образом:

  • Create or replace procedure

  • имя_процедуры

  • Is

  • Declare

  • …объявление переменных и типов…

  • Begin

  • … исполнительный порядок…

  • Exception

  • …Обработка исключения…

  • End имя_процедуры

  • Таблицы:

  • Тип таблиц ближе к массивам, но отличие в том, что каждый элемент таблицы имеет индекс, например, V(-15):=’Mir’. Количество элементов не фиксировано, объявление таблицы:

  • DECLARE

  • TYPE t_tab IS TABLE OF VARCHAR(10)

  • INDEX BY BINARY_INTEGER;

  • V1 t_tab

  • BEGIN

  • V1(-4) = ‘John’

  • V1(0) = ‘Doe’;

  • END;

  • В отличии от массива, в таблице индексы не обязаны последовательно возрастать. Пример с заполнением таблицы:

  • DECLARE

  • TYPE t_tab IS TABLE OF Stud %TYPE

  • INDEX BY BINARY INTEGER;

  • V1.t_tab

  • BEGIN

  • SELECT * INTO V1(-2)

  • FROM stud

  • WHERE Id = -2

  • END;

  • В таблице и массиве есть ряд доступных свойств: COUNT, FIRST, LAST, NEXT, DELETE(10) (удаление строки с индексом 10), DELETE(10,200) (удаление записи из диапазона от 10 до 200). Пример:

  • DECLARE

  • TYPE t_tab IS TABLE OF stud.FN%TYPE

  • INDEX BY BINARY_INTEGER;

  • FNAMES t_tab;

  • BEGIN

  • FNAMES(1):=’John’;

  • FNAMES(3):=’Doe’;

  • IF FNAMES.EXISTS(1) THEN FNAMES.DELETE(1)

  • END IF;

  • END

  • Курсоры:

  • Declare

  • Cursor ordc is

  • Select * from Orders;

  • Cursor get_Orditem(prom_num orders.ord_num % type) is

  • Select quantity

  • From orders where ord_num = prod.num;

  • Пример работы с курсорами:

  • DECLARE

  • V_stud students.IO%TYPE;

  • V_FirstName students.FirstName%TYPE;

  • V_Depart students.Department%TYPE:=”Computer Science”;

  • CURSOR c_Students IS

  • SELECT id, FirstName

  • FROM students

  • WHERE Department=V_Depart

  • Begin

  • Open c_Students;

  • LOOP

  • FETCH c_Students INTO V_stud, v_FirstName

  • EXIT WHEN

  • C_Students% NOT FOUND;

  • END LOOP

  • CLOSE c_Students;

  • END;

  • Пример с курсорными переменными:

  • DECLARE

  • TYPE L_classes IS REF CURSOR

  • Return classes%ROWTYPE

  • V_c1 c_Classes;

  • Open v_c1 FOR

  • SELECT * FROM Classes;

  • REF – ссылка на курсор; V_c1 – курсорная переменная.

  • Пример с функцией:

  • CREATE OR REPLACE FUNCTION MyFun (x IN BOOLEN)

  • RETURN VARCHAR2

  • IS

  • DECLARE

  • Str VARCHAR(5);

  • Begin

  • IF (x) THEN

  • Str:=”TRUE”;

  • ELSE

  • Str:=”FALSE”;

  • ENDIF

  • RETURN(Str);

  • END MyFun

  • Также имеется большое количество встроенных функций, таких как CHR(x) (возврат символа в формате ASCII), CONCAT(s1,s2) (Объединение строк), SUBSTR(s,n1,n2) (выделение в строке S n2 символов начиная с n1) и так далее.