Как из sql сделать db
Перейти к содержимому

Как из sql сделать db

  • автор:

Как создать файл с расширением .db из файла с расширением .sql?

Добрый день!
Есть бэкап сайта в формате .sql, нужно переконвертировать файл в формат .db для работы в SID (SQL Interactive Demonstrator). Подскажите, пожалуйста, какими средствами это можно сделать?

  • Вопрос задан более трёх лет назад
  • 5340 просмотров

Комментировать
Решения вопроса 1

martin74ua

Руслан Федосеев @martin74ua Куратор тега MySQL
Linux administrator
формат db — это очень расплывчато.
С какой базой данных работает ваш SID ?
Ответ написан более трёх лет назад
Нравится 2 12 комментариев
Константин @KoNnY Автор вопроса
DBENGINE sqlite3

martin74ua

Руслан Федосеев @martin74ua Куратор тега MySQL
ну вот вам и ответ — создать нужную вам базу в sqlite.
Константин @KoNnY Автор вопроса
Руслан Федосеев: К синтаксису я привел таблицы, но как сохранить в формате .db — нет.

martin74ua

Руслан Федосеев @martin74ua Куратор тега MySQL
издеваетесь?
developer.alexanderklimov.ru/android/sqlite/practi.

martin74ua

Руслан Федосеев @martin74ua Куратор тега MySQL
sqlite3 data.db < data.sql Константин @KoNnY Автор вопроса

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

martin74ua

Руслан Федосеев @martin74ua Куратор тега MySQL

[martin@martin sqlite]$ ll итого 4 -rw-rw-r-- 1 martin martin 247 Окт 17 23:32 test.sql [martin@martin sqlite]$ sqlite3 test.db < test.sql [martin@martin sqlite]$ ll итого 8 -rw-r--r-- 1 martin martin 2048 Окт 17 23:33 test.db -rw-rw-r-- 1 martin martin 247 Окт 17 23:32 test.sql [martin@martin sqlite]$ cat test.sql create table test (id integer primary key, value text); insert into test (id, value) values(1, 'barsik'); insert into test (id, value) values (2, 'murzik'); insert into test (value) values('vaska'); insert into test (value) values ('ryzhik'); [martin@martin sqlite]$

Вот, специально попробовал.

Константин @KoNnY Автор вопроса

Спасибо за помощь. Мануалы сбили этой командой data.db < data.sql
Все оказалось проще.
1) Запускаешь sqlite3.exe (Windows
2) Открываешь файл командой sqlite3 > .read data.sql
3) Сохраняешь командой sqlite3 > .save data.db
4) Закрываешь программу sqlite3 > .exit

martin74ua

Руслан Федосеев @martin74ua Куратор тега MySQL
это проще говорите? ну ну.
перенаправление ввода одинаково работает и в винде и в линуксе
Константин @KoNnY Автор вопроса

Руслан Федосеев: ну без 1 пункта вообще ничго не сделаешь, а 4 можно не выполнять. 2 команды так плохо? Не знаю, но в любом случае, команда sqlite3 > data.db < data.sql не сработала

martin74ua

Руслан Федосеев @martin74ua Куратор тега MySQL

а, у вас такие проблемы 😉
1. Запускаем cmd
2. cd c:/users/admin/project/ (или где там у вас sql файл лежит)
теперь внимательно, вся магия в следующей строке
3. sqlite3.exe data.db < data.sql
4. все, в каталоге появился файл data.db

Константин @KoNnY Автор вопроса
Команд ничуть не меньше, поэтому дело вкуса.
Ответы на вопрос 1

Nipheris

Давайте условимся говорить о формате sqlite, раз уже выяснили в комментариях.
Итак, качайте command-line shell отсюда: sqlite.org/download.html
Запускаете его, указав в качестве параметра имя нового файла БД, например sqlite3 demo.db (пример тут).
Дальше все инструкции на SQL поочередно вставляете и выполняете. Все будет писаться в указанный вами файл.

Если очень хочется GUI, то SQLiteStudio - то, что я обычно рекомендую. Там также нужно будет подключить новую БД, и выполнить в ней все ваши SQL конструкции.

Впрочем, Руслан Федосеев привел куда более удобный вариант, чем по одному запросу кидать))

СОЗДАТЬ БАЗУ ДАННЫХ

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

Выбор продукта

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

* SQL Server *

SQL Server

Обзор

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

Синтаксис

Создается база данных .

Дополнительные сведения о соглашениях о синтаксисе см. в статье Соглашения о синтаксисе в Transact-SQL.

CREATE DATABASE database_name [ CONTAINMENT = < NONE | PARTIAL >] [ ON [ PRIMARY ] [ . n ] [ , [ . n ] ] [ LOG ON [ . n ] ] ] [ COLLATE collation_name ] [ WITH [. n ] ] [;] ::= < FILESTREAM ( [. n ] ) | DEFAULT_FULLTEXT_LANGUAGE = < lcid | language_name | language_alias >| DEFAULT_LANGUAGE = < lcid | language_name | language_alias >| NESTED_TRIGGERS = < OFF | ON >| TRANSFORM_NOISE_WORDS = < OFF | ON >| TWO_DIGIT_YEAR_CUTOFF = | DB_CHAINING < OFF | ON >| TRUSTWORTHY < OFF | ON >| PERSISTENT_LOG_BUFFER=ON ( DIRECTORY_NAME='' ) | LEDGER = > ::= < NON_TRANSACTED_ACCESS = < OFF | READ_ONLY | FULL >| DIRECTORY_NAME = 'directory_name' > ::= < ( NAME = logical_file_name , FILENAME = < 'os_file_name' | 'filestream_path' >[ , SIZE = size [ KB | MB | GB | TB ] ] [ , MAXSIZE = < max_size [ KB | MB | GB | TB ] | UNLIMITED >] [ , FILEGROWTH = growth_increment [ KB | MB | GB | TB | % ] ] ) > ::= < FILEGROUP filegroup name [ [ CONTAINS FILESTREAM ] [ DEFAULT ] | CONTAINS MEMORY_OPTIMIZED_DATA ] [ . n ] > 

Присоединение базы данных

CREATE DATABASE database_name ON [ . n ] FOR < < ATTACH [ WITH [ , . n ] ] > | ATTACH_REBUILD_LOG > [;] ::= < | RESTRICTED_USER | FILESTREAM ( DIRECTORY_NAME = < 'directory_name' | NULL >) > ::=

Создание моментального снимка базы данных

CREATE DATABASE database_snapshot_name ON ( NAME = logical_file_name, FILENAME = 'os_file_name' ) [ . n ] AS SNAPSHOT OF [;] 

Аргументы

database_name

Имя новой базы данных. Имена баз данных должны быть уникальны внутри экземпляра SQL Server и соответствовать правилам для идентификаторов.

Аргумент database_name может иметь максимальную длину 128 символов, если для файла журнала не указано логическое имя. Если логическое имя файла не указано, SQL Server формирует для журнала имена logical_file_name и os_file_name путем добавления суффикса к database_name. Это ограничивает длину аргумента database_name 123 символами, чтобы формируемое логическое имя файла было не длиннее 128 символов.

Если имя файла данных не указано, SQL Server использует database_name как logical_file_name и os_file_name. Путь по умолчанию берется из реестра. Путь по умолчанию можно изменить на вкладке Свойства сервера (страница "Параметры базы данных") в Management Studio. Изменение пути по умолчанию требует перезапуска SQL Server.

CONTAINMENT =

Область применения: SQL Server 2012 (11.x) и более поздних версий

Указывает состояние включения базы данных. NONE = неавтономная база данных. PARTIAL = частично автономная база данных.

DNS

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

ОСНОВНОЙ

Указывает, что связанный список определяет первичный файл. Первый файл, указанный в элементе в первичной файловой группе, становится первичным файлом. В базе данных может быть только один первичный файл. Дополнительные сведения см. в статье Файлы и группы файлов базы данных.

Если параметр PRIMARY не указан, то первый файл списка в инструкции CREATE DATABASE становится первичным файлом.

LOG ON

Указывает, что дисковые файлы, используемые для хранения журнала базы данных, то есть файлы журналов, определяются явно. За параметром LOG ON следует разделенный запятыми список элементов , которые определяют файлы журналов. Если параметр LOG ON не указан, автоматически создается один файл журнала, размер которого определяется большей из следующих двух величин: 512 КБ или 25 процентов от суммы размеров всех файлов данных в базе данных. Этот файл помещается в местоположение для журнала по умолчанию. См. дополнительные сведения об этом расположении.

Параметр LOG ON не может указываться для моментального снимка базы данных.

COLLATE collation_name

Задает параметры сортировки по умолчанию для базы данных. Именем параметров сортировки может быть либо имя параметров сортировки Windows, либо имя параметров сортировки SQL. Если параметр не указан, базе данных назначаются параметры сортировки по умолчанию для экземпляра SQL Server. Имя параметров сортировки не может указываться для моментального снимка базы данных.

Имя параметров сортировки не может указываться с предложениями FOR ATTACH и FOR ATTACH_REBUILD_LOG. Дополнительные сведения о способах изменения параметров сортировки подсоединенной базы данных см. на веб-сайте корпорации Майкрософт.

Список имен параметров сортировки Windows и SQL см. в статье Параметры сортировки.

Сортировка в автономных базах данных отличается от неавтономных баз данных. Дополнительные сведения см. в разделе Параметры сортировки автономной базы данных.

инструкции WITH

Область применения: SQL Server 2012 (11.x) и более поздних версий.

Указывает уровень нетранзакционного доступа FILESTREAM к базе данных.

значение Описание
ВЫКЛ. Нетранзакционный доступ отключен.
READONLY Данные FILESTREAM в этой базе данных могут быть считаны нетранзакционными процессами.
FULL Полный нетранзакционный доступ к FILESTREAM FileTable включен.

Область применения: SQL Server 2012 (11.x) и более поздних версий

Имя каталога, совместимое с Windows. Это имя должно быть уникальным среди всех Database_Directory имен в экземпляре SQL Server. Проверка уникальности не учитывает регистр символов независимо от параметров сортировки SQL Server. Этот параметр необходимо назначить до создания FileTable в этой базе данных.

Следующие параметры разрешаются, только если параметр CONTAINMENT установлен в состояние PARTIAL. Если параметр CONTAINMENT установлен в состояние NONE, возникнут ошибки.

DEFAULT_FULLTEXT_LANGUAGE = | языка |

Область применения: SQL Server 2012 (11.x) и более поздних версий

DEFAULT_LANGUAGE = | языка |

Область применения: SQL Server 2012 (11.x) и более поздних версий

NESTED_TRIGGERS =

Область применения: SQL Server 2012 (11.x) и более поздних версий

TRANSFORM_NOISE_WORDS =

Область применения: SQL Server 2012 (11.x) и более поздних версий

Полный описание этого параметра см . в разделе "Параметр конфигурации сервера преобразования" для преобразования слов" сервера.

TWO_DIGIT_YEAR_CUTOFF = < 2049 | >

Четыре цифры, обозначающие год. Значение по умолчанию — 2049. Полное описание этого параметра см. в статье Настройка параметра конфигурации сервера two digit year cutoff.

DB_CHAINING

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

Если задано значение OFF, то база данных не может участвовать в межбазовых цепочках владения. Значение по умолчанию — OFF.

Экземпляр SQL Server распознает этот параметр, если параметр сервера цепочки владения между базами данных имеет значение 0 (OFF). Если параметр cross db ownership chaining имеет значение 1 (ON), то все пользовательские базы данных могут участвовать в межбазовых цепочках владения, вне зависимости от значения этого параметра. Этот параметр задается с помощью процедуры sp_configure.

Для задания этого параметра необходимо членство в предопределенной роли сервера sysadmin. Параметр DB_CHAINING нельзя установить для системных баз данных: master , model , tempdb .

TRUSTWORTHY

Если задано значение ON, то модули базы данных (например, представления, определяемые пользователем функции и хранимые процедуры), в которых используется контекст олицетворения, могут обращаться к ресурсам, расположенным за пределами базы данных.

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

Параметр TRUSTWORTHY устанавливается в значение OFF при каждом присоединении базы данных.

По умолчанию для всех системных баз данных, кроме msdb , для параметра TRUSTWORTHY задано значение OFF. Это значение не может быть изменено для баз данных model и tempdb . Рекомендуется никогда не задавать значение ON для параметра TRUSTWORTHY базы данных master .

PERSISTENT_LOG_BUFFER=ON ( DIRECTORY_NAME='' )

Если указан этот параметр, буфер журнала транзакций создается в томе на дисковом устройстве с поддержкой памяти класса хранилища (энергонезависимое хранилище NVDIMM-N), которое также называется постоянным буфером журнала. Дополнительные сведения см. в записи блога о сокращении задержки фиксации транзакций с помощью памяти класса хранилища. Область применения: SQL Server 2017 (14.x) и более поздних версий.

LEDGER =

Если задано значение ON , создается база данных реестра, в которой обеспечивается целостность всех пользовательских данных. В базе данных реестра можно создавать только таблицы реестра. Значение по умолчанию — OFF . Значение параметра LEDGER нельзя изменить после создания базы данных. Дополнительные сведения см. в разделе Настройка базы данных реестра.

CREATE DATABASE . FOR ATTACH [ WITH < attach_database_option >]

Указывает, что база данных создана путем присоединения существующего набора файлов операционной системы. Должен существовать элемент , который указывает первичный файл. Кроме этого элемента, необходимы только элементы , предназначенные для файлов, пути которых отличны от путей, существовавших при создании или последнем подключении базы данных. Для таких файлов должен быть определен элемент .

Для параметра FOR ATTACH необходимо выполнение следующих условий.

  • Должны быть доступны все файлы данных (MDF и NDF).
  • Если существует несколько файлов журналов, все они должны быть доступны.

Если база данных, доступная для чтения и записи, располагает единственным файлом журнала, который недоступен в текущий момент, а также если база данных была закрыта в отсутствие пользователей или открытых транзакций перед операцией присоединения, то параметр FOR ATTACH автоматически перестраивает файл журнала и обновляет первичный файл. Однако журнал невозможно перестроить в базе данных, доступной только для чтения, так как нельзя обновить первичный файл. Поэтому, если присоединяется база данных только для чтения, журнал которой недоступен, необходимо указать в предложении FOR ATTACH файлы журнала или файлы.

База данных, созданная в более поздней версии SQL Server, не может быть подключена в ранних версиях.

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

При подключении базы данных, содержащей параметр FILESTREAM "Directory name", к экземпляру SQL Server он должен проверить уникальность имени Database_Directory. Если это не так, операция присоединения завершается с ошибкой FILESTREAM Database_Directory name is not unique in this SQL Server instance . Чтобы избежать этой ошибки, необходимо передать этой операции необязательный параметр directory_name.

Параметр FOR ATTACH не может указываться для моментального снимка базы данных.

В предложении FOR ATTACH может указываться параметр RESTRICTED_USER. Предложение RESTRICTED_USER позволяет подключаться к базе данных только членам предопределенных ролей базы данных db_owner и dbcreator и предопределенной роли сервера sysadmin, количество соединений при этом не ограничивается. Пользователям, не соответствующим этому условию, подключение не разрешается.

Если в базе данных используется Service Broker, в предложении FOR ATTACH следует использовать WITH >service_broker_option

Управляет доставкой сообщений Service Broker и идентификатором Service Broker для базы данных. Параметры Service Broker можно указывать только при использовании предложения FOR ATTACH.

ENABLE_BROKER

Указывает, что компонент Service Broker включен для указанной базы данных. Это означает, что происходит запуск доставки сообщений и параметру is_broker_enabled задается значение true в представлении каталога sys.databases . Существующий идентификатор компонента Service Broker сохраняется в базе данных.

NEW_BROKER

Создает новое значение service_broker_guid в sys.databases и в восстановленной базе данных. Завершает все конечные точки диалога с очисткой. Посредник включен, но сообщения удаленным конечным точкам диалога не отправляются. Любой маршрут, ссылающийся на старый идентификатор Service Broker, должен быть повторно создан с новым идентификатором.

ERROR_BROKER_CONVERSATIONS

Завершает все диалоги, находящиеся в состоянии ошибки, которые были присоединены к базе данных или восстановлены. Посредник отключается до завершения этой операции, после чего вновь включается. Существующий идентификатор компонента Service Broker сохраняется в базе данных.

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

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

Подключение работает с форматом хранения vardecimal, но ядро СУБД SQL Server нужно обновить по меньшей мере до версии SQL Server 2005 (9.x) SP2. Подключение баз данных, использующих формат хранения vardecimal более ранних версий SQL Server, невозможно. Дополнительные сведения о формате хранения vardecimal см. в разделе Сжатие данных.

При первом присоединении базы данных к новому экземпляру SQL Server или ее восстановлении копия главного ключа базы данных (зашифрованная главным ключом службы) еще не хранится на сервере. Необходимо расшифровать главный ключ базы данных с помощью инструкции OPEN MASTER KEY. Как только главный ключ базы данных будет расшифрован, появится возможность разрешить автоматическую расшифровку в будущем с помощью инструкции ALTER MASTER KEY REGENERATE, чтобы оставить на сервере копию главного ключа базы данных, зашифрованного с помощью главного ключа службы. После обновления базы данных с переходом от более ранней версии главный ключ базы данных должен быть создан повторно для использования нового алгоритма шифрования AES. См. дополнительные сведения о повторном создании главного ключа базы данных. Время, необходимое для повторного создания главного ключа базы данных с обновлением до алгоритма шифрования AES, зависит от числа объектов, защищаемых главным ключом базы данных. Повторное создание главного ключа базы данных с обновлением до алгоритма шифрования AES необходимо произвести только один раз. Это никак не повлияет на последующие операции повторного создания, выполняемые в соответствии со стратегией смены ключей. См. дополнительные сведения об обновлении базы данных с помощью присоединения.

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

Параметры TRUSTWORTHY и DB_CHAINING не оказывают эффекта при присоединении базы данных.

FOR ATTACH_REBUILD_LOG

Указывает, что база данных создана путем присоединения существующего набора файлов операционной системы. Этот параметр применяется только в базах данных, доступных для чтения и записи. Должен существовать элемент , указывающий первичный файл. Если один или несколько файлов журналов транзакций отсутствуют, то файл журнала перестраивается. ATTACH_REBUILD_LOG автоматически создает новый 1-МБ файл журнала. Этот файл помещается в местоположение для журнала по умолчанию. См. дополнительные сведения об этом расположении.

Если файлы журналов доступны, ядро СУБД использует их, не перестраивая файлы журнала.

Для параметра FOR ATTACH_REBUILD_LOG необходимы следующие условия:

  • Чистое завершение работы базы данных.
  • Должны быть доступны все файлы данных (MDF и NDF).

Эта операция разрывает цепочку резервных копий журнала. Рекомендуется выполнить полное резервное копирование базы данных после завершения операции. Дополнительные сведения см. в описании BACKUP.

Как правило, параметр FOR ATTACH_REBUILD_LOG используется при копировании базы данных, доступной для чтения и записи и обладающей большим журналом, на другой сервер, где копия будет использоваться преимущественно или исключительно для операций чтения. Поэтому для журнала требуется меньше места, чем в случае исходной базы данных.

Параметр FOR ATTACH_REBUILD_LOG не может указываться для моментального снимка базы данных.

Управляет свойствами файла.

NAME logical_file_name

Задает логическое имя файла. Параметр NAME требуется при указании параметра FILENAME во всех случаях, кроме указания одного из предложений FOR ATTACH. Файловая группа FILESTREAM не может иметь имя PRIMARY.

Является логическим именем, используемым в SQL Server при ссылке на файл. Аргумент logical_file_name должен быть уникальным в базе данных и соответствовать правилам для идентификаторов. Имя может быть символом или константой Юникода, а также обычным идентификатором или идентификатором с разделителями.

FILENAME < 'os_file_name' | 'filestream_path' >

Задает имя файла в операционной системе (физическое имя).

'os_file_name'

Путь и имя файла, используемые операционной системой при создании файла. Файл должен находиться на одном из следующих устройств: на локальном сервере, где установлен SQL Server, в сети хранения данных [SAN] или в сети на основе iSCSI. Указанный путь должен существовать до выполнения инструкции CREATE DATABASE. Дополнительные сведения см. в разделе Файлы и файловые группы базы данных далее в этой статье.

Параметры SIZE, MAXSIZE и FILEGROWTH доступны, если путь к файлу указан в формате UNC.

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

Необработанные секции не поддерживаются в SQL Server 2014 и более поздних версиях.

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

'filestream_path'

Для файловой группы FILESTREAM параметр FILENAME указывает путь, где будут храниться данные FILESTREAM. Должен существовать путь вплоть до последнего каталога, но последний каталог существовать не должен. Например, если указан путь C:\MyFiles\MyFilestreamData , то каталог C:\MyFiles должен существовать до выполнения инструкции ALTER DATABASE, но папка MyFilestreamData не должна существовать.

Файловую группу и файл ( ) необходимо создавать в одной инструкции.

Свойства SIZE и FILEGROWTH к файловой группе FILESTREAM неприменимы.

SIZE size

Указывает размер файла.

Параметр SIZE не может указываться, если аргумент os_file_name задан как путь в формате UNC. Свойство SIZE к файловой группе FILESTREAM не применяется.

Задает начальный размер файла.

Если для первичного файла не задан аргумент size, ядро СУБД использует размер первичного файла, указанный в базе данных model . Размер базы данных model по умолчанию — 8 МБ (начиная с SQL Server 2016 (13.x)) или 1 МБ (для более ранних версий). Если указан вторичный файл данных или журнала, но для этого файла не указан аргумент size, ядро СУБД задает размер файла равным 8 МБ (начиная с SQL Server 2016 (13.x)) или 1 МБ (для более ранних версий). Размер, указанный для первичного файла, не должен быть меньше размера первичного файла базы данных model .

Можно использовать суффиксы килобайт (KB), мегабайт (MB), гигабайт (GB) и терабайт (TB). По умолчанию — MБ. Укажите целое число. Не включайте десятичную дробь. size — целочисленное значение. Для значений, превышающих 2 147 483 647, используйте более крупные единицы измерения.

MAXSIZE max_size

Задает максимальный размер, до которого может расти файл. Параметр MAXSIZE не может указываться, если аргумент os_file_name задан как путь в формате UNC.

Максимальный размер файла. Можно использовать суффиксы KB, MB, GB и TB. По умолчанию — MБ. Укажите целое число. Не включайте десятичную дробь. Если аргумент max_size не указан, файл будет увеличиваться до исчерпания свободного пространства на диске. max_size — целочисленное значение. Для значений, превышающих 2 147 483 647, используйте более крупные единицы измерения.

Указывает, что файл может расти вплоть до заполнения диска. В SQL Server файл журнала, указанный с неограниченным ростом, имеет максимальный размер 2 ТБ, а файл данных имеет максимальный размер 16 ТБ.

Ограничения размера отсутствуют, если этот параметр указан для контейнера FILESTREAM. Размер продолжает увеличиваться до полного заполнения диска.

FILEGROWTH growth_increment

Задает автоматический шаг роста файла. Значение параметра FILEGROWTH для файла не может превосходить значение параметра MAXSIZE. Параметр FILEGROWTH не может указываться, если аргумент os_file_name задан как путь в формате UNC. Свойство FILEGROWTH к файловой группе FILESTREAM не применяется.

Объем пространства, добавляемого в файл каждый раз, когда требуется новое пространство.

Значение может быть указано в килобайтах, мегабайтах, гигабайтах, терабайтах или процентах (%). Если указано число без суффикса MB, KB или %, то по умолчанию используется MB. Если размер указан в процентах (%), то шаг роста — это заданная часть в процентах от размера файла во время этого файла. Указанный размер округляется до ближайших 64 КБ, минимальное значение — 64 КБ.

Значение 0 указывает, что автоматическое приращение отключено и добавление пространства запрещено.

Если параметр FILEGROWTH не задан, доступны следующие значения по умолчанию.

Версия Значения по умолчанию
Начиная с SQL Server 2016 (13.x) Данные — 64 МБ. Файлы журналов — 64 МБ.
Начиная с SQL Server 2005 (9.x) Данные — 1 МБ. Файлы журналов — 10 %.
До SQL Server 2005 (9.x) Данные — 10 %. Файлы журналов — 10 %.

Управляет свойствами файловой группы. Файловая группа не может указываться для моментального снимка базы данных.

FILEGROUP filegroup_name

Логическое имя файловой группы.

Аргумент filegroup_name должен быть уникальным в базе данных и не может быть именем PRIMARY или PRIMARY_LOG, предоставленным системой. Имя может быть символом или константой Юникода, а также обычным идентификатором или идентификатором с разделителями. Имя должно соответствовать правилам для идентификаторов.

Указывает, что файловая группа хранит большие двоичные объекты (BLOB) FILESTREAM в файловой системе.

Задает именованную файловую группу как файловую группу по умолчанию в базе данных.

Область применения: SQL Server 2014 (12.x) и более поздних версий

Указывает, что файловая группа хранит данные memory_optimized в файловой системе. Дополнительные сведения см. в статье Обзор оптимизации в памяти и сценарии использования. В каждой базе данных может присутствовать только одна файловая группа MEMORY_OPTIMIZED_DATA. Примеры кода по созданию файловых групп для хранения оптимизированных для памяти данных см. в разделе Создание таблиц, оптимизированных для памяти, и хранимых процедур, скомпилированных в собственном коде.

database_snapshot_name

Имя нового моментального снимка базы данных. Имена моментальных снимков баз данных должны быть уникальны внутри экземпляра SQL Server и соответствовать правилам для идентификаторов. database_snapshot_name не может превышать 128 символов.

ON ( NAME =logical_file_name, FILENAME ='os_file_name') [ . n ]

При создании моментального снимка базы данных указывает список файлов в базе данных-источнике. Для работы моментального снимка все файлы данных должны задаваться отдельно. Однако не разрешается указывать файлы журналов для моментальных снимков базы данных. В моментальных снимках базы данных не поддерживаются файловые группы FILESTREAM. Если файл данных FILESTREAM задействован в предложении CREATE DATABASE ON, выполнение этой инструкции завершится сбоем и приведет к возникновению ошибки.

Описания параметров NAME и FILENAME и их значений см. в описаниях соответствующих значений .

При создании моментального снимка базы данных не разрешается применять другие параметры и ключевое слово PRIMARY.

AS SNAPSHOT OF source_database_name

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

До SQL Server 2019 исходная база данных для моментального снимка базы данных не может содержать файловую группу MEMORY_OPTIMIZED_DATA. Поддержка моментальных снимков базы данных в памяти была добавлена в SQL Server 2019.

Дополнительные сведения см. в описании моментальных снимков базы данных.

Замечания

Резервную копию базы данных master необходимо создавать каждый раз при создании, изменении или удалении пользовательской базы данных.

Инструкция CREATE DATABASE должна выполняться в режиме автоматической фиксации (режим управления транзакциями по умолчанию) и не разрешена в явной или неявной транзакции.

Для создания базы данных и файлов, в которых будет храниться база данных, можно использовать одну инструкцию CREATE DATABASE . В SQL Server инструкция CREATE DATABASE реализуется посредством следующих действий:

  1. SQL Server использует копию базы данных model для инициализации базы данных и ее метаданных.
  2. Базе данных назначается идентификатор GUID компонента Service Broker.
  3. Ядро СУБД затем заполняет остальную часть базы данных пустыми страницами, за исключением страниц, содержащих внутренние данные с описанием способа использования пространства в базе данных.

В экземпляре SQL Server можно указать не более 32 767 баз данных.

У каждой базы данных есть владелец, который может выполнять специальные действия в базе данных. Владельцем является пользователь, создавший базу данных. Владельца базы данных можно изменить с помощью инструкции ALTER AUTHORIZATION.

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

  • DBCC CHECKDB
  • FileStream
  • Оперативное резервное копирование с помощью VSS и моментальных снимков файлов
  • Создание моментального снимка базы данных
  • Файловая группа данных, оптимизированных для памяти

Файлы и файловые группы базы данных

В каждой базе данных имеется по крайней мере два файла (первичный файл и файл журнала транзакций) и по крайней мере одна файловая группа. Для каждой базы данных может указываться не более 32 767 файлов и 32 767 файловых групп.

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

Для хранения файлов базы данных SQL Server рекомендуется использовать сеть хранения данных (SAN), сеть на основе iSCSI или локально подключенный диск, так как в этой конфигурации достигаются оптимальные производительность и надежность SQL Server.

Моментальные снимки базы данных

С помощью инструкции CREATE DATABASE можно создать статическое представление, доступное только для чтения, моментальный снимокбазы данных-источника. Моментальный снимок базы данных согласован с базой данных-источником на уровне транзакций в том виде, в котором она существовала в момент создания моментального снимка. База данных-источник может иметь несколько моментальных снимков.

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

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

Каждый моментальный снимок существует до тех пор, пока не будет удален с помощью инструкции DROP DATABASE .

Параметры базы данных

Каждый раз при создании базы данных автоматически устанавливаются несколько параметров базы данных. См. список параметров ALTER DATABASE SET.

База данных модели и создание новых баз данных

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

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

Если не указан параметр FOR ATTACH , то каждая новая база данных наследует значения параметров из базы данных model . Например, параметру автоматического сжатия базы данных задано значение true в базе данных model и во всех вновь создаваемых базах данных. Если изменить параметры в базе данных model , они будут использоваться при создании новых баз данных. Операции, вносящие изменения в базу данных model , не влияют на существующие базы данных. Если параметр FOR ATTACH задан в инструкции CREATE DATABASE, то новая база данных наследует значения параметров исходной базы данных.

Просмотр сведений о базе данных

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

Разрешения

Требуется разрешение CREATE DATABASE , CREATE ANY DATABASE или ALTER ANY DATABASE .

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

В следующем примере предоставляется разрешение на создание базы данных для пользователя Fay базы данных.

USE master; GO GRANT CREATE DATABASE TO [Fay]; GO 

Разрешения на файлы данных и журналов

В SQL Server для файлов данных и журналов каждой базы данных заданы определенные разрешения. Следующие разрешения задаются при применении следующих операций к базе данных:

  • Вложен
  • Объекты резервного копирования
  • Создание
  • Отсоединен
  • Изменение для добавления нового файла
  • Восстановлено

Эти разрешения предотвращают случайное повреждение файлов, хранящихся в каталоге с открытыми разрешениями.

Microsoft SQL Server 2005 Express не задает разрешения на данные и файлы журнала.

Примеры

А. Создание базы данных без указания файлов

В следующем примере создается база данных mytest и соответствующие первичный файл и файл журнала транзакций. Так как инструкция не включает элементы , файл базы данных-источника имеет тот же размер, что и первичный файл базы данных model . Размер журнала транзакций устанавливается как наибольшее из следующих значений: 512 КБ или 25 % размера первичного файла данных. Поскольку параметр MAXSIZE не задан, файлы могут увеличиваться до заполнения всего свободного места на диске. Этот пример также демонстрирует, как удалить базу данных mytest , если она существует, перед созданием базы данных mytest .

USE master; GO IF DB_ID (N'mytest') IS NOT NULL DROP DATABASE mytest; GO CREATE DATABASE mytest; GO -- Verify the database files and sizes SELECT name, size, size*1.0/128 AS [Size in MBs] FROM sys.master_files WHERE name = N'mytest'; GO 

B. Создание базы данных, в которой заданы файлы данных и журнала транзакций

В следующем примере создается база данных Sales . Ключевое слово PRIMARY не использовано, поэтому первый файл ( Sales_dat ) становится первичным файлом. Поскольку в параметре SIZE для файла Sales_dat не заданы суффиксы MB и KB, используется значение MB и пространство выделяется в мегабайтах. Резервную копию базы данных Sales_log выделено в мегабайтах, потому что суффикс MB явно указан в параметре SIZE .

USE master; GO CREATE DATABASE Sales ON ( NAME = Sales_dat, FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\saledat.mdf', SIZE = 10, MAXSIZE = 50, FILEGROWTH = 5 ) LOG ON ( NAME = Sales_log, FILENAME = 'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\DATA\salelog.ldf', SIZE = 5MB, MAXSIZE = 25MB, FILEGROWTH = 5MB ) ; GO 

C. Создание базы данных, в которой указаны несколько файлов данных и журналов транзакций

Следующий пример создает базу данных Archive , имеющую 3 файла данных объемом по 100-MB каждый и два файла журнала транзакций по 100-MB . Первичный файл является первым файлом в списке и явно задан ключевым словом PRIMARY . Файлы журналов транзакций заданы следующими ключевыми словами LOG ON . Обратите внимание на расширения, используемые для файлов в параметре FILENAME : .mdf для первичных файлов данных, .ndf для вторичных файлов данных и .ldf для файлов журнала транзакций. В этом примере база данных размещается на диске D: , а не вместе с базой данных master .

USE master; GO CREATE DATABASE Archive ON PRIMARY (NAME = Arch1, FILENAME = 'D:\SalesData\archdat1.mdf', SIZE = 100MB, MAXSIZE = 200, FILEGROWTH = 20), ( NAME = Arch2, FILENAME = 'D:\SalesData\archdat2.ndf', SIZE = 100MB, MAXSIZE = 200, FILEGROWTH = 20), ( NAME = Arch3, FILENAME = 'D:\SalesData\archdat3.ndf', SIZE = 100MB, MAXSIZE = 200, FILEGROWTH = 20) LOG ON (NAME = Archlog1, FILENAME = 'D:\SalesData\archlog1.ldf', SIZE = 100MB, MAXSIZE = 200, FILEGROWTH = 20), (NAME = Archlog2, FILENAME = 'D:\SalesData\archlog2.ldf', SIZE = 100MB, MAXSIZE = 200, FILEGROWTH = 20) ; GO 

D. Создание базы данных с файловыми группами

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

  • Первичная файловая группа с файлами Spri1_dat и Spri2_dat . Для этих файлов задана величина приращения FILEGROWTH, равная 15% .
  • Файловая группа с именем SalesGroup1 и файлами SGrp1Fi1 и SGrp1Fi2 .
  • Файловая группа с именем SalesGroup2 и файлами SGrp2Fi1 и SGrp2Fi2 .

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

USE master; GO CREATE DATABASE Sales ON PRIMARY ( NAME = SPri1_dat, FILENAME = 'D:\SalesData\SPri1dat.mdf', SIZE = 10, MAXSIZE = 50, FILEGROWTH = 15% ), ( NAME = SPri2_dat, FILENAME = 'D:\SalesData\SPri2dt.ndf', SIZE = 10, MAXSIZE = 50, FILEGROWTH = 15% ), FILEGROUP SalesGroup1 ( NAME = SGrp1Fi1_dat, FILENAME = 'D:\SalesData\SG1Fi1dt.ndf', SIZE = 10, MAXSIZE = 50, FILEGROWTH = 5 ), ( NAME = SGrp1Fi2_dat, FILENAME = 'D:\SalesData\SG1Fi2dt.ndf', SIZE = 10, MAXSIZE = 50, FILEGROWTH = 5 ), FILEGROUP SalesGroup2 ( NAME = SGrp2Fi1_dat, FILENAME = 'D:\SalesData\SG2Fi1dt.ndf', SIZE = 10, MAXSIZE = 50, FILEGROWTH = 5 ), ( NAME = SGrp2Fi2_dat, FILENAME = 'D:\SalesData\SG2Fi2dt.ndf', SIZE = 10, MAXSIZE = 50, FILEGROWTH = 5 ) LOG ON ( NAME = Sales_log, FILENAME = 'E:\SalesLog\salelog.ldf', SIZE = 5MB, MAXSIZE = 25MB, FILEGROWTH = 5MB ) ; GO 

Е. Присоединение базы данных

В следующем примере база данных Archive , созданная в примере Е, отсоединяется, а затем присоединяется с помощью предложения FOR ATTACH . База данных Archive была определена с несколькими файлами данных и журналов. Однако поскольку местоположение файлов не изменилось со времени их создания, в предложении FOR ATTACH должен быть задан только первичный файл. Начиная с SQL Server 2005 (9.x) любые полнотекстовые файлы, являющиеся частью подключаемой базы данных, будут подключены вместе с базой данных.

USE master; GO sp_detach_db Archive; GO CREATE DATABASE Archive ON (FILENAME = 'D:\SalesData\archdat1.mdf') FOR ATTACH ; GO 

F. Создание моментального снимка базы данных

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

База данных-источник для этого примера — Sales , созданная в примере Г.

USE master; GO CREATE DATABASE sales_snapshot0600 ON ( NAME = SPri1_dat, FILENAME = 'D:\SalesData\SPri1dat_0600.ss'), ( NAME = SPri2_dat, FILENAME = 'D:\SalesData\SPri2dt_0600.ss'), ( NAME = SGrp1Fi1_dat, FILENAME = 'D:\SalesData\SG1Fi1dt_0600.ss'), ( NAME = SGrp1Fi2_dat, FILENAME = 'D:\SalesData\SG1Fi2dt_0600.ss'), ( NAME = SGrp2Fi1_dat, FILENAME = 'D:\SalesData\SG2Fi1dt_0600.ss'), ( NAME = SGrp2Fi2_dat, FILENAME = 'D:\SalesData\SG2Fi2dt_0600.ss') AS SNAPSHOT OF Sales ; GO 

G. Создание базы данных и назначение имени и параметров сортировки

В следующем примере создается база данных MyOptionsTest . Указано имя параметров сортировки, а параметрам TRUSTYWORTHY и DB_CHAINING присвоено значение ON .

USE master; GO IF DB_ID (N'MyOptionsTest') IS NOT NULL DROP DATABASE MyOptionsTest; GO CREATE DATABASE MyOptionsTest COLLATE French_CI_AI WITH TRUSTWORTHY ON, DB_CHAINING ON; GO --Verifying collation and option settings. SELECT name, collation_name, is_trustworthy_on, is_db_chaining_on FROM sys.databases WHERE name = N'MyOptionsTest'; GO 

H. Присоединение перемещенного полнотекстового каталога

В следующем примере показано, как присоединить полнотекстовый каталог AdvWksFtCat наряду с файлами данных и журнала AdventureWorks2022 . В этом примере полнотекстовый каталог перемещается из расположения по умолчанию в новое расположение c:\myFTCatalogs . Файлы данных и журналов остаются в расположениях по умолчанию.

USE master; GO --Detach the AdventureWorks2022 database sp_detach_db AdventureWorks2022; GO -- Physically move the full text catalog to the new location. --Attach the AdventureWorks2022 database and specify the new location of the full-text catalog. CREATE DATABASE AdventureWorks2022 ON (FILENAME = 'c:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Data\AdventureWorks2022_data.mdf'), (FILENAME = 'c:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\MSSQL\Data\AdventureWorks2022_log.ldf'), (FILENAME = 'c:\myFTCatalogs\AdvWksFtCat') FOR ATTACH; GO 

I. Создание базы данных, имеющей файловую группу строк и две файловые группы FILESTREAM

В следующем примере создается база данных FileStreamDB . Эта база данных создается с одной файловой группой строк и двумя файловыми группами FILESTREAM. Каждая файловая группа содержит один файл.

  • Группа FileStreamDB_data содержит данные строк. В нее входит один файл FileStreamDB_data.mdf , расположенный в пути по умолчанию.
  • Группа FileStreamPhotos содержит данные FILESTREAM. В нее входит два контейнера данных FILESTREAM, FSPhotos , расположенный в папке C:\MyFSfolder\Photos , и FSPhotos2 , расположенный в папке D:\MyFSfolder\Photos . Она отмечена как файловая группа FILESTREAM по умолчанию.
  • Группа FileStreamResumes содержит данные FILESTREAM. Она содержит один контейнер данных FILESTREAM — FSResumes , расположенный в папке C:\MyFSfolder\Resumes .
USE master; GO -- Get the SQL Server data path. DECLARE @data_path nvarchar(256); SET @data_path = (SELECT SUBSTRING(physical_name, 1, CHARINDEX(N'master.mdf', LOWER(physical_name)) - 1) FROM master.sys.master_files WHERE database_id = 1 AND file_id = 1); -- Execute the CREATE DATABASE statement. EXECUTE ('CREATE DATABASE FileStreamDB ON PRIMARY ( NAME = FileStreamDB_data ,FILENAME = ''' + @data_path + 'FileStreamDB_data.mdf'' ,SIZE = 10MB ,MAXSIZE = 50MB ,FILEGROWTH = 15% ), FILEGROUP FileStreamPhotos CONTAINS FILESTREAM DEFAULT ( NAME = FSPhotos ,FILENAME = ''C:\MyFSfolder\Photos'' -- SIZE and FILEGROWTH should not be specified here. -- If they are specified an error will be raised. , MAXSIZE = 5000 MB ), ( NAME = FSPhotos2 , FILENAME = ''D:\MyFSfolder\Photos'' , MAXSIZE = 10000 MB ), FILEGROUP FileStreamResumes CONTAINS FILESTREAM ( NAME = FileStreamResumes ,FILENAME = ''C:\MyFSfolder\Resumes'' ) LOG ON ( NAME = FileStream_log ,FILENAME = ''' + @data_path + 'FileStreamDB_log.ldf'' ,SIZE = 5MB ,MAXSIZE = 25MB ,FILEGROWTH = 5MB )' ); GO 

J. Создание базы данных, имеющей файловую группу FILESTREAM с несколькими файлами

В следующем примере создается база данных BlobStore1 . Эта база данных создается с одной файловой группой строк и одной файловой группой FILESTREAM, FS . Файловая группа FILESTREAM содержит два файла, FS1 и FS2 . Затем выполняется изменение базы данных путем добавления третьего файла, FS3 , в файловую группу FILESTREAM.

USE master; GO CREATE DATABASE [BlobStore1] CONTAINMENT = NONE ON PRIMARY ( NAME = N'BlobStore1', FILENAME = N'C:\BlobStore\BlobStore1.mdf', SIZE = 100MB, MAXSIZE = UNLIMITED, FILEGROWTH = 1MB ), FILEGROUP [FS] CONTAINS FILESTREAM DEFAULT ( NAME = N'FS1', FILENAME = N'C:\BlobStore\FS1', MAXSIZE = UNLIMITED ), ( NAME = N'FS2', FILENAME = N'C:\BlobStore\FS2', MAXSIZE = 100MB ) LOG ON ( NAME = N'BlobStore1_log', FILENAME = N'C:\BlobStore\BlobStore1_log.ldf', SIZE = 100MB, MAXSIZE = 1GB, FILEGROWTH = 1MB ); GO ALTER DATABASE [BlobStore1] ADD FILE ( NAME = N'FS3', FILENAME = N'C:\BlobStore\FS3', MAXSIZE = 100MB ) TO FILEGROUP [FS]; GO 

Следующие шаги

  • ALTER DATABASE
  • Присоединение и отсоединение базы данных
  • DROP DATABASE
  • EVENTDATA
  • ALTER AUTHORIZATION
  • sp_detach_db
  • sp_removedbreplication
  • Моментальные снимки базы данных
  • Перемещение файлов базы данных
  • Базы данных
  • Данные большого двоичного объекта

Как работать с DB Browser for SQLite: шаг за шагом руководство

DB Browser for SQLite - это инструмент, который позволяет вам удобно работать с базами данных SQLite. Он предоставляет графический интерфейс пользователя, который облегчает создание, редактирование и просмотр данных в базе данных SQLite. В этой статье мы рассмотрим основные возможности DB Browser for SQLite и как ими пользоваться.

Установка DB Browser for SQLite

Первым шагом является установка DB Browser for SQLite. Вы можете скачать его с официального сайта https://sqlitebrowser.org/dl/ и выбрать подходящую версию для своей операционной системы. После установки запустите приложение.

Открытие базы данных

Чтобы начать работать с базой данных, вам нужно открыть ее в DB Browser for SQLite. Для этого следуйте этим шагам:

  1. Нажмите на кнопку "Открыть базу данных" или выберите пункт "Файл" в верхнем меню и выберите "Открыть базу данных".
  2. Выберите файл базы данных SQLite на вашем компьютере и нажмите "Открыть".

После этого вы увидите структуру вашей базы данных и данные, которые она содержит.

Создание таблицы

DB Browser for SQLite позволяет вам создавать новые таблицы в базе данных. Для создания новой таблицы выполните следующие действия:

  1. Выберите базу данных, в которой вы хотите создать таблицу.
  2. Нажмите на кнопку "Создать новую таблицу" или выберите пункт "Таблицы" в верхнем меню и выберите "Создать новую таблицу".
  3. Введите имя таблицы и определите ее столбцы и их типы данных.
  4. Нажмите "Сохранить", чтобы создать таблицу.

Теперь у вас есть новая таблица в вашей базе данных.

Добавление данных

Чтобы добавить данные в таблицу, выберите таблицу и выполните следующие действия:

  1. Нажмите на кнопку "Вставить запись" или выберите пункт "Таблицы" в верхнем меню и выберите "Вставить запись".
  2. Заполните значения полей для новой записи.
  3. Нажмите "Сохранить", чтобы добавить запись.

Таким образом, вы можете добавлять данные в таблицу своей базы данных.

Запросы к базе данных

DB Browser for SQLite позволяет выполнять запросы к вашей базе данных. Вы можете использовать стандартный SQL-запрос или создать запрос визуально с помощью Query Builder.

Чтобы выполнить запрос, выполните следующие действия:

  1. Выберите вкладку "SQL" в верхнем меню.
  2. Введите SQL-запрос в текстовом поле.
  3. Нажмите кнопку "Выполнить SQL" или нажмите клавишу Enter.

DB Browser for SQLite выполнит ваш запрос и отобразит результаты в таблице снизу.

Экспорт и импорт данных

Вы можете экспортировать данные из вашей базы данных в различные форматы, такие как CSV, JSON, XML и другие. Для экспорта данных выполните следующие действия:

  1. Выберите таблицу или запрос, данные которого вы хотите экспортировать.
  2. Выберите пункт "Файл" в верхнем меню и выберите "Экспорт".
  3. Выберите формат экспорта и место, куда сохранить файл.
  4. Нажмите "Экспортировать", чтобы сохранить данные.

Вы также можете импортировать данные в вашу базу данных из файлов различных форматов. Для импорта данных выполните следующие действия:

  1. Выберите таблицу, в которую вы хотите импортировать данные.
  2. Выберите пункт "Файл" в верхнем меню и выберите "Импорт".
  3. Выберите файл данных для импорта.
  4. Нажмите "Открыть", чтобы импортировать данные.

Теперь вы знаете основные возможности DB Browser for SQLite и можете эффективно работать с базами данных SQLite.

Получение данных из таблицы SQLite

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

В этой статье мы будем:

  • Получать все строки с помощью с помощью cursor.fetchall() .
  • Использовать cursor.fetchmany(size) для получения ограниченного количества строк, а также cursor.fetchone() — для одной.
  • Использовать переменные Python в запросе SQLite для передачи динамических данных.

Подготовка

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

В этом примере будет использоваться таблица sqlitedb_developers . Она была создана в первой части руководства по sqlite3 и заполнена во второй.

Шаги для получения строк из таблицы SQLite

Для выполнения операции SELECT из Python нужно выполнить следующие шаги:

  • Установить соединение с базой данных SQLite из Python;
  • Создать запрос с инструкцией SELECT для SQLite. Именно на этом этапе понадобятся знания названия таблицы и подробностей о колонках;
  • Выполнить SELECT-запрос с помощью метода cursor.execute()
  • Получить строки с помощью объекта Cursor и метода cursor.fetchall() ;
  • Перебрать строки и получить для каждой ее соответствующее значение;
  • Закрыть объект Cursor и соединение с базой данных SQLite;
  • Перехватить любые исключения, которые могут возникнуть в процессе работы.

Пример программы на Python для получения всех строк из таблицы sqlitedb_developers .

 
import sqlite3

def read_sqlite_table(records):
try:
sqlite_connection = sqlite3.connect('sqlite_python.db')
cursor = sqlite_connection.cursor()
print("Подключен к SQLite")

sqlite_select_query = """SELECT * from sqlitedb_developers"""
cursor.execute(sqlite_select_query)
records = cursor.fetchall()
print("Всего строк: ", len(records))
print("Вывод каждой строки")
for row in records:
print("ID:", row[0])
print("Имя:", row[1])
print("Почта:", row[2])
print("Добавлен:", row[3])
print("Зарплата:", row[4], end="\n\n")

cursor.close()

except sqlite3.Error as error:
print("Ошибка при работе с SQLite", error)
finally:
if sqlite_connection:
sqlite_connection.close()
print("Соединение с SQLite закрыто")

read_sqlite_table()
Подключен к SQLite Всего строк: 6 Вывод каждой строки ID: 1 Имя: Oleg Почта: oleg04@gmail.com Добавлен: 2020-11-29 Зарплата: 8100.0 . ID: 6 Имя: Nikita Почта: aqillysso@gmail.com Добавлен: 2020-11-27 Зарплата: 7400.0 Соединение с SQLite закрыто

В этом примере прямо отображаются строка и значение ее колонки. Если вам нужно использовать значения колонки в своей программе, то их можно сохранять в переменные Python. Для этого нужно написать, например, так: name = row[1] .

Разбор примера

  • Эта строка импортирует в программу модуль sqlite3.
  • С помощью классов и методов из этого модуля можно прямо взаимодействовать с базой данных.

sqlite3.connect() и connection.cursor() :

  • С помощью sqlite3.connect() устанавливается соединение с базой данных SQLite из Python.
  • После этого готовится SELECT-запрос для получения всех строк из таблицы sqlitedb_developers . Она содержит пять колонок.
  • Метод connection.cursor() используется для получения объекта Cursor из объекта соединения.

cursor.execute() и cursor.fetchall() :

  • Выполняется SELECT-операция с помощью метода execute() объекта Cursor .
  • После успешного выполнения запроса используется метод cursor.fetchall() для получения всех записей таблицы sqlitedb_developers .
  • В конце используется цикл для перебора всех записей и вывода их по одному.

После того как все записи были получены, объект Cursor закрывается с помощью cursor.close() , а соединение с базой данных — с помощью sqliteConnection.close() .

  • Используйте cursor.execute() для выполнения запроса.
  • cursor.fetchall() — получение всех строк.
  • cursor.fetchone() — для одной строки.
  • cursor.fetchmany(SIZE) — для ограниченного количества строк.

Использование переменных в качестве параметров Select-запроса

Часто есть необходимость передать переменную в SELECT-запрос для проверки определенного условия.

Предположим, приложение хочет сделать запрос для получения информации о разработчиках, используя их id. Для этого необходим запрос с параметрами. Это такой запрос, где внутри используются заполнители (?) на месте параметров, которые потом заменяются реальными значениями.

cursor.execute("SELECT salary FROM sqlitedb_developers WHERE )
 
import sqlite3

def get_developer_info(id):
try:
sqlite_connection = sqlite3.connect('sqlite_python.db')
cursor = sqlite_connection.cursor()
print("Подключен к SQLite")

sql_select_query = """select * from sqlitedb_developers where /> cursor.execute(sql_select_query, (id,))
records = cursor.fetchall()
print("Вывод ID ", id)
for row in records:
print("ID:", row[0])
print("Имя:", row[1])
print("Почта:", row[2])
print("Добавлен:", row[3])
print("Зарплата:", row[4], end="\n\n")

cursor.close()

except sqlite3.Error as error:
print("Ошибка при работе с SQLite", error)
finally:
if sqlite_connection:
sqlite_connection.close()
print("Соединение с SQLite закрыто")

get_developer_info(2)
Подключен к SQLite Вывод ID 2 ID: 2 Имя: Viktoria Почта: s_dom34@gmail.com Добавлен: 2020-11-19 Зарплата: 6000.0 Соединение с SQLite закрыто

Получение нескольких строк из таблицы

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

Для получения всех строк нужно больше ресурсов: памяти и времени обработки. А для улучшения производительности в таких случаях рекомендуется использовать метод fetchmany(size) класса сursor для получения фиксированного количество строк.

С помощью cursor.fetchmany(size) можно указать, сколько строк требуется прочесть. Рассмотрим на примере:

 
import sqlite3

def read_limited_rows(row_size):
try:
sqlite_connection = sqlite3.connect('sqlite_python.db')
cursor = sqlite_connection.cursor()
print("Подключен к SQLite")

sqlite_select_query = """SELECT * from sqlitedb_developers"""
cursor.execute(sqlite_select_query)
print("Чтение ", row_size, " строк")
records = cursor.fetchmany(row_size)
print("Вывод каждой строки \n")
for row in records:
print("ID:", row[0])
print("Имя:", row[1])
print("Почта:", row[2])
print("Добавлен:", row[3])
print("Зарплата:", row[4], end="\n\n")

cursor.close()

except sqlite3.Error as error:
print("Ошибка при работе с SQLite", error)
finally:
if sqlite_connection:
sqlite_connection.close()
print("Соединение с SQLite закрыто")

read_limited_rows(2)
Подключен к SQLite Чтение 2 строк Вывод каждой строки ID: 1 Имя: Oleg Почта: oleg04@gmail.com Добавлен: 2020-11-29 Зарплата: 8100.0 ID: 2 Имя: Viktoria Почта: s_dom34@gmail.com Добавлен: 2020-11-19 Зарплата: 6000.0 Соединение с SQLite закрыто

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

Получение одной строки из таблицы

Когда нужно получить одну строку из таблицы SQLite, стоит использовать метод fetchone() класса cursor . Этот метод необходим в тех случаях, когда известно, что запрос вернет одну строку.

cursor.fetchone() получает только следующую строку из результата. Если же строк нет, то возвращается None . Пример:

 
import sqlite3

def read_single_row(developer_id):
try:
sqlite_connection = sqlite3.connect('sqlite_python.db')
cursor = sqlite_connection.cursor()
print("Подключен к SQLite")

sqlite_select_query = """SELECT * from sqlitedb_developers where /> cursor.execute(sqlite_select_query, (developer_id, ))
print("Чтение одной строки \n")
record = cursor.fetchone()
print("ID:", record[0])
print("Имя:", record[1])
print("Почта:", record[2])
print("Добавлен:", record[3])
print("Зарплата:", record[4])

cursor.close()

except sqlite3.Error as error:
print("Ошибка при работе с SQLite", error)
finally:
if sqlite_connection:
sqlite_connection.close()
print("Соединение с SQLite закрыто")

read_single_row(3)
Подключен к SQLite Чтение одной строки ID: 3 Имя: Valentin Почта: exp3@gmail.com Добавлен: 2020-11-23 Зарплата: 6500.0 Соединение с SQLite закрыто

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *