<
  • Главная
Статьи

Як перевірити існування тимчасової таблиці

Самородов Федір Анатолійович : Як перевірити існування тимчасової таблиці

SQL Server вміє працювати c тимчасовими таблицями. Назви у таких таблиць починаються з одного або з двох решіток (#). Тимчасові таблиці, очевидно, придумані для того, щоб зберігати в них дані тимчасово. Наприклад, для збереження проміжних результатів будь-яких обчислень. Або для передачі якихось даних від одного процесу іншому.

Іноді потрібно перевірити, чи була вже створена певна тимчасова таблиця чи ні. Як це правильно зробити?

Якщо мова йде про глобальну тимчасової таблиці, то перевірити її наявність можна традиційним способом - заглянувши в список таблиць. Тільки не забудьте зробити поправку на те, що всі тимчасові таблиці - і глобальні і локальні - створюються не в поточної користувальницької базі даних, а в системній базі TempDB.

Подивіться на приклад. Один процес створив глобальну тимчасову таблицю. Тепер цей і всі інші процеси можуть звертатися до неї, як до звичайної таблиці. В тому числі, вони побачать її в системних каталогах sys.Tables і Information_Schema.Tables.

Годиться. Однак, такий механізм перевірки не спрацює, якщо мова йде про локальні тимчасових таблицях. Адже такі таблиці створюються індивідуально для кожного сеансу, і в різних сеансах можуть виявитися таблиці з однаковими назвами. Щоб не було конфлікту імен, сервер перейменовує локальні таблиці, створюючи їх у TempDB.

Ось я створюю в двох сенсах локальні тимчасові таблиці з однаковими назвами. У кожному сеансі сервер відрізняє свою таблицю від чужих, але в системних каталогах їх видно все відразу:

Якщо подивитися уважніше, то можна помітити, що до назв таблиць сервер дописує унікальне закінчення, за яким він і визначає чия це таблиця:

Якщо подивитися уважніше, то можна помітити, що до назв таблиць сервер дописує унікальне закінчення, за яким він і визначає чия це таблиця:

Возитися з цими закінченнями в SQL-коді не хотілося б. І не потрібно. Тому що у нас є функція Object_ID, яка автоматично вибирає потрібну таблицю:

Тому що у нас є функція Object_ID, яка автоматично вибирає потрібну таблицю:

Якщо об'єкт із заданим назв існує, то функція Object_ID поверне його ідентифікатор, а якщо немає - NULL. Таким чином ми зможемо зручно і надійно перевірити наявність навіть такого незвичайного об'єкту, як локальна тимчасова таблиця:

Таким чином ми зможемо зручно і надійно перевірити наявність навіть такого незвичайного об'єкту, як локальна тимчасова таблиця:

У цій функції є необов'язковий другий параметр, який можна використовувати для вказівки конкретного типу об'єкта. "U" означає, що ми шукаємо саме таблицю.

Детальніше про це Ви зможете дізнатися на курсах SQL Server

Як це правильно зробити?


Новости
    Без плагина
    На сайте WordPress имеется файл, именуемый как .htaccess. Многие пользователи не предают ему особого внимания и не используют все его возможности. На самом деле файл .htaccess – это дополнительные конфигурации

    Плагин подписки wordpress
    Очень трудно найти один плагин подписки wordpress , который объединил бы в себе все виды подписок, которые так необходимы сайту. Именно поэтому я решил сделать подборку лучших плагинов, которые смогут

    Слайд-шоу с помощью плагина для WordPress UnPointZero Slider
    Плагин для cms WordPress UnPointZero Slider – новостной слайдер. Он отражает в форме слайд-шоу изображения со ссылками на ваши статьи и краткие выдержки оттуда. Его можно установить и на новостной сайт,

    Плагины для Wordpress
    С помощью этого плагина вы легко сможете интегрировать Google диск на ваш WordPress сайт или блог . Gravity Forms — лучший плагин для создания форм на WordPress, от самых простых (например, форма

    Подписки плагином JetPack: размещение и редакция формы подписки
    Вступление Здравствуйте! В этой статье я покажу, как использовать плагин JetPack для создания пользовательской формы подписки и как эту формы подписки плагином JetPack добавлять в статьи сайта, а при

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

    Возможности Jetpack плагина
    Вступление Возможности Jetpack плагина это более 30 функциональных модуля плагина, делающего его универсальным плагином WordPress, заменяющего аналогичные сторонние плагины. Jetpack один заменяет десятки

    Резервное копирование WordPress сайта без плагинов
    Вступление Резервное копирование WordPress это второе, что нужно научиться делать после установки WordPress. Можно сколько угодно говорить о безопасности сайта и его защите, но лучшего варианта защиты

    Плагины на приват для Майнкрафт ПЕ
    > > Плагины на приват для Майнкрафт ПЕ Порой всем нам хочется попробовать себя в роли администратора сервера и испытать эту ответственность, но, к сожалению, вы не всегда все знаете о создании

    Плагин WordPress Database Backup. Архивация базы данных блога на WordPress
    Привет друзья! Сегодня на очереди еще один простой, НО, необходимый и полезный плагин — плагин WordPress Database Backup , который с легкостью и самостоятельно произведет процесс, который научно называется:

  • Виртуальный хостинг

    Виртуальный хостинг. Возможности сервера распределяются в равной мере между всеми... 
    Читать полностью

  • Редизайн сайта

    Редизайн сайта – это полное либо частичное обновление дизайна существующего сайта.... 
    Читать полностью

  • Консалтинг, услуги контент-менеджера

    Сопровождение любых интернет ресурсов;- Знание HTML и CSS- Поиск и обновление контента;-... 
    Читать полностью

  • Трафик из соцсетей

    Сравнительно дешевый способ по сравнению с поисковым и контекстным видами раскрутки... 
    Читать полностью

  • Поисковая оптимизация

    Поисковая оптимизация (англ. search engine optimization, SEO) — поднятие позиций сайта в результатах... 
    Читать полностью