Firt issue was start script.
I create a linux script named start_server.sh to run the flask run command:
[mythcat@desk my_flask]$ ./start_server.sh
I update the User with new fiels: class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
username = db.Column(db.String(80), unique=True)
password = db.Column(db.String(120), unique=True)
email = db.Column(db.String(120), unique=True)
gender = db.Column(db.String(5), unique=True)
work = db.Column(db.String(33), unique=True)
city = db.Column(db.String(15), unique=True)
Let's see how I deal with this versus database and migrate process. [mythcat@desk my_flask]$ rm server.sqlite
[mythcat@desk my_flask]$ python3
Python 3.7.4 (default, Jul 9 2019, 16:32:37)
[GCC 9.1.1 20190503 (Red Hat 9.1.1-1)] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from server import db
>>> db.create_all()
>>> db.engine.table_names()
['user']
>>> exit()
[mythcat@desk my_flask]$ ls server.sqlite
server.sqlite
[mythcat@desk my_flask]$ sqlite3 server.sqlite
SQLite version 3.26.0 2018-12-01 12:34:55
Enter ".help" for usage hints.
sqlite> .tables
user
sqlite> .schema user
CREATE TABLE user (
id INTEGER NOT NULL,
username VARCHAR(80),
password VARCHAR(120),
email VARCHAR(120),
gender VARCHAR(5),
work VARCHAR(33),
city VARCHAR(15),
PRIMARY KEY (id),
UNIQUE (username),
UNIQUE (password),
UNIQUE (email),
UNIQUE (gender),
UNIQUE (work),
UNIQUE (city)
);
I got a strange error: sqlalchemy.exc.OperationalError: (sqlite3.OperationalError) duplicate column name: city
I fix it with this , but I'm not sure if the right way:[mythcat@desk my_flask]$ rm migrations/ -r -f
[mythcat@desk my_flask]$ python3 server.py db init
Creating directory /home/mythcat/project_github/my_flask/migrations ... done
Creating directory /home/mythcat/project_github/my_flask/migrations/versions ... done
Generating /home/mythcat/project_github/my_flask/migrations/script.py.mako ... done
Generating /home/mythcat/project_github/my_flask/migrations/env.py ... done
Generating /home/mythcat/project_github/my_flask/migrations/alembic.ini ... done
Generating /home/mythcat/project_github/my_flask/migrations/README ... done
Please edit configuration/connection/logging settings in '/home/mythcat/project_github/my_flask/migrations/alembic.ini'
before proceeding.
[mythcat@desk my_flask]$ python3 server.py db migrate
INFO [alembic.runtime.migration] Context impl SQLiteImpl.
INFO [alembic.runtime.migration] Will assume non-transactional DDL.
INFO [alembic.env] No changes in schema detected.
[mythcat@desk my_flask]$ python3 server.py db upgrade
INFO [alembic.runtime.migration] Context impl SQLiteImpl.
INFO [alembic.runtime.migration] Will assume non-transactional DDL.