gifts2017

Шпаргалка по SQL

Опубликовал Александр Блинов (alexandr.blinov) в раздел Администрирование - Системное

Не знаете язык запросов SQL, а надо быстро слепить что-нибудь простенькое?
Тогда мы идем к вам ))

Шпаргалка по SQL

Предназначена для коллег, плохо знающих язык запросов SQL (как я). Уже давно веду файл, в котором собираю примеры запросов на разные случаи жизни. 
Все запросы создавались и работают в MS SQL. 

Соединение нескольких таблиц, выборка конкретных полей

SELECT ОстаткиНоменклатуры.Код, ОстаткиНоменклатуры.Наименование, Таблица.Поле3, Таблица2.Поле4
  FROM [БазаДанных].[dbo].[Таблица1] as Таблица1
  left join  
  [БазаДанных].[dbo].[Таблица2] as Таблица2
  on Таблица1.Поле1 = Таблица2.Поле3

Показать 1000 записей, где длина строки, склеенной из нескольких полей, больше 36 символов

SELECT TOP 1000 [Фамилия] + [Имя] + [Отчество] as FIO,len([Фамилия] + [Имя] + [Отчество]) as LENGHT,*
  FROM [БазаДанных].[dbo].[Таблица]
  where LEN([Фамилия] + [Имя] + [Отчество]) > 36

Найти максимальную длину строки, которая будет состоять из нескольких столбцов

SELECT MAX(LEN([Фамилия] + [Имя] + [Отчество])) FROM [БазаДанных].[dbo].[Таблица]

Получить количество записей во всех таблицах базы данных

SELECT
    o.Name,
    i.rows
FROM sysobjects o
INNER JOIN sysindexes i
ON (o.id = i.id)
WHERE o.xtype = 'u'
AND i.indid < 2
ORDER BY o.name

Получить размер всех баз на сервере баз данных (сортировка по размеру журнала транзакций)

select 
db_name(dbid) as DataBases, 
sum(size) * 8 / 1024 / 1024 as SizeGB,
sum(case when f.groupid = 0 then 0 else size end) * 8 / 1024 / 1024 as DataSizeGB,
sum(case when f.groupid != 0 then 0 else size end) * 8 / 1024 / 1024 as LogSizeGB
from master.sys.sysaltfiles as f
group by db_name(dbid)
order by LogSizeGB desc

Регламентные операции с базами MS SQL Server 

* реиндексация базы (выбрать базу) *
* блокирует работу с базой, поэтому надо выбирать технологические перерывы
sp_msforeachtable N'DBCC dbreindex("?")'


* дефрагментация индексов
* если сделана реиндексация, то дефрагментация индексов не нужна
* если нельзя делать реиндексацию, то делать хотя бы дефрагментацию
sp_msforeachtable N'DBCC INDEXDEFRAG (<имя базы данных>, ''?'')'


* обновление статистики SQL Server (для правильного выбора плана запроса 
* выбрать базу!
exec sp_msforeachtable N'UPDATE STATISTICS ? WITH FULLSCAN'


* очистка процедурного кэша (кэша планов) 
* выбрать базу!
* сразу после обновления статистики
dbcc freeproccache

 

Если есть хотя бы минимальный интерес - продолжу. 

См. также

Подписаться Добавить вознаграждение
Комментарии
1. С К (kraynev-navi) 03.09.15 14:32
Если есть хотя бы минимальный интерес - продолжу.

Why not?!
2. Иван Петров (dgolovanov) 03.09.15 15:11
Мне в SQL надо создать временную таблицу с данными из 1С. Как это можно сделать, кроме генерации кода запроса с указанием текстом данных из 1С и выполнения его в SQL? Спасибо.
3. Павел И. (3.14159) 03.09.15 15:35
не увидел DROP DATABASE
ElektronHM; Aleksey.Bochkov; suggestive; fvadim; +4 Ответить
4. Михаил Гусев (Идальго) 03.09.15 22:03
Не поймите не правильно, но разве какой-нибудь справочник по SQL (даже вот хотя бы for dummies) не будет более удобен и систематизирован чем описание синтаксиса в статьях на ИС?
xzorkiix; tigra378; cleaner_it; +3 Ответить 1
5. Danil (Danila-Master) 04.09.15 08:16
(2) dgolovanov,
Можно использовать WITH
Пример:
--Создание временной таблицы
WITH TimeTable([Поле1], [Поле2]) AS (SEL ECT [Поле1], [Поле2] FROM [БазаДанных].[dbo].[Таблица])

-- Выборка из временной таблицы
SELECT TT.Поле1, TT.Поле2 FR OM TimeTable AS TT

Как то так.
dgolovanov; +1 Ответить
6. Александр Блинов (alexandr.blinov) 04.09.15 12:28
(2) dgolovanov,
данные в 1С могут быть разбросаны по разным таблицам. Получать, фильтровать и сводить их может оказаться нетривиальной задачей. Я бы делал запросом.

(4) Идальго,
на текущий момент данная статья в закладках у 14 человек (плюс исходная шпаргалка, которую я использую). Эти 15 человек, очевидно, ответили на Ваш вопрос отрицательно.
7. Иван Петров (dgolovanov) 04.09.15 17:03
(6) alexandr.blinov, а если данные хранятся в ТЗ?
8. Андрей Щеглов (Andrefan) 09.09.15 09:37
Плюсую. Я ЗА идею. Буду ждать продолжения
9. ediks (ediks) 09.09.15 15:28
Кому-то удобно пользоваться шпаргалкой, кому-то статьей. Каждому свое.
Сам предпочитаю пользоваться W3Schools.
10. EREK Merek (Yers) 11.09.15 18:48
Поддерживаю, полезная информация в работе.