24.09.2017, 07:53 [+3 UTC]
в нашей команде: 2 128 чел. | участники онлайн: 4 (рекорд: 21)

:: РЕГИСТРАЦИЯ

:: консультации

:: задать вопрос

:: все разделы

:: правила

:: новости

:: участники

:: доска почёта

:: форум

:: блоги

:: поиск

:: статистика

:: наш журнал

:: наши встречи

:: наша галерея

:: отзывы о нас

:: поддержка

:: руководство

Версия системы:
7.41 (25.02.2017)

Общие новости:
23.02.2017, 09:51

Форум:
23.09.2017, 18:51

Последний вопрос:
23.09.2017, 14:31

Последний ответ:
23.09.2017, 08:43

Последняя рассылка:
23.09.2017, 22:45

Писем в очереди:
0

Мы в соцсетях:

Наша кнопка:

RFpro.ru - здесь вам помогут!

Отзывы о нас:
12.07.2012, 12:16 »
Заречнева Вера Михайловна
Спасибо за подсказку по поводу excel. возможно, что мне это очень поможет в расчетах. [вопрос № 186440, ответ № 271335]
21.09.2009, 14:53 »
Игорь Алексеевич
Большое спасибо Товарищ Бородин! Ваш совет по поводу длинных тегов <?php ?> помог! SSI на народе не поддерживается, по поводу Javascript ваши сомнения обоснованы! [вопрос № 172363, ответ № 254411]
28.09.2009, 18:03 »
AkaProc
Огромное спасибо! В Mozilla Firefox все отлично показывает! [вопрос № 172676, ответ № 254800]

РАЗДЕЛ • Базы данных

Установка и настройка серверов баз данных, таблицы и запросы.

[администратор рассылки: Коцюрбенко Алексей aka Жерар (Мастер-Эксперт)]

Лучшие эксперты в этом разделе

Megaloman
Статус: Академик
Рейтинг: 23
Коцюрбенко Алексей aka Жерар
Статус: Мастер-Эксперт
Рейтинг: 0
Alexander Babich
Статус: Профессор
Рейтинг: 0

Перейти к консультации №:
 

Консультация онлайн # 136493
Раздел: • Базы данных
Автор вопроса: PaTiFoN
Отправлена: 12.05.2008, 16:34
Поступило ответов: 2

Здравствуйте уважаемые эксперты! Появилась необходимость обновить данные одной базы на основании данных другой. Как написать запрос в Query Analyzer там то выбираетсся только одна база... Мне говорили что запросы можно сторить даже по разным серверам, но как - то я тогда не придал этому значения... Microsoft SQL Server 2000. Заранее спасибо.

Состояние: Консультация закрыта

Ответ # 223206 от Megaloman (Академик)

Здравствуйте, PaTiFoN!
Имя базы указывается через две точки перед именем таблицы.
Например:
База..Таблица Или База..Таблица.Поле1, База..Таблица.Поле2 ...
Кажется, делал и выборку от разных серверов, но сейчас не на чем проверить.


Консультировал: Megaloman (Академик)
Дата отправки: 12.05.2008, 18:36

Рейтинг ответа:

0

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

Ответ # 223209 от Филатов Евгений Геннадьевич

Здравствуйте, PaTiFoN!

Полная спецификация для любого объекта базы данных определяется четырьмя идентификаторами : именем сервера, именем базы данных, именем владельца и именем объекта. Идентификаторы отделяются друг от друга точками, например
ServerBase.Sklad.dbo.Ostatok
В конце можно еще после точки указать имя столбца для выборки из таблицы, например
ServerBase.Sklad.dbo.Ostatok.Summa
По-умолчанию берутся текущие сервер, база и пользователь. Т.е. если уже произошло подключение к базе ( как в Query Analyzer ) , то вполне достаточно указать имя таблицs в текущей базе данных, например
Select * from Ostatok
в противном случае нужно указывать и другие недостающие данные , например если таблица находится на этом же сервере и у текущего пользователя есть права доступа к базе, то достаточно указать имя базы :
Select * from Zal..Ostatok

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

Желательно в Roles рабочей базы создать новую группу, например Rabota. В свойствах доступа настроить для пользователей этой группы разрешения на чтение, модификацию и выполнение каждой таблицы, вида и встроенных процедур.
Создать нового глобального пользователя, например User1 ( с ограниченными правами - ServerRoles пустые, в DatabaseAccess отметить эту базу и в нижней части отметить, что пользователь входит в группу Rabota ) .
Тогда при запуске программы пользователь будет вводить свои данные ( имя пользователя и пароль ) , под которыми производится подключение к базе.

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

В примере приведен строка запроса из встроенной процедуры текущей базы данных, в которой в системной базе Master производится поиск мак-адреса сетевой карты ( переменная @net ) , с которой пользователь подключился к рабочей базе данных под своим именем ( переменная @user ) . Если такого подключенного пользователя нет, то возвращается значение Null .

Приложение:


Консультировал: Филатов Евгений Геннадьевич
Дата отправки: 12.05.2008, 19:28

Рейтинг ответа:

0

[подробно]

Сообщение
модераторам

Отправлять сообщения
модераторам могут
только участники портала.
ВОЙТИ НА ПОРТАЛ »
регистрация »

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

Яндекс Rambler's Top100

главная страница | поддержка | задать вопрос

Время генерирования страницы: 0.13831 сек.

© 2001-2017, Портал RFPRO.RU, Россия
Авторское право: ООО "Мастер-Эксперт Про"
Калашников О.А.  |  Гладенюк А.Г.
Версия системы: 7.41 от 25.02.2017
Бесплатные консультации онлайн