Bazy danych « Różności …

Różności …

28 grudnia 2010

Oracle notki, startup, shutdown.

Zaszufladkowany do: Bazy danych,Oracle — Tagi: — Jacek @ 11:50
Połączenie bez podawania loginu i hasła:
# sqlplus / as sysdba
to jest autentykacja wg systemu operacyjnego. To jest możliwe bo użytkownik należy do grupy DBA.
STARTUP PROCESS
UNMOUT – instance started (background processes + memory structures)
w ORACLE_HOME/dbs oracle szuka: spfilsSID.ora potem spfile.ora potem initSID.ora
status: STARTED
sql> alter database mount;
MOUNT – instance is associated with database
tu wczytywane są control files. W control filach informacje o plikach bazodanowych, redologach
sql> alter database open;
OPEN – datafiles i redologs are open.
sql> show parameter control_files
sql> slect status from v$instance;
sql> startup pfile=’lokalizacja’
sql> startup restrict
tylko uprzywilejowani użytkownicy mogą się zalogować do bazy
sql> show user – aby sprawdzić jako kto jestem zalogowany
SHUTDOWN PROCESS
CLOSE
UNMOUNT
SHUTDOWN
shutdown = shutdown normal – czeka na zamknięcie każdej sesji
shutdown transactional – czeka na zakończenie transakcji
shutdown immediate – kończy każdą sesję
shutdown abort – przy uruchamianiu konieczne jest recovery (apply redologs to database)

Oracle notki – struktura fizyczna i logiczna

Zaszufladkowany do: Bazy danych,Oracle — Tagi: — Jacek @ 11:41
instance – collection of background processes and memory structures
database – collection of files that contain your data
RAC – real application cluster – wiele instancji pisze do tej samej bazy danych. Jeżeli jedna instancja pada – druga przejmuje jej rolę.
sql> show parameter db_name
sql> show paremeter instance_name
sql> show paremeter db_block_size
w przypadku data warehouse – big rows – wtedy usawia się blocksize na 32K a nie na 8K
Memory structures:
SGA – system global area
wymagane:
BUFFER CACHE – store datablocks – jeżeli później zada się takie samo zapytanie sql to dane pójdą z cache’u – improve performance
i tu tylko datablocks przechowywane takie jak domyślny blocksize (procesy: CKPT-zmienia nagłówki plików występuje wtedy gdy DBW zapisuje dane
do pliku lub gdy log writer zapisuje redo log lub występuje co pewien czas, DBW0-database writer-zapisuje informacje w blokach
z buffer cache do datafile)
LOG BUFFER – zapamiętuje zmiany zrobione w bazie danch – a potem te zmiany są zapisywane do REDO LOGów a potem do ARCHIVE LOGów.
To wszystko jes robione aby było możliwe recovery. (procesy: LGWR – log writer – zapisuje z log buffer do redo logs, ARC0 – archiving process -
zapisuje redo logi do archive logów)
SHARED POOL – tu przechowywane są wyrażenia SQL. Tutaj też przechowywane są DATA DICTIONARY INFORMATION – opis jakie tabele, użytkownicy itd.
opcjonalne:
JAVA POOL
STREAMS POOL – używa się, jeżeli jest wiele serwerów na których jest baza danch.
LARGE POOL – przechowuje informacje o backupach i restorach i SHARED SERVER INFORMATION – jeżeli jest kilka procesów pobierających te
same informacje.
KEEP POOL – tu można przechować np. wartości określonej tabeli i trzymać tak długo jak się da.
RECYCLE POOL – jeżeli np. chcemy przeskanować całą tabelę a nie chcemy aby ta operacja zżarła całą dostępną pamięć – dane wtedy nie są trzymane
w buffer cache.
32K BUFFER
16K BUFFER
4K BUFFER
2K BUFFER – to są buffer cache dla tabel o innych blocksize
PMON – process monitor – zarezerwowany dla procesów userów, jeżeli sesja zerwana to czyści zasoby.
SMON – system monitor – instance recovery
W LINUKSIE KAŻDY PROCES OSOBNO W WINDOWSACH JEDEN ROZBITY NA WIELE WĄTKÓW
SERVER PROCESS – odpowiedzialny za pobieranie danych z bazy danych – każdy z procesów ma przydzieloną pamięć PGA – PROGRAM GLOBAL AREA – informacje dotyczące sesji jak zmienne
USER PROCESS – łączy się z SERVER PROCESS
DEDICATED SERVER ENVIRONMENT – jeden server process odpowiada jednemu user process
SHARED SERVER CONFIGURATION
—— PHYSICAL STRUCTURES ——-
database files – .dbf
redo log files – .log
dobrze jest aby w każdej grupie był więcej niż jeden redolog file na wypadek awarii któregoś!!!! warto aby drugi redolog był na ososbnym dysku!!!!
skrypt: add_redolog_file.sql
po dodaniu mają status invalid.
należy wykonać alter system switch logfile; – aby oracle przeszedł do następnego logu – należy wykonać tyle razy ile nowych logów dodanych aby przeszło przez wszystkie
undo tablespace – .dbf – używana do rolling back information np na wypadek usunięcia danych których nie chciałem
spfile – server parameter file lun init file initialization file
sql> show parameter spfile
jeżeli VALUE w tym zapytaniu będzie puste to znaczy, że używam starego init.file
pliki spfile i init są przechowywane w ORACLE_HOME/dbs
alert log i trace files
sql> show parameter background_dump_dest
control files .ctl
czytane przez instancję, kiedy baza danych startuje
zawierają informacje o fizycznej strukturze bazy danych
dobrze jest mieć 3 controlfile na różnych dyskach!!!!
controlfiles to dokładnie kopie siebie samych. w wypadku awarii trzeba skopiować dobry controlfile na zły i uruchomić instancję
backup files
—— LOGICAL STRUCTURES ——-
tablespace
system tablespace – data dictionary
sysaux tablespace – auxiliary purporse
undo tablespace – potrzebne do rollbacku
temp tablespace – używane do sortowania danych w wypadku gdy nie mamay dosyć RAMu
segment
table segment
index segment
temporary segment
Jeżeli tworzę np tabelę to oracle rezerwuje segment. Jeżeli segment zostanie wypełniony to oracle rezerwuje następną przestrzeń zwaną EXTENT. Extent to kilka kolejnych bloków bazy danych.

Oracle notki

Zaszufladkowany do: Bazy danych,Oracle — Tagi: — Jacek @ 11:37
instalacja oracle 11gr2 na fed1
nie można było uruchomić bazy danych
skopiowałem orahome/base/admin/orcl/pfile/init.ora.8883224234 do base/db11gr2/dbs/initfed1orcl.ora
przy uruchomianiu dostałem komunikaty:
~~~~~~~~~~~~~~~~~~~~~~~~~
ORA-00845 MEMORY TARGET not supported on this system
ORA-00845: MEMORY_TARGET not supported on this system
Problem Description
While creating a startup database using dbca the database creation GUI gives error message in a pop up window,
ORA-00845: MEMORY_TARGET not supported on this system
from where you can ignore the error message.
The similar scenario also occur whenever you try to start your database then startup shows error message like below.
SQL> STARTUP
ORA-00845: MEMORY_TARGET not supported on this system
Cause of the Problem
•Starting from Oracle 11g the automatic memory management feature is now defined with parameter MEMORY_TARGET and MEMMORY_MAX_TARGET.
•On linux file system the shared memory need to be mounted on /dev/shm directory on the operating system.
•And the size of /dev/shm needs to be greater than MEMORY_TARGET or MEMMORY_MAX_TARGET.
•The AMM (Automatic Memory Management) now in 11g manages both SGA and PGA together by MMAN process.
•The MEMORY_TARGET parameter in 11g comes for (SGA_TARGET+PGA_AGGREGATE_TARGET) which was in 10g.
•And MEMORY_MAX_TARGET parameter in 11g comes instead of SGA_MAX_TARGET parameter which was in 10g.
•The ORA-00845:can arises for the following two reasons on linux system.
1)If the shared memory which is mapped to /dev/shm directory is less than the size of MEMORY_TARGET or MEMORY_MAX_TARGET.
or,
2)If the shared memory is not mapped to /dev/shm directory.
Solution of the Problem
Make sure /dev/shm is properly mounted. You can see it by,
#df -h or #df -k command.
The output should be similar like
$ df -k
Filesystem            Size  Used Avail Use% Mounted on
shmfs                 1G    512M 512M  50% /dev/shm
We see here for /dev/shm we have assigned 1G memory. Now if you set MEMORY_TARGET more than 1G then above ORA-845 will arise. For example if you have MEMORY_TARGET or MEMORY_MAX_TARGET set to 12G then you can mount shared memory to 13g like below.
As a root user,
# mount -t tmpfs shmfs -o size=13g /dev/shm
In order to make the settings persistence so that it will affect after restarting machine add an entry in /etc/fstab similar to the following:
shmfs /dev/shm tmpfs size=13g 0
~~~~~~~~~~~~~~~~~~~~~~
wykonałem:
# mount -t tmpfs shmfs -o size=13g /dev/shm
~~~~~~~~~~~~~~~~~~~~~~~~~~~
przy kolejnym sql>startup otrzymałem błąd:
ORA-01102:cannot mount database in EXCLUSIVE mode
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
The Oracle docs note this on the ora-01102 error:
ORA-01102 cannot mount database in EXCLUSIVE mode
Cause: Some other instance has the database mounted exclusive or shared.
Action: Shut down the other instance or mount in a compatible mode.
ORA-01102 occurs when you are mounting (opening) a database, typically because another instance is already opened in parallel (exclusive) mode.
To resolve ORA-01102, you should try opening the base, which causing the error, in parallel mode after shutting down other instances.  If these steps leave ORA-01102 unresolved, you may need to try restarting OracleService<SID>
Oracle DBA Forums contains a good explanation of  how ORA-01102 may also be thrown under false pretenses:
Question:
Chris Pena asked what the following error regards
SQL> startup force pfile=’/apps/oracle/product/10.2.0/db_1/dbs/inittest01.ora’
ORACLE instance started.
Answer (by Burleson):
The docs note:
ORA-01102: cannot mount database in exclusive mode
Cause: An instance tried to mount the database in exclusive mode, but some other instance has already mounted the database in exclusive or parallel mode.
Action: Either mount the database in parallel mode or shut down all other instances before mounting the database in exclusive mode.
The ORA-01102 is a “false” error in this regard (assuming that you are not using data guard), and this note may be helpful:
********************************
http://www.orafaq.com/forum/t/40030/0/
database is started in EXCLUSIVE mode by default. Therefore, the
ORA-01102 error is misleading and may have occurred due to one of the
following reasons:
- there is still an “sgadef<sid>.dbf” file in the “ORACLE_HOME/dbs”
directory
- the processes for Oracle (pmon, smon, lgwr and dbwr) still exist
- shared memory segments and semaphores still exist even though the
database has been shutdown
- there is a “ORACLE_HOME/dbs/lk<sid>” file
The “lk<sid>” and “sgadef<sid>.dbf” files are used for locking shared memory.
It seems that even though no memory is allocated, Oracle thinks memory is
still locked. By removing the “sgadef” and “lk” files you remove any knowledge
oracle has of shared memory that is in use. Now the database can start.
POSSIBLE SOLUTION:
Verify that the database was shutdown cleanly by doing the following:
1. Verify that there is not a “sgadef<sid>.dbf” file in the directory
“ORACLE_HOME/dbs”.
% ls $ORACLE_HOME/dbs/sgadef<sid>.dbf
If this file does exist, remove it.
% rm $ORACLE_HOME/dbs/sgadef<sid>.dbf
2. Verify that there are no background processes owned by “oracle”
% ps -ef | grep ora_ | grep $ORACLE_SID
If background processes exist, remove them by using the Unix
command “kill”. For example:
% kill -9 <Process_ID_Number>
3. Verify that no shared memory segments and semaphores that are owned
by “oracle” still exist
% ipcs -b
If there are shared memory segments and semaphores owned by “oracle”,
remove the shared memory segments
% ipcrm -m <Shared_Memory_ID_Number>
and remove the semaphores
% ipcrm -s <Semaphore_ID_Number>
NOTE: The example shown above assumes that you only have one
database on this machine. If you have more than one
database, you will need to shutdown all other databases
before proceeding with Step 4.
4. Verify that the “$ORACLE_HOME/dbs/lk<sid>” file does not exist
5. Startup the instance
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
faktycznie w katalogu base/db11gr2/dbs
był plik lkORCL, który usunąłem po wcześniejszym zamknięciu bazy danych
przy kolejnym
sql> startup
dostałem błąd:
ORA-00205: Error in identifying control file, check alert log for more info
ale baza się otworzyła tylko nie zamontowała.
sprawdzam gdzie jest alert log:
sql> show parameter dump_dest
i szukam user_dump_dest
w logu jest komunikat:
ORA-00210: cannot open the specified control file
ORA-00202: control file:
‘/home/oracle/orahome/base/flash_recovery_area/orcl/control02.ctl’
ORA-27086: unable to lock file – already in use
zrobiłem kopię obu control files i skasowałem oryginały a potem znowu skopiowałem kopie pod oryginalne nazwy.
to rozwiązało problem i baza się uruchamia ale teraz wszystkie pliki dbf są zablokowane.
trzeba było wykasować plik base/db11gr2/dbs/lkORCL i przeładować system i wykonać komendę zaraz po uruchomieniu:
# mount -t tmpfs shmfs -o size=4g /dev/shm
instaluje oracle na winxp3
global databse name xp3orcl.winxp3
sid: xp3orcl
netca – oracle network configuration assistant
dbca – oracle database configuration assistant

Oracle notki – installation.

Zaszufladkowany do: Bazy danych,Oracle,PL/SQL,SQL — Tagi: — Jacek @ 11:29
database configuration assistant:
c:> dbca (w windowsach)
aby zapisać konfigurację bazy danych w windowsach i ewentualnie puszczać tworzenie instancji automatycznie:
c:\database> setup -record -destinationFile c:\database\basic.rsp (jest to tzw. response file)
uruchomi się instaler, ale na samym końcu nie nalży instalować tylko dać cancel
potem:
c:\database> setup -silent -responseFile c:\\database\basic.rsp
tworzenie bazy danych od podstaw:
najpierw należy stworzyć serwis:
oradim -new -sid test
potem należy utworzyć plik inittest.ora
#inittest.ora
DB_NAME=test
INSTANCE_NAME=test.johnson
CONTROL_FILES = (“c:\oracle\ctrlfiles\control01.ctl”, “c:\oracle\ctrlfiles\control02.ctl”, “c:\oracle\ctrlfiles\control03.ctl”)
BACKGROUND_DUMP_DEST = c:\oracle\product\10.2.0\admin\bdump
USER_DUMP_DEST = c:\oracle\product\10.2.0\admin\udump
DB_FILES = 1000
UNDO_MANAGEMENT = auto
UNDO_TABLESPACE=undo
SHARED_POOL_SIZE=75m  (jest używane do przechowywanie poleceń sql)
potem uruchamiamy
sqlplus / as sysdba
sql> startup nomount pfile=’c:\oracle\product\10.2.0\db_1\database\inittest.ora’
pfile to parameter file
potem należy stworzyć plik do utworzenia samej bazy danych: create.sql
– create.sql
CREATE DATABASE test
MAXLOGFILES 32
MAXDATAFILES 500
DATAFILE ‘c:\baza\system01.dbf’ SIZE 325M REUSE          (reuse – znaczy, że jeżeli plik już jest to zostanie nadpisany)
SYSAUX DATAFILE ‘c:\baza\sysaux01.dbf’ SIZE 300M REUSE
AUTOEXTEND ON NEXT 10240K MAXSIZE UNLIMITED
UNDO TABLESPACE “UNDO” DATAFILE ‘c:\baza\undo01.dbf’
SIZE 200M REUSE AUTOEXTEND ON NEXT 5120K MAXSIZE UNLIMITED
CHARACTER SET WE8MSWIN1252
logfile ‘c:\baza\redo01.log’ size 100m reuse,
‘c:\baza\redo02.log’ size 100m reuse,
‘c:\baza\redo03.log’ size 100m reuse;
potem:
sql> @create.sql

Oracle – notki, SQL, PL/SQL

Zaszufladkowany do: Bazy danych,Oracle,PL/SQL,Programowanie,SQL — Tagi: , , — Jacek @ 11:16
sql> host – aby dostać się do promptu hosta
c:> echo %oracle_sid% lub echo $oracle_sid$
c:> exit
sql>
po zalaogowaniu można wydać komendę:
sql> define
i wyświetlą się parametry informujące o tym jako kto jesteśmy podłączeni
będąc podłączonym można podłączyć się jako inny user
sql> connect sys as sysdba
Sprawdzenie jakie tabele są w schemacie użytkownika:
sql> select table_name from user_tables;
sql> desc ps$ (opis tabeli)
sql> set pagesize 200
sql> / (ponowne uruchomienie polecenia z buforu)
sql> l lub list – wyswietla to co jest w buforze
w buforze jest tylko ostatnie polecenie
jeżeli chcemy coś zmienić w buforze:
sql> 2
podajemy numer linii w której chcemy zrobić zmianę
sql> c/name/surename
i określamy (c – change) co na co chcemy zamienić
SQL – Structured Query Language
określenie w jakim formacie ma zostać wyświetlana data;
sql> alter session set nls_date_format=’mm/dd/yyyy’;
można określić jak inne dane mają być wyświetlane:
sql> col sal fromat $999,999.00
sql> col ename heading ‘Employee|Name’
Jeżeli chcemy coś dodać do bufora:
sql> 1
sql> a ,nazwisko
aby format danej kolumny był taki jak jakiejś innej można:
sql> col comm like sal heading “Commision”
aby kolumna była szersza:
sql> col job format a15
wyszyszczenie formatowania:
sql> col comm clear
lub
sql> clear columns
jeżeli chcemy zachować ostatnią komendę z bufora:
sql> save plik.sql
uruchomienie
sql> @plik.sql
zapis wyników:
sql> spool plik.txt
sql> spool off
sql> host
c:> type plik.txt
c:> exit
sql> spool plik.txt append
można robić zmiany bufora w edytorze:
ed
i wyświetlić/zdefiniować edytor
define _editor
define _editor=c:\notepad
Jeżeli chcemy wstawić zmienną do zapytania
… where job=’&p’
sql> undefine p
aby wyświetlać po stronie:
sql> set pause on
sql> set pagesize 35
Plik z ustawieniami środowiska startowy:
SQLPATH=c:\oracle\product
tam trzeba umieścić plik:
login.sql
sql> help index
sql> help define
zmiana hasła
sql> passw user1
Na serwerze aplikacji można uruchomić isqlplus, który pozwala na dostęp do bazy danych przez przeglądarkę internetową:
c:> isqlplusctl start
potem w przeglądarce
http://localhost:5560/isqlplus

Oracle (i)

Zaszufladkowany do: Oracle — Jacek @ 09:05

Baza:
Oracle 11gR2 EE with RAC, Partitioning, Spatial (active/active)

Zarządzanie procesami biznesowymi:
Oracle Unified Business Process Management Suite. (active/active)

Repozytorium dokumentów:
Oracle Universal Content Management.

Portal:
Oracle WebLogic Portal.

Infrastruktura cache:
Oracle Coherence EE

Opis:
Oracle BPM Suite:

  • Oracle WebCenter Suite
  • Oracle Universal Content Management

Oracle WebCenter Suite:

  • Oracle WebCenter Services
  • Oracle WebCenter Interaction
  • Oracle WebLogic Portal
  • Oracle WebCenter Suite Spaces Component

BPEL – Business Proces Execution Language

27 grudnia 2010

Oracle Architecture (K1)

Zaszufladkowany do: Bazy danych,Oracle — Tagi: — Jacek @ 11:17

The term database refers to the physical storage of information, and the
term instance refers to the software executing on the server that provides access to
the information in the database.

Oracle’s database structures include tablespaces, control files, redo log files, archived
logs, block change tracking files, Flashback logs, and recovery backup (RMAN) files.

tablespace is a logical structure. Each tablespace is composed of physical structures called datafiles.
Oracle9i introduced the concept of Oracle Managed Files (OMFs), which enable
your database to automatically create, name, and delete, where appropriate, all the
files that make up your database.

The control file contains locations for other physical files that form the database: the
datafiles and redo log files.
It also contains key information about the contents and
state of the database, including:
• The name of the database
• When the database was created
• Names and locations of datafiles and redo log files
• Tablespace information
• Datafile offline ranges
• The log history and current log sequence information
• Archived log information
• Backup set, pieces, datafile, and redo log information
• Datafile copy information
• Checkpoint information

Datafiles contain the actual data stored in the database, the tables and indexes that
store data, the data dictionary that maintains information about these data structures,
and the rollback segments used to implement concurrency.

The first block of each datafile is called the datafile header (checkpoint structure).
From a physical point of view, a datafile is stored as operating system blocks.
From alogical point of view, datafiles have three intermediate organizational levels:
datablocks, extents, and segments. An extent is a set of data blocks that are contiguouswithin
an Oracle datafile. A segment is an object that takes up space in an Oracledatabase,
such as a table or an index that is composed of one or more extents.
OracleDatabase 10g added a Segment Advisor that greatly simplifies reclaiming
unusedspace in current database versions.

Redo log files contain a “recording” of the changes made to the database as a
resultof transactions and internal Oracle activities. In addition, redo log files are used
for “undo” operations when a ROLLBACK statementis issued.
If you do decide to suppress redo logging for certain operations, you would
include theNOLOGGING keyword in the SQL statement (index creation, podczas
odtwarzania nie będzie utworzony – trzeba będzie utworzyć go ponownie).
In addition tousing the NOLOGGING keyword in certain commands, you can also mark
a tableor an entire tablespace with the NOLOGGING attribute. This will suppress redoinformation
for all applicable operations on the table or for all tables in thetablespace.
Oracle writes synchronously to all redo log members.
ALTER DATABASE ARCHIVELOG (od Oracle 10g)
LOG_ARCHIVE_START = TRUE (w initialization file, do 10g)
LOG_ARCHIVE_DEST = C:\ORANT\DATABASE\ARCHIVE
LOG_ARCHIVE_FORMAT = ORCL%t_%s_%r.arc

An Oracle instance can be defined as an area of shared memory and a collection of
background processes.
The area of shared memory for an instance is called the SystemGlobal Area, or SGA.
Oracle Database 10g introduced Automatic Shared Memory Management (ASM).
Whenever the MEMORY_TARGET (new to Oracle Database11g) or SGA_TARGET initialization
parameter is set, the database automatically distributesthe memory among various SGA
components providing optimal memory management.

The database buffer cache holds blocks of data retrieved from the database.

The shared pool caches various constructs that can be shared among users. Forexample, SQL queries
and query fragments issued by users and results are cached sothey can be reused if the same statement
is submitted again. PL/SQL functions arealso loaded into the shared pool for execution.
The sharedpool is also used for caching information from the Oracle data dictionary, which isthe
metadata that describes the structure and content of the database itself.

The redo log buffer caches redo information until it is written to the physical redolog files stored on a disk.

Large pool provides memory allocation for various I/O server processes, backup, and recovery,
and provides session memory where shared servers and Oracle XA for transactionprocessing are used.

Java pool provides memory allocation for Java objects and Java execution, including datain the
Java Virtual Machine in the database.

Streams pool provides memory allocation used to buffer Oracle Streams queued messages in the SGA
instead of in database tables and provides memory for capture and apply.

Dynamic initialization parameters available for these pools include LARGE_POOL_SIZE, JAVA_POOL_SIZE,
and STREAMS_POOL_SIZE. These are automatically setif MEMORY_TARGET or SGA_TARGET is specified.

The PGA (Process Global Area) consists of session memory and a private SQL area. Thememory amount can
be controlled by setting the PGA_AGGREGATE_TARGET initializationparameter. (automatyczne zarządzanie
od 10g) As of OracleDatabase 11g, PGA memory allocation is automatically tuned along with the SGA memory
allocations by setting MEMORY_TARGET.

Background Processes:

Database Writer (DBWn)
Writes database blocks from the database buffer cache in the SGA to the datafileson disk.

Log Writer (LGWR)
Writes the redo information from the log buffer in the SGA to all copies of thecurrent redo
log file on disk.

System Monitor (SMON)
SMON performscrash recovery when the instance is started after a failure and coordinates
andperforms recovery for a failed instance when youhave more than one instanceaccessing
the same database, as with Real Application Clusters. SMON alsocleans up adjacent pieces of
free space in the datafiles by merging them into onepiece and gets rid of space used for sorting
rows when that space is no longer needed.

Process Monitor (PMON)
Watches over the user processes that access the database.

Archiver (ARCn)
Reads the redo log files once Oracle has filled them and writes a copy of the usedredo log files
to the specified archive log destination(s).

Checkpoint (CKPT)
Updates datafile headers whenever a checkpoint is performed.

Recover (RECO)
Automatically cleans up failed or suspended distributed transactions.

Dispatcher
Optional background processes used when shared server configurations aredeployed.

Global Cache Service (LMS)
Manages resources for Real Application Clusters and interinstance resourcecontrol.

Job Queue
Provides a scheduler service used to schedule user PL/SQL statements or proceduresin batch.

Queue Monitor (QMNn)
Monitors Oracle Streams message queues with up to 10 monitoring processessupported.

Automatic Storage Management (ASM) processes
RBAL coordinates rebalancing of activities for disk groups. ORBn performs theactual rebalancing.
ASMB provides communication between the database andthe ASM instance.

The Data Dictionary
A set of metadata that describes the data structureincluding table definitions and integrity constraints.

25 grudnia 2010

MySQL – podstawy

Zaszufladkowany do: Bazy danych,MySQL — Tagi: — Jacek @ 22:45
mysql> SELECT * FROM Cars INTO OUTFILE '/tmp/cars.csv'
    -> FIELDS TERMINATED BY ',';


http://zetcode.com/databases/mysqltutorial/exportimport/

łączenie do MySQL mysql przetargi --host=153.19.105.4 -p sql> grant all privileges on nazwabazy.* to user@localhost identified by "jakieshaslo";

mysql> set character_set_client=latin2;

mysql> set character_set_connection=utf8;

mysql> load data infile "/tmp/przyswajalne" into table strony fields
terminated by ';' LINES TERMINATED BY '\r\n' (nazwa_html,zawartosc);

mysql> CREATE DATABASE akw_baza_test DEFAULT CHARACTER SET utf8 COLLATE
utf8_general_ci;

mysql> create table produkty (nr INT NOT NULL AUTO_INCREMENT, kategoria
VARCHAR(20), jednostka VARCHAR(10), iloscp INT, wstog FLOAT, odchylenie
FLOAT, co VARCHAR(50), rodzaj VARCHAR(50), podrodzaj VARCHAR(50), sklasnik
VARCHAR(60), PRIMARY KEY (nr)) default character set utf8;

mysql> alter table produkty add column skladnik VARCHAR(60);

mysql> load data infile "d:\\jacek\\pierdoly\\trans\\1.csv" into table
produkty character set cp1250 fields terminated by ';' LINES TERMINATED BY
'\r\n' (skladnik, jednostka, iloscp, wstog, odchylenie);

sql> update produkty set kategoria="konserwa" where nr<12;

character_set_client = the character set data from the client is encoded in
character_set_connection = MySQL converts incoming data to. It converts
from character_set_client
character_set_results = MySQL converts outgoing data to
character_set_server = character set for the new database
character_set_database = character set for the new tables
character_set_system = the character set for meta data: database, table,
column names

aby ustawić:
set character_set_results = latin2; (lub utf8, lub iso-8859-2)

show variables like "%char%";
show variables like "%collation%";

aby poprawnie wpisywać z windowsowej konsoli trzeba ustawić:
set character_set_client = cp852;
również aby poprawnie zobaczyć w konsoli jakie są zapisy w kolumnach
trzeba ustawić
set character_set_results = cp852;
aby na stronie WWW wyświetlało się poprawnie należy ustawić:
mysql_query("SET character_set_results=utf8"); lub latin2
tuż przed zadaniem zapytania

mysqldump --user=root --password=haslo --default-character-set=utf8 --opt
-all badania > badania.sql
mysql db_name < backup-file.sql

create table opla_pass (numer int NOT NULL auto_increment, user
varchar(100), haslo varchar(100), ip varchar(30), nazwa_komputera
varchar(40), PRIMARY KEY (numer));

create table skany (porzadkowy int not null auto_increment, numer int,
skan blob, primary key (porzadkowy));

grant select,insert,update,delete on faktury.* to 'fakt'@'localhost'
identified by 'haslo';

alter table skany modify column skan longblob;
alter table skany drop column data_dodania;

logowanie do pliku zewnętrznego:
mysql> tee mysql.out
Logging to file 'mysql.out'

echo "select * from customer;" | mysql {required options} custdb >
customer.txt

mysql> insert into produkty (kategoria, jednostka, iloscp, wstog,
odchylenie, co, rodzaj, podrodzaj, skladnik, medium, coi
d) values ("", "miligramy", "10", "6490.5" , NULL, "szprot w oleju",
"kwasy tłuszczowe", "nasycone", "", "", "2");
/usr/local/mysql/bin/mysqldump --user=root --password=haslo --max_allowed_packet=99M --opt --all spamassassin > spamassassin.sql

24 grudnia 2010

Oracle wprowadzenie (K1)

Zaszufladkowany do: Bazy danych,Oracle — Tagi: — Jacek @ 15:44
  • Oracle 8 – 1997
  • Oracle 8i – 1999
  • Oracle 9i – 2001
  • Oracle 10g – 2003
  • Oracle 11g – 2007

Rodzaje baz danych:

  • Oracle Express Edition
    1GB RAM, 4 GB Dysk
  • Oracle Personal Edition
    dla developerów. Wymagana licencja. Funkcjonalność SE
  • Oracle Standard Edition One
    do 2 CPU, brak wsparcia dla RAC
  • Oracle Standard Edition
    do 4 CPU na pojedynczym systemie lub klastrze RAC
  • Oracle Enterprise Edition

ODBC – Open DataBase Connectivity standard.
JDBC – Java DataBase Connectivity open standard.
OCI – Oracle Call Interface – interfejs programistyczny – tworzenie zaawansowanych i wydajnych programów.

Oracle Internet DirectoryOID pozwala na połączenie z serwerem bez plików konfiguracyjnych po stronie klienta. OID jest implementacją LDAP
(Lightweight Directory Access Protocol)

Oracle Connection Manager – CMAN – pozwala na ograniczenie połączeń typu Oracle Net poprzez użycie koncentratorów.

Oracle Application Server

  • BPEL Business Process Execution Language (BPEL) – tool is designed for
    Service-Oriented Architecture (SOA) environments and used for creating, managing,
    and deploying cross-application business processes.
  • Business Activity Monitoring (BAM)
  • WebCenter – portal framework used for deploying portlets and
    Ajax-based components.

The Fusion Middleware SOA Suite serves as the basis for Oracle’s Application
Integration Architecture (AIA).

Distributed Queries and Transactions
Distributed queries can retrieve data from multiple databases.
Distributed transactions can insert, update, or delete data on distributed databases.
Oracle’s two-phase commit mechanism.

Transportable Tablespaces
Database Parallelization
Bitmap indexes
Bitmap indexes typically work best for columns that have few different values relative to the overall number of rows in a  table.
A bitmap index uses an individual bit for each
potential value with the bit either “on” (set to 1) to indicate that the row contains the
value or “off” (set to 0) to indicate that the row does not contain the value.

OLAP
Online Analytical Processing.
Za wikipedią: Kostka OLAP (ang. OLAP cube) – wielowymiarowa baza danych, która przechowuje dane w sposób bardziej
przypominający wielowymiarowe arkusze kalkulacyjne niż tradycyjną, relacyjną bazę danych. Kostka umożliwia
wyświetlanie i oglądanie danych z różnych punktów widzenia. Do jej budowy potrzeba dowolnego źródła danych
opartego na relacjach. Ze względów wydajnościowych zaleca się stosowanie źródeł opartych na języku SQL i
technologii hurtowni danych.
The OLAP Option physically stores dimensionally aware cubes in the Oracle relational
database. These cubes are most frequently accessed using SQL, although a
22 | Chapter 1: Introducing Oracle
Java API is also supported.

Data Mining Option.
Business intelligence tools.

Database Management Features.
Starting with Oracle Database 10g, statistics are automatically gathered to an Automatic
Workload Repository (AWR) within the database.
Oracle’s Automatic Database
Diagnostic Monitor (ADDM) evaluates the statistics on a regular basis and sends alerts
of potential problem conditions to Oracle Enterprise Manager.
Some of the newer fully automated features, such as Automatic Memory Management, also leverage
data gathered in the AWR.

Oracle Enterprise Manager.
EM provides a database management tool framework and an
HTML-based interface used to manage database users, instances, and features. EM
can also manage Oracle Application Server, Oracle Applications, Oracle’s Linux
release, and software products from other vendors.

Data Guard.
The standby database
provides a copy of the production database to be used if the primary database is lost.

Oracle Real Application Clusters.
Cache Fusion that greatly minimizes the amount of writing to disk
that was formerly used to control data locks.
Oracle Database 10g introduced a new
level of RAC portability and Oracle support by providing integrated “clusterware”
for the supported RAC platforms.
Applications can leverage the Oracle Call Interface (OCI) to provide failover to a
second instance transparently to the user.

Automated Storage Management.

Oracle Portal.
Servlety to technologia skryptów Java wykonywanych po stronie serwera.
Portlet jest to niezależny komponent stworzony najczęściej w języku Java do umieszczenia
na stronie www. Są to programy wyświetlające jedną funkcjonalność na stronie. Portlet jest
umieszczany w kontenerze portletów, który agreguje zawartość prezentowanej strony.
Celem portletów jest stworzenie programu, który będzie uniezależniony od kontenera,
na którym będzie uruchamiany, co stwarza możliwość jego wielokrotnego użycia.

Oracle TimesTen.
Oracle TimesTen is a relational database that is stored in physical memory and is
typically used where very high-performance transaction-processing workloads are
present.

MySQL – zwiększenie rozmiaru bazy danych

Zaszufladkowany do: Bazy danych,MySQL — Tagi: — Jacek @ 14:00
mysql> show engines;
mysql> show table status;
aby dodać miejsce (INNODB) trzeba zamknąć bazę:
mysqladmin -u root -p shutdown
a następnie w /etc/my.cnf trzeba dodać kolejny plik
innodb_data_file_path = dbdata1:200M;dbdata2:200M;dbdata3:512M
i uruchomić bazę ponownie.

23 grudnia 2010

Oracle – sesje użytkowników.

Zaszufladkowany do: Bazy danych,Oracle,Skrypty SQL i PL/SQL — Tagi: — Jacek @ 16:44
Aby wyświetlić aktywne sesje użytkowników w bazie danych Oracle:
select b.Username, b.Osuser, b.Process, b.Machine, a.Spid, b.Program, b.Sid, b.Serial#
from v$process a, v$session b
where a.Addr = b.Paddr ORDER BY b.Machine
/
« Nowsze wpisy

Strona startowa: www.jaceksen.pl