MySql + FLask

Mysql 学习笔记

下载

下载

https://www.cnblogs.com/reyinever/p/8551977.html
官网下载 MySQLcommunity sever
解压缩

配置环境变量

变量名:MYSQL_HOME
变量值:E:\mysql-5.7.20-winx64
path里添加:%MYSQL_HOME%\bin;

注册用户

生成data

以管理员身份运行cmd
进入E:\mysql-5.7.20-winx64\bin 下
执行命令:mysqld --initialize-insecure --user=mysql
在E:\mysql-5.7.20-winx64目录下生成data目录

启动服务

执行命令:net start mysql 启动mysql服务,
若提示:服务名无效 解决办法:mysqld -install

登陆

登录mysql:(因为之前没设置密码,所以密码为空,不用输入密码,直接回车即可)

E:\mysql-5.7.20-winx64\bin>mysql -u root -p
Enter password: 回车符

修改root密码,注册新用户

略,有空再添加

创建数据库

https://www.runoob.com/mysql/mysql-tutorial.html
在mysql terminal中
mysql> create DATABASE appdb;
mysql> use appdb;

创建table

例子

root@host# mysql -u root -p
Enter password:*******
mysql> use RUNOOB;
Database changed
mysql> CREATE TABLE runoob_tbl(
   -> runoob_id INT NOT NULL AUTO_INCREMENT,
   -> runoob_title VARCHAR(100) NOT NULL,
   -> runoob_author VARCHAR(40) NOT NULL,
   -> submission_date DATE,
   -> PRIMARY KEY ( runoob_id )
   -> )ENGINE=InnoDB DEFAULT CHARSET=utf8;
Query OK, 0 rows affected (0.16 sec)
mysql>

数据库操作

insert

mysql> INSERT INTO runoob_tbl 
    -> (runoob_title, runoob_author, submission_date)
    -> VALUES
    -> ("学习 PHP", "菜鸟教程", NOW());
Query OK, 1 rows affected, 1 warnings (0.01 sec)

查看

查看数据库信息

SHOW DATABASES;
SHOW TABLES;

Flask + MySQL

这里我用root登陆,格式是[root]:[password](我的密码是空)。MySQL端口3306,然后用我创建的appdb。
注意sqlite可以直接用python来建数据库,table。但是MySql要先在外面建好db和table。

# config.py
# app path
base_dir = os.path.abspath(os.path.dirname(__file__))  # 返回绝对路径
# sqlalchemy 配置
    SQLALCHEMY_DATABASE_URI = 'mysql+pymysql://root:@localhost:3306/appdb'  # MySql
    # SQLALCHEMY_DATABASE_URI = 'sqlite:///' + os.path.join(base_dir, 'app.db')  # Sqlite
    SQLALCHEMY_TRACK_MODIFICATIONS = True
    SQLALCHEMY_COMMIT_ON_TEARDOWN = True
# app.py 
# 导入配置
app.config.from_object(config.get('default'))
# models/user.py
class User(UserMixin, db.Model):
    """define a user

    Attributes:
        id: define the id of a user
        username: define username of a user
        password: define password of a user
    """
    id = db.Column(db.Integer, primary_key=True)
    username = db.Column(db.String(80), unique=True, nullable=False)
    password = db.Column(db.String(80), unique=True, nullable=False)

    def check_password(self, password):
        return password == self.password

    def __repr__(self):
        return '<User %r>' % self.username
# routes/user.py
通过python添加用户
@app.route('/')
def register():
	user = User(username=form.username.data, password=form.password.data)
	db.session.add(user)
	db.session.commit()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python+MySQL+Flask 是一种常见的 Web 开发技术栈,它们分别是 Python 编程语言、MySQL 数据库和 Flask Web 框架。 Python 是一种高级编程语言,具有简单易学、强大灵活、可扩展性好等优点,因此在 Web 开发领域得到了广泛应用。MySQL 是一种常见的关系型数据库,具有高可靠性、高性能、易于管理等特点,因此也广泛应用于 Web 开发中。Flask 是一个基于 Python 的轻量级 Web 框架,它具有易于学习、灵活、可扩展性好等优点,因此被广泛应用于 Web 开发中。 Python+MySQL+Flask 的工作流程一般如下: 1. 使用 Python 连接 MySQL 数据库,执行 SQL 语句进行数据库操作; 2. 使用 Flask 构建 Web 应用程序,将 Python 代码和 HTML、CSS、JavaScript 等前端代码结合起来,实现 Web 功能; 3. 将 Flask 应用程序部署到服务器上,使其可以被外部用户访问。 具体的操作流程如下: 1. 安装 Python 和 MySQL,使用 Python 的 MySQL 连接库连接到 MySQL 数据库; 2. 创建 Flask 应用程序,设置路由、视图函数、模板等; 3. 在视图函数中进行数据库操作,将结果渲染到模板中返回给用户; 4. 部署 Flask 应用程序到服务器上,使用 Web 服务器(如 Nginx)进行反向代理和负载均衡,使其可以被外部用户访问。 总的来说,Python+MySQL+Flask 是一种简单易用、高效可靠的 Web 开发技术栈。它们的优点在于 Python 语言的简单易学、MySQL 数据库的高可靠性和高性能、Flask 框架的灵活和可扩展性。如果你想学习 Web 开发,这个技术栈是一个不错的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值