Модераторы: LSD
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> System scheme, Scheme scheme что это? Oracle XE 
V
    Опции темы
Berliner
Дата 23.5.2006, 15:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



здраствуйте подскажите пожалуста что такое System scheme, Object Scheme. А то читал в хелпе по Oracle и не понял что это, может роли? 
PM   Вверх
Sqlninja
Дата 23.5.2006, 16:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 353
Регистрация: 15.5.2006
Где: San Francisco, CA

Репутация: 13
Всего: 13



Вообще, это набор логических структур данных.

Каждый обьектв Oracle хранится в определенной условной схеме. Схема может быть системной типа SYS или SYSTEM,  или пользовательской типа SCOTT. Каждый юзер имеет свою схему, которая имеет такое же имя как и он. В схему могут входить самые различные объекты - таблицы, индексы, кластеры, Java классы и.т.д. Манипуляции со схемами осуществляются с помощью SQL.

  

Это сообщение отредактировал(а) Sqlninja - 23.5.2006, 16:07


--------------------
It's better to burn out than to fade away.
PM MAIL WWW ICQ   Вверх
batigoal
Дата 23.5.2006, 16:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 2
Всего: 151



Насколько я понимаю, это практически то же самое, что пользователь (под которым ты коннектишься). Т.е., грубо говоря, 1 юзер соответствует 1 схеме и наоборот.

Поправьте, если не так. 


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
Sqlninja
Дата 23.5.2006, 16:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 353
Регистрация: 15.5.2006
Где: San Francisco, CA

Репутация: 13
Всего: 13



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


--------------------
It's better to burn out than to fade away.
PM MAIL WWW ICQ   Вверх
LSD
Дата 23.5.2006, 20:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 18
Всего: 538



Схема это что-то вроде пакетов в Java, просто способ логически сгруппировать данные.

В Oracle схема жестко привязанна к пользователю, но  например в SQL Server - нет, схема существует независимо от пользователя. 


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
Berliner
Дата 24.5.2006, 11:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 803
Регистрация: 18.5.2005

Репутация: нет
Всего: 2



Интересно, когда ставил сервер у меня спросили пароль  system ввел пароль(я так понимаю это пароль админа),  есть тестовый юзер HR с базой про сотрудников. Пытаюсь сделать выборку из этой быза про сотрудников, при помощи пользователя system- пишет(что типа недоступная схема или что то такое), интересно пароль администратора и недоступная схема. Хотя насколько я понял из Help что в Oracle есть несколько типов администраторов. 
PM   Вверх
batigoal
Дата 24.5.2006, 11:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 2
Всего: 151



Цитата(Berliner @  24.5.2006,  12:09 Найти цитируемый пост)
Пытаюсь сделать выборку из этой быза про сотрудников, при помощи пользователя system- пишет(что типа недоступная схема или что то такое), 

Потому что SYSTEM имеет доступ ко всем схемам, из-за этого нужно указать схему явно. Типа такого:
Код

SELECT * FROM hr.dual;

 


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
LSD
Дата 25.5.2006, 10:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 18
Всего: 538



Цитата(Berliner @  24.5.2006,  12:09 Найти цитируемый пост)
Хотя насколько я понял из Help что в Oracle есть несколько типов администраторов.

Вероятнее всего там речь шла о DBA, а не учетных записях. Действительно в Oracle выделяют 12 разных типов DBA, по специализции, но это уже изыски.
Из учетных записей можно выделить SYS, это пользователь в схеме которого хранятся все словари, системные данные и т.п. Любой пользователь соединившийся как SYSDBA, автоматически начинает работать от имени SYS. 


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
BIZ0N
Дата 27.5.2006, 18:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 7
Регистрация: 27.5.2006

Репутация: нет
Всего: нет



Вопрос: а обьекты тоже обязательно принадлежат какойнибудь схеме? а системные представления (например dba_users)?

Я просто читаю статью с www.firststeps.ru (он здесь упоминался как один из хороших источников), не могу проглотить вот эту фразу:
Цитата

В отличие от процедур и функций, которые могут содержатся локально в блоке или хранится в базе данных, пакеты могут быть только хранимыми и никогда локальными!


Про что здесь разговор? О том, где может храниться код (на клиенте или на сервере), или про то что обьекты не принадлежат отдельной схеме, а принадлежат базе в целом? 
PM MAIL   Вверх
batigoal
Дата 27.5.2006, 20:16 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Нелетучий Мыш
****


Профиль
Группа: Участник Клуба
Сообщений: 6423
Регистрация: 28.12.2004
Где: Санктъ-Петербургъ

Репутация: 2
Всего: 151



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

Цитата(BIZ0N @  27.5.2006,  19:18 Найти цитируемый пост)
а системные представления (например dba_users)?

Судя по коду, они принадлежат схеме SYS:
Код

REM SYS V_$OPEN_CURSOR

  CREATE OR REPLACE FORCE VIEW "SYS"."V_$OPEN_CURSOR" ("SADDR", "SID", "USER_NAME", "ADDRESS", "HASH_VALUE", "SQL_ID", "SQL_TEXT") AS 
  select "SADDR","SID","USER_NAME","ADDRESS","HASH_VALUE","SQL_ID","SQL_TEXT" from v$open_cursor;
 


--------------------
"Чтобы правильно задать вопрос, нужно знать большую часть ответа" (Р. Шекли)
ЖоржЖЖ
PM WWW   Вверх
Sqlninja
Дата 28.5.2006, 11:58 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 353
Регистрация: 15.5.2006
Где: San Francisco, CA

Репутация: 13
Всего: 13



Цитата(BIZ0N @  27.5.2006,  18:18 Найти цитируемый пост)
Про что здесь разговор? О том, где может храниться код (на клиенте или на сервере), или про то что обьекты не принадлежат отдельной схеме, а принадлежат базе в целом?  


Здесь просто нужно  понять отличие хранимых обьектов от локальных. Хранимый объект, например, процедура, пакет или функция, хранится в базе в скомпилированном виде, в так называемом P-Code. При наличии соответствующих привилегий хранимые обьекты могут быть доступны из внешних программ и быть видимыми для всех пользователей.

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

Так вот, Вы не можете создавать локальные пакеты в программных блоках, ни в анонимных, ни в именованых, то есть подобное делать нельзя:

Код

declare
  package pkg_coca_cola_mstat is
  ...
  end pkg_coca_cola_mstat;
begin
...
end;
 


--------------------
It's better to burn out than to fade away.
PM MAIL WWW ICQ   Вверх
BIZ0N
Дата 28.5.2006, 18:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 7
Регистрация: 27.5.2006

Репутация: нет
Всего: нет



to Sqlninja: Спасибо именно то, что хотел услышать! (очень хороший пример) 
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Oracle"
Zloxa
LSD

Данный раздел предназначен для обсуждения проблем с Oracle Database, другие продукты Oracle здесь не обсуждаются. Просьба при создании темы, придерживаться следующих правил:

  • при создании темы давайте ей осмысленное название, описывающее суть проблемы
  • указывайте используемую версию базы, способ соединения и язык программирования
  • при ошибках обязательно приводите код ошибки и сообщение сервера
  • приводите код в котором возникла ошибка, по возможности дайте тестовый пример демонстрирующий ошибку
  • при вставке кода используйте соответсвующие теги: [code=sql] [/code] для подсветки SQL и PL/SQL кода, [code=java] [/code] - для Java, и т.д.

  • документация по Oracle: 9i, 10g, 11g
  • книги по Oracle можно поискать здесь
  • действия модераторов можно обсудить здесь

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, LSD.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Oracle | Следующая тема »


 




[ Время генерации скрипта: 0.0905 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.