<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="pl">
	<id>http://brain.fuw.edu.pl/edu/index.php?action=history&amp;feed=atom&amp;title=%2FTransakcje</id>
	<title>/Transakcje - Historia wersji</title>
	<link rel="self" type="application/atom+xml" href="http://brain.fuw.edu.pl/edu/index.php?action=history&amp;feed=atom&amp;title=%2FTransakcje"/>
	<link rel="alternate" type="text/html" href="http://brain.fuw.edu.pl/edu/index.php?title=/Transakcje&amp;action=history"/>
	<updated>2026-04-18T15:56:29Z</updated>
	<subtitle>Historia wersji tej strony wiki</subtitle>
	<generator>MediaWiki 1.34.1</generator>
	<entry>
		<id>http://brain.fuw.edu.pl/edu/index.php?title=/Transakcje&amp;diff=2029&amp;oldid=prev</id>
		<title>Jarekz: Utworzono nową stronę &quot;= TI:WTBD/Transakcje =  Od relacyjnego systemu baz danych wymaga się zazwyczaj własności określanych hasłem ''ACID'': * Atomic -- zlecona operacja modyfikacji d...&quot;</title>
		<link rel="alternate" type="text/html" href="http://brain.fuw.edu.pl/edu/index.php?title=/Transakcje&amp;diff=2029&amp;oldid=prev"/>
		<updated>2015-05-23T14:46:02Z</updated>

		<summary type="html">&lt;p&gt;Utworzono nową stronę &amp;quot;= &lt;a href=&quot;/edu/index.php/TI:WTBD&quot; title=&quot;TI:WTBD&quot;&gt;TI:WTBD&lt;/a&gt;/Transakcje =  Od relacyjnego systemu baz danych wymaga się zazwyczaj własności określanych hasłem &amp;#039;&amp;#039;ACID&amp;#039;&amp;#039;: * Atomic -- zlecona operacja modyfikacji d...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nowa strona&lt;/b&gt;&lt;/p&gt;&lt;div&gt;= [[TI:WTBD]]/Transakcje =&lt;br /&gt;
&lt;br /&gt;
Od relacyjnego systemu baz danych wymaga się zazwyczaj własności określanych hasłem ''ACID'':&lt;br /&gt;
* Atomic -- zlecona operacja modyfikacji danych udaje się w całości, albo wcale; nie może być operacji wykonanych częściowo&lt;br /&gt;
* Consistent -- każda zakończona sukcesem operacja modyfikacji danych musi prowadzić do spójnego stanu bazy, tzn. zgodnego z więzami narzuconymi przez definicję danych&lt;br /&gt;
* Isolated -- operacje modyfikacji danych nie mogą ze sobą interferować ani się przeplatać; nie powinny być również widoczne w stanie częściowego wykonania&lt;br /&gt;
* Durable -- stan bazy będący wynikiem zakończonej operacji jest trwały; nie jest podatny na uszkodzenie w wyniku późniejszych nieudanych operacji czy błędów powstałych po zakończeniu tej operacji.&lt;br /&gt;
Najczęściej kompromisom podlega własność izolacji, ponieważ jej ścisłe przestrzeganie ma silny ujemny wpływ na wydajność w sytuacji wielodostępu.&lt;br /&gt;
:SQLite, mimo że jest systemem wbudowanym (biblioteką operacji na danych w lokalnym pliku, a nie -- systemem klient-serwer) w dużym stopniu zachowuje własności ACID w sytuacji wielodostępu.&lt;br /&gt;
Po to, by również operacje na danych nie dające się sformułować jako pojedyncze instrukcje SQL mogły być traktowane jako operacje atomowe w powyższym sensie, SQL wprowadza pojęcie ''transakcji''.&lt;br /&gt;
* Każda operacja zmieniająca dane ma miejsce w ramach ''transakcji''.&lt;br /&gt;
* Jeżeli w chwili wydania polecenia zmieniającego dane nie ma otwartej transakcji, zostaje ona otwarta automatycznie.&lt;br /&gt;
* Jawne otwarcie transakcji:&lt;br /&gt;
: BEGIN [ DEFERRED | IMMEDIATE | EXCLUSIVE ] [ TRANSACTION ];&lt;br /&gt;
* Czyli wystarczy napisać BEGIN. Domyślnie stosowana jest opcja DEFERRED.&lt;br /&gt;
* Opcje różnią się sposobem stosowania blokad wielodostępu:&lt;br /&gt;
** DEFERRED nic nie blokuje dopóki nie zacznie się wykonywać faktycznych operacji&lt;br /&gt;
** IMMEDIATE blokuje od razu zapisy&lt;br /&gt;
** EXCLUSIVE blokuje zapisy i odczyty (nieco upraszczając)&lt;br /&gt;
* Zamknięcie transakcji to albo jej zatwierdzenie:&lt;br /&gt;
** { COMMIT | END } [ TRANSACTION ];&lt;br /&gt;
* albo jej wycofanie:&lt;br /&gt;
** ROLLBACK [ TRANSACTION ];&lt;br /&gt;
* Zamknięcie połączenia z bazą powoduje ''wycofanie'' bieżącej transakcji, o ile jakaś transakcja pozostawała otwarta.&lt;br /&gt;
* Wycofanie może również nastąpić automatycznie, gdy w wykonaniu transakcji wystąpił błąd&lt;br /&gt;
* Transakcji otwieranych poleceniem BEGIN nie można zagnieżdżać. Do tego służą punkty wycofania:&lt;br /&gt;
** SAVEPOINT ''nazwa'';&lt;br /&gt;
* Do takie punktu można się w razie czego cofnąć:&lt;br /&gt;
** ROLLBACK [ TRANSACTION ] TO [ SAVEPOINT ] ''nazwa'';&lt;br /&gt;
* Można też go ,,zwolnić&amp;quot;:&lt;br /&gt;
** RELEASE [ SAVEPOINT ] ''nazwa'';&lt;br /&gt;
* Nazwy punktów wycofania nie muszą być unikalne (SQLite), cofanie jest do najbliższego punktu o pasującej nazwie.&lt;/div&gt;</summary>
		<author><name>Jarekz</name></author>
		
	</entry>
</feed>