Использование манипулирования данными

Oracle предоставляет команды языка обработки данных для выполнения операций с данными в базе данных. Операции с данными могут заключаться в заполнении таблиц базы данных данными приложения или бизнес-данных, изменении данных и удалении данных из базы данных, когда это необходимо. Помимо операций с данными, существует набор команд, которые используются для управления этими операциями. Эти команды сгруппированы как Transaction Control Language.

Есть три типа операторов DML, участвующих в логической транзакции SQL, а именно: Insert, Update, Delete и Merge. Транзакция - это логический набор действий DML в сеансе базы данных.

INSERT заявление

Команда INSERT используется для хранения данных в таблицах. Команда INSERT часто используется в языках программирования более высокого уровня, таких как Visual Basic.NET или C ++, как встроенная команда SQL; однако эту команду также можно выполнить в командной строке SQL * PLUS в командном режиме. Существует две различные формы команды INSERT. Первая форма используется, если новая строка будет иметь значение, вставленное в каждый столбец строки. Вторая форма команды INSERT используется для вставки строк, в которых некоторые данные столбца неизвестны или указаны по умолчанию из другой бизнес-логики. Эта форма команды INSERT требует, чтобы вы указали имена столбцов, для которых хранятся данные.

Синтаксис:

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

INSERT INTO table
VALUES (column1 value, column2 value, 
...);

Приведенный ниже синтаксис можно использовать, если только несколько столбцов из таблицы должны быть заполнены значением. Остальные столбцы могут выводить свои значения либо как NULL, либо из другой бизнес-логики.

INSERT INTO table (column1 name, column2 name, . . .)
VALUES (column1 value, column2 value, . . .);

Приведенный ниже оператор INSERT создает новую запись о сотруднике в таблице EMPLOYEES. Обратите внимание, что он вставляет значения для основных столбцов EMPLOYEE_ID, FIRST_NAME, SALARY и DEPARTMENT_ID.

INSERT INTO employees (EMPLOYEE_ID, FIRST_NAME, SALARY, DEPARTMENT_ID)
VALUES (130, 'KEMP', 3800, 10);

В противном случае полные данные о сотрудниках можно вставить в таблицу EMPLOYEES без указания списка столбцов с помощью приведенного ниже оператора INSERT - при условии, что значения известны заранее и должны соответствовать типу данных и положению столбцов в таблице.

INSERT INTO employees
VALUES (130, 'KEMP','GARNER', '[email protected]', '48309290',TO_DATE ('01-JAN-2012'), 'SALES', 3800, 0, 110, 10);

Вставляемые значения должны быть совместимы с типом данных столбца. В качестве значений столбцов можно использовать литералы, фиксированные значения и специальные значения, такие как функции, SYSDATE, CURRENT_DATE, SEQ.CURRVAL (NEXTVAL) или USER. Указанные значения должны соответствовать общим правилам. Строковые литералы и значения даты должны быть заключены в кавычки. Значение даты может быть указано в формате ДД-МЕС-ЧД или Д-МЕС-ГГГГ, но предпочтительнее ГГГГ, поскольку он четко указывает век и не зависит от внутренней логики вычисления века ЧД.

Инструкция INSERT-AS-SELECT (IAS)

Данные могут быть заполнены в целевую таблицу из исходной таблицы с помощью операции INSERT..AS..SELECT (IAS). Это операция чтения прямого пути. Это простой способ создания копии данных из одной таблицы в другую или создания резервной копии таблицы, в которой операции исходной таблицы находятся в оперативном режиме.

Например, данные могут быть скопированы из таблицы EMPLOYEES в таблицу EMP_HISTORY.

INSERT INTO EMP_HISTORY
SELECT EMPLOYEE_ID, EMPLOYEE_NAME, SALARY, DEPARTMENT_ID
FROM employees;

Заявление UPDATE

Команда UPDATE изменяет данные, хранящиеся в столбце. Она может обновлять одну или несколько строк за раз в зависимости от набора результатов, отфильтрованного по условиям, указанным в предложении WHERE. Обратите внимание, что обновление столбцов отличается от изменения столбцов. Ранее в этой главе вы изучали команду ALTER. Команда ALTER изменяет структуру таблицы, но оставляет неизменными данные таблицы. Команда UPDATE изменяет данные в таблице, а не структуру таблицы.

Синтаксис:

UPDATE table
SET column = value [, column = value ...]
[WHERE condition]

Из синтаксиса

Выражение SET column = может быть любой комбинацией символов, формул или функций, которые будут обновлять данные в указанном имени столбца. Предложение WHERE является необязательным, но если оно включено, оно определяет, какие строки будут обновлены. Только одна таблица может обновляться за раз с помощью команды UPDATE.

Оператор UPDATE ниже обновляет зарплату сотрудника JOHN до 5000.

UPDATE employees
SET salary = 5000
WHERE UPPER (first_name) = 'JOHN';

Хотя предикаты WHERE необязательны, но должны быть добавлены логически, чтобы изменить только требуемую строку в таблице. Оператор UPDATE ниже обновляет зарплаты всех сотрудников в таблице.

UPDATE employees
SET salary = 5000;

Несколько столбцов также можно обновить, указав несколько столбцов в предложении SET, разделенных запятыми. Например, если для JOHN необходимо изменить зарплату и должность на 5000 и SALES соответственно, оператор UPDATE будет выглядеть так:

UPDATE employees
SET	SALARY = 5000,
	JOB_ID = 'SALES'
WHERE UPPER (first_name) = 'JOHN';

1 row updated.

Другой способ обновления нескольких столбцов одной строки показывает использование подзапроса.

UPDATE employees
SET (SALARY, JOB_ID) = (SELECT 5000, 'SALES' FROM DUAL)
WHERE UPPER (ENAME) = 'JOHN'

УДАЛИТЬ заявление

Команда DELETE - один из самых простых операторов SQL. Он удаляет одну или несколько строк из таблицы. В SQL запрещены операции удаления нескольких таблиц. Синтаксис команды DELETE приведен ниже.

DELETE FROM table_name
    [WHERE condition];

Команда DELETE удаляет все строки в таблице, которые удовлетворяют условию в необязательном предложении WHERE. Поскольку предложение WHERE является необязательным, можно легко удалить все строки из таблицы, опуская предложение WHERE, поскольку предложение WHERE ограничивает область действия операции DELETE.

Приведенный ниже оператор DELETE удалит детали EDWIN из таблицы EMP.

DELETE employees
WHERE UPPER (ENAME) = 'EDWIN'

1 row deleted.

Примечание. УДАЛИТЬ [НАЗВАНИЕ ТАБЛИЦЫ] и УДАЛИТЬ ИЗ [НАЗВАНИЕ ТАБЛИЦЫ] имеют одно и то же значение.

Условие WHERE в операторах условного удаления может использовать подзапрос, как показано ниже.

DELETE FROM employees
WHERE DEPARTMENT_ID IN (SELECT DEPARTMENT_ID
				    FROM LOCATIONS
				    WHERE LOCATION_CODE = 'SFO')

TRUNCATE

Truncate - это команда DDL, которая используется для удаления всех записей из таблицы, но с сохранением структуры таблицы. Он не поддерживает условие WHERE для удаления выбранных записей.

Синтаксис:

TRUNCATE [table name]

Это автоматическая фиксация, т.е. фиксирует текущую активную транзакцию в сеансе. Усечение таблицы не удаляет зависимые индексы, триггеры или ограничения таблицы. Если таблица A является родительской по отношению к ограничению ссылки таблицы B в базе данных, таблица A не может быть усечена.

Сделка

Транзакция - это логическая единица работы, выполняемой в базе данных. Он может либо содержать -

  • Несколько команд DML, оканчивающихся командой TCL, например COMMIT или ROLLBACK.

  • Одна команда DDL

  • Одна команда DCL

Начало транзакции отмечается первой командой DML. Он заканчивается командой TCL, DDL или DCL. Команда TCL, то есть COMMIT или ROLLBACK, явно выдает завершение активной транзакции. В силу их основного поведения, если какая-либо из команд DDL или DCL выполняется в сеансе базы данных, фиксирует текущую активную транзакцию в сеансе. Если экземпляр базы данных аварийно завершает работу, транзакция останавливается.

COMMIT, ROLLBACK и SAVEPOINT - это язык управления транзакциями. COMMIT постоянно применяет изменения данных в базе данных, в то время как ROLLBACK выполняет операцию против фиксации. SAVEPOINT контролирует серию транзакции, устанавливая маркеры на разных этапах транзакции. Пользователь может откатить текущую транзакцию до желаемой точки сохранения, которая была установлена ​​ранее.

COMMIT- Фиксация завершает текущую активную транзакцию, постоянно применяя изменения данных в таблицах базы данных. COMMIT - это команда TCL, которая явно завершает транзакцию. Однако команды DDL и DCL неявно фиксируют транзакцию.

SAVEPOINT- Точка сохранения используется для отметки определенной точки в текущей транзакции в сеансе. Поскольку это логический маркер в транзакции, точки сохранения не могут быть запрошены в словарях данных.

ROLLBACK- Команда ROLLBACK используется для завершения всей транзакции путем отмены изменений данных. Если транзакция содержит отмеченные точки сохранения, ROLLBACK TO SAVEPOINT [имя] может использоваться для отката транзакции только до указанной точки сохранения. В результате все изменения данных до указанной точки сохранения будут отброшены.

Демонстрация

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

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (105, 'Allen',TO_DATE ('15-JAN-2013','SALES',10000,10);

SAVEPOINT Allen;

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (106, 'Kate',TO_DATE ('15-JAN-2013','PROD',10000,20);

SAVEPOINT Kate;

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (107, 'McMan',TO_DATE ('15-JAN-2013','ADMIN',12000,30);

SAVEPOINT McMan;

Предположим, оператор подачи данных понимает, что он ошибочно ввел зарплату «Кейт» и «МакМэн». Он откатывает активную транзакцию до точки сохранения Кейт и повторно вводит данные о сотруднике для Кейт и МакМана.

ROLLBACK TO SAVEPOINT Kate;

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (106, 'Kate',TO_DATE ('15-JAN-2013','PROD',12500,20);

SAVEPOINT Kate;

INSERT INTO employees (employee_id, first_name, hire_date, job_id, salary, department_id)
VALUES (107, 'McMan',TO_DATE ('15-JAN-2013','ADMIN',13200,30);

SAVEPOINT McMan;

Закончив ввод данных, он может подтвердить всю транзакцию, выполнив команду COMMIT в текущем сеансе.

Последовательность чтения

Oracle поддерживает согласованность между пользователями в каждом сеансе с точки зрения доступа к данным и операций чтения / записи.

Когда DML встречается в таблице, исходные значения данных, измененные действием, записываются в записи отмены базы данных. Пока транзакция не зафиксирована в базе данных, любой пользователь в другом сеансе, который позже запрашивает измененные данные, просматривает исходные значения данных. Oracle использует текущую информацию в глобальной области системы и информацию в записях отмены для построения согласованного по чтению представления данных таблицы для запроса. Только когда транзакция зафиксирована, изменения транзакции становятся постоянными. Транзакция является ключом к стратегии Oracle по обеспечению согласованности чтения.

Начальная точка для последовательных представлений создается от имени читателей

Контролирует, когда измененные данные могут быть видны другим транзакциям базы данных для чтения или обновления.