Бесплатный вебинар
«как найти любимую работу»
Подарки на 150 000 ₽ за участие
Живой эфир
Записи не будет!
00:00:00:00
дн.ч.мин.сек.

Импорт больших .sql файлов в SQL Server Management Studio

Быстрый ответ

Для импорта большого файла с расширением .sql в MS SQL воспользуйтесь следующей командой в командной строке или PowerShell:

sqlcmd -S ваш_сервер_SQL -d ваша_целевая_база_данных -i C:\местоположение_вашего_большого.sql

В этой команде "вашсервер_SQL" означает название вашего SQL сервера, "вашацелеваябазаданных" – это имя целевой БД, а "C:местоположениевашегобольшого.sql" – это полный путь к .sql файлу. Убедитесь, что утилита sqlcmd установлена и доступна для вызова из командной строки.

Если представится необходимость увеличить производительность импорта, измените размер пакета, применив следующую команду:

sqlcmd -S ваш_сервер_SQL -d ваша_целевая_база_данных -i ваш_большой_файл.sql -a 32767

При использовании именованных экземпляров SQL сервера команда принимает следующий вид:

sqlcmd -S сервер\экземпляр -i ваш_большой_файл.sql

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

Кинга Идем в IT: пошаговый план для смены профессии

Эффективные альтернативные инструменты

BigSqlRunner

Если размер файла превышает 300 МБ, рекомендуется воспользоваться утилитой BigSqlRunner, созданной специально для работы с большими файлами.

Подробнее об этом расскажет наш спикер на видео
skypro youtube speaker

Консольное приложение

Ещё одним возможным решением является создание консольного приложения, которое с помощью StreamReader в C#, сможет построчно считывать и выполнить SQL-команды:

csharp
Скопировать код
using (var reader = new StreamReader("ваш_большой_файл.sql"))
{
    string sqlCommand;
    while ((sqlCommand = reader.ReadLine()) != null)
    {
        db.Database.ExecuteSqlCommand(sqlCommand);
        // Ммм, прямо чувствуешь аромат SQL! Бесподобно! 💾🍽️
    }
}

Данный подход позволит обработать большой файл без его полной загрузки в память, что невыполнимо в SSMS.

Визуализация

Представьте себе, что вы — повар, который готовится создать великолепное кулинарное произведение (📜). Ваш .sql файл — это именно этот рецепт:

Markdown
Скопировать код
📜 = Обширный сценарий SQL (Слишком большой для одноэтапной реализации!)

Ваша задача — поделить его на более мелкие, удобоваримые карточки с рецептами:

Markdown
Скопировать код
📜🔪➡️ [🍽️, 🍽️, 🍽️] (Разделяем гигантский рецепт на управляемые порции!)

Каждую такую карточку можно сравнить с блоком импорта, который ваша SQL-среда сможет легко обработать.

Markdown
Скопировать код
**SQL Server Management Studio (SSMS):** Партии выполняются последовательно через графический интерфейс, как инструкции рецепта 🍳.
**sqlcmd:** Используйте этот командный инструмент для автоматизации обработки партий, как при использовании автоматизированной кухонной техники 🤖.
**PowerShell:** Этот инструмент подходит для систематизации и многофункциональной обработки партий 🍲.

В итоге получится изысканная база данных, приготовленная по вашему обширному рецепту, но без хаоса на кухне! 🍽️✨

Markdown
Скопировать код
Огромный файл SQL 📜 ➡️ Передозированные блоки [🍽️, 🍽️, 🍽️] ➡️ Высококачественные данные 🍽️✨

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

Основные особенности sqlcmd

Предотвращение ошибок и зависаний SSMS

sqlcmd поможет избежать ошибок или зависаний, которые могут возникнуть при попытке загрузить файл полностью в SSMS.

Конфигурация для повышения производительности

sqlcmd предлагает различные параметры и ключи для ускорения процесса импорта. Так, опция -a позволяет изменить размер пакета, а -o перенаправляет вывод в файл для анализа.

Скриптование и автоматизация

Использование скриптов PowerShell или пакетных скриптов для управления sqlcmd позволяет автоматизировать процесс импорта. Это особенно актуально для регулярных задач или постоянных обновлений БД.

Ключевые моменты при выполнении большого импорта

Мониторинг и оптимизация производительности

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

Тактическая работа с транзакциями

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

Реализация контроля ошибок

Необходимы надежные механизмы обработки ошибок. Логирование ошибок будет экономить ваше время и нервы при отлавливании проблем, особенно при работе с большими файлами.

Полезные материалы

  1. SQL Server Management Studio (SSMS)Официальная документация SSMS, основного средства работы с SQL Server.
  2. SqlBulkCopy Class — Данные о классе SqlBulkCopy, предназначенном для эффективной загрузки больших объемов данных в БД.
  3. Утилита sqlcmd — Подробности по использованию утилиты sqlcmd для выполнения SQL-команд и взаимодействия с базами данных.
  4. Использование подсказок для тестирования индексов SQL Server — Как лучше всего использовать подсказки для тестирования и оптимизации индексов для улучшения работы с SQL Server.
Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей
Какой утилитой рекомендуется использовать для импорта .sql файла размером более 300 МБ?
1 / 5