sql >> Databáze >  >> RDS >> Mysql

Laravel Sail obnoví výchozí databázi

Případ – Opětovné použití již vytvořeného svazku Docker

Pokud zastavíte Sail pomocí sail down , objem dat zůstane na hostiteli Docker, aniž by byl odstraněn.

Když je Sail zastaveno, použijte sail down -v smazat stávající data svazku Docker.

Nejprve sail up , DB_DATABASE=forge

Při prvním spuštění Sail se na hostiteli Dockeru vytvoří svazek.

grep DB_DATABASE .env
DB_DATABASE=forge

docker volume ls
DRIVER    VOLUME NAME

sail up -d
Creating network "test_sail" with driver "bridge"
Creating volume "test_sailmysql" with local driver
Creating volume "test_sailredis" with local driver
Creating test_mailhog_1 ... done
Creating test_mysql_1   ... done
Creating test_redis_1   ... done
Creating test_laravel.test_1 ... done

docker volume ls
DRIVER    VOLUME NAME
local     test_sailmysql
local     test_sailredis

sail mysql
mysql> show databases;
| forge              |

Když však ukončím Sail, kontejner Docker se odstraní, ale svazek se nesmaže.

sail down
Stopping test_laravel.test_1 ... done
Stopping test_mailhog_1      ... done
Stopping test_redis_1        ... done
Stopping test_mysql_1        ... done
Removing test_laravel.test_1 ... done
Removing test_mailhog_1      ... done
Removing test_redis_1        ... done
Removing test_mysql_1        ... done
Removing network test_sail

docker volume ls
DRIVER    VOLUME NAME
local     test_sailmysql
local     test_sailredis

Druhý sail up , DB_DATABASE=test

Pokud spustíte druhý Sail se stejným názvem adresáře, již vytvořený svazek Dockeru bude znovu použit.

grep DB_DATABASE .env
DB_DATABASE=test

sail up -d
Creating network "test_sail" with driver "bridge"
Creating test_mysql_1   ... done
Creating test_redis_1   ... done
Creating test_mailhog_1 ... done
Creating test_laravel.test_1 ... done

docker volume ls
DRIVER    VOLUME NAME
local     test_sailmysql
local     test_sailredis

Protože data existují v test_sailmysql , což je svazek vytvořený při prvním spuštění, úloha vytvoření nové databáze se neprovede.

sail mysql
  ERROR 1049 (42000): Unknown database 'test'
sail artisan migrate
  Illuminate\Database\QueryException
  SQLSTATE[HY000] [1049] Unknown database 'test' (SQL: select * from information_schema.tables where table_schema = test and table_name = migrations and table_type = 'BASE TABLE')

Začněte po odstranění stávajícího svazku

sail down -v
...
Removing volume test_sailmysql
Removing volume test_sailredis
sail up -d
...
Creating volume "test_sailmysql" with local driver
Creating volume "test_sailredis" with local driver
sail mysql
mysql> show databases;
| test               |
sail artisan migrate
Migration table created successfully.
Migrating: 2014_10_12_000000_create_users_table
Migrated:  2014_10_12_000000_create_users_table (214.30ms)
Migrating: 2014_10_12_100000_create_password_resets_table
Migrated:  2014_10_12_100000_create_password_resets_table (99.56ms)
Migrating: 2019_08_19_000000_create_failed_jobs_table
Migrated:  2019_08_19_000000_create_failed_jobs_table (151.61ms)

sail down možnosti

sail down -h

    -v, --volumes           Remove named volumes declared in the `volumes`
                            section of the Compose file and anonymous volumes
                            attached to containers.


  1. Jak spustit aplikaci spring-boot bez závislosti na databázi?

  2. 1052:Sloupec 'id' v seznamu polí je nejednoznačný

  3. Jak funguje funkce CHARACTER_LENGTH() v MySQL

  4. Přístup ke vzdálené databázi mysql z příkazového řádku