【前端开发学习】6.MySQL

news2024/11/17 7:34:50

文章目录

  • 1 MySQL 指令
    • 1.1 数据库管理(文件夹)
    • 1.2 数据表管理(文件)
    • 1.3 数据行操作
    • 总结
  • 2 案例:员工管理
    • 2.1 创建表结构
    • 2.2 Python 操作 MySQL
      • 1. 创建数据
      • 2. 查询数据
      • 3. 删除
      • 4. 修改
      • 总结
  • 3 案例: Flask + 前端 + MySQL
    • 3.1 新增用户
    • 3.2 查看用户

本文指令基于 MySQL 8.0 版本。

1 MySQL 指令

1.1 数据库管理(文件夹)

数据库 = 文件夹
数据表 = 文件

1. 查看已有的数据库

show databases;

2. 创建数据库

create database gx1217 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

3. 删除数据库

drop database 数据库名;

4. 进入数据库

use 数据库名;

5. 查看文件夹下所有的数据表

show tables;

1.2 数据表管理(文件)

1. 创建表格

create table 表名称(
	列名称 类型,
	列名称 类型,		
	列名称 类型,
)default charset=utf8;

eg:

在这里插入图片描述
(1)

create table tb1(
	id int, 
	name varchar(16), 
	age int
)default charset=utf8;

(2)空值:

create table tb1(
	id int, 
	name varchar(16) not null, -- 不允许为空 
	age int null, -- 允许为空(默认)
)default charset=utf8;

(3)默认值:

create table tb1(
	id int, 
	name varchar(16),
	age int default 3, -- 插入数据时,age如果没有传入值,默认为3
)default charset=utf8;

(4)主键一般用于表示当前行的数据编号(类似于身份证):

create table tb1(
	id int primary key, -- 主键(不允许为空,不允许重复)  
	name varchar(16), 
	age int,
)default charset=utf8;

(5)一般情况下, 在创建表时会这么写:

create table tb1(
	id int auto_increment primary key, -- 内部维护,自增
	name varchar(16), 
	age int,
)default charset=utf8;

2. 删除表

drop table 表名称;

3. 查看表

desc 表名称;

在这里插入图片描述

4. 常用数据类型

  • tinyint

    • 有符号,取值范围:-128 ~ 127(有正有负)【默认】;
      create table tb1(
         id int, 
         age tinyint, -- 有符号
      )default charset=utf8;
      
    • 无符号,取值范围:0 ~ 255 (只有正);
      create table tb1(
         id int, 
         age tinyint unsigned, -- 无符号
      )default charset=utf8;
      
  • int

    • 有符号,取值范围:-2147483648 ~ 2147483647(有正有负)【默认】;

    • 无符号,取值范围:0 ~ 4294967295(只有正);

  • bigint

    • 有符号【默认】;

    • 无符号;

  • float

  • double

  • decimal
    准确的小数值, m 是数字总个数(负号不算), d 是小数点后个数, m 最大值为 65, d 最大值为 30 。

    salary decimal(8, 2)
    
  • char
    定长字符串。

    mobile char(11) -- 固定用11个字符存储
    -- 哪怕没有11个字符,也会用11个字符存储
    
  • varchar
    变长字符串,真实数据有多长就按照多长存储。

  • text
    text 数据类型用于保存变长的大字符串,最多可以用到 65535 ( 2 ** 16 - 1 ) 个字符。

  • mediumtext

  • longtext

  • datetime

    YYYY-MM-DD HH:MM:SS (1000-01-01 00:00:00)
    
  • date

    YYYY-MM-DD (1000-01-01)
    

1.3 数据行操作

1. 新增数据

insert into 表名(列名, 列名) values(,);

insert into 表名(列名, 列名) values(,), (,);

2. 删除数据

delete from 表名;
delete from 表名 where 条件;
delete from db3;
delete from db3 where id=1;

3. 修改数据

update 表名 set=;

update 表名 set=,=;

update 表名 set=where 条件;

4. 查询数据

select * from 表名称;
select 列名称, 列名称 from 表名称;

select 列名称, 列名称 from 表名称 where 条件;

总结

开发系统的时候,一般先通过 工具 + 命令 「创建数据集,创建数据表」 , 而表中的数据一按通过程序实现 增删改查

2 案例:员工管理

  • 使用 MySQL 内置工具(命令)

    • 创建数据库 : unicom;
    • 创建数据表 : admin;
    id 整型,自增,主键;
    username 字符串,不为空;
    password 字符串,不为空;
    mobile 字符串 不为空;
    
  • Python 代码实现:

    • 添加用户;
    • 删除用户;
    • 查看用户;
    • 更新用户信息;

2.1 创建表结构

create database unicom DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
use unicom;
create table admin(
	id int auto_increment primary key,
	username varchar(64) not null,
	password varchar(64) not null,
	mobile varchar(11) not null
)default charset=utf8;

在这里插入图片描述

2.2 Python 操作 MySQL

pip install pymysql

1. 创建数据

(1)模板

import pymysql

# 1.连接 MySQL
conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd="root", charset='utf8', db='unicom')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 2.发送指令
# 千万不要用字符串格式去做sql的拼接,安全隐患sql注入
cursor.execute("insert into admin(username, password, mobile) values('rice', '123456', '15121254532')")
conn.commit()

# 3.关闭
conn.close()

(2)发送指令的其他格式

sql = "insert into admin(username, password, mobile) values(%s, %s, %s)"
cursor.execute(sql, ["candy", "123456", "12345678910"])
conn.commit()
sql = "insert into admin(username, password, mobile) values(%(n1)s, %(n2)s, %(n3)s)"
cursor.execute(sql, {"n1":"hair", "n2":"123456", "n3":"12345678910"})

2. 查询数据

(1)模板

import pymysql

# 1.连接 MySQL
conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd="root", charset='utf8', db='unicom')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 2.发送指令
# 千万不要用字符串格式去做sql的拼接,安全隐患sql注入
cursor.execute("select * from admin where id > 2")
# 列表里面套字典
data_list = cursor.fetchall()
for row_dict in data_list:
    print(row_dict)

# 3.关闭
cursor.close()
conn.close()

(2)拼接的查询语句

cursor.execute("select * from admin where id > %s", [2, ])

(3)获取符合条件的第一条数据,返回字典

res = cursor.fetchone()

3. 删除

模板

import pymysql

# 1.连接 MySQL
conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd="root", charset='utf8', db='unicom')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 2.发送指令
cursor.execute("delete from admin where id = %s", [4, ])
conn.commit()

# 3.关闭
cursor.close()
conn.close()

4. 修改

模板

import pymysql

# 1.连接 MySQL
conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd="root", charset='utf8', db='unicom')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 2.发送指令
cursor.execute("update admin set mobile=%s where id=%s", ["15254829951", 2, ])
conn.commit()

# 3.关闭
cursor.close()
conn.close()

总结

  • 新增、删除、修改 的时候,一定要执行 conn.commit() ,否则数据库中没有数据;
  • 查询 时,不需要 conn.commit() ,但是要执行 fetchall() fetchone() ;
  • 对于 SQL 语句不要用 Python 的字符串格式化进行拼接,一定要用 execute()

3 案例: Flask + 前端 + MySQL

3.1 新增用户

from flask import Flask, render_template, request
import pymysql

app = Flask(__name__)


@app.route("/add/user", methods=["GET", "POST"])
def add_user():
    if request.method == "GET":
        return render_template("add_user.html")

    username = request.form.get("user")
    password = request.form.get("pwd")
    mobile = request.form.get("mobile")

    # 1.连接MySQL
    conn = pymysql.connect(host="127.0.0.1", port=3306,
                           user='root', passwd="root",
                           charset='utf8', db="unicom")
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

    # 2.执行SQL
    sql = "insert into admin(username, password, mobile) values(%s, %s, %s)"
    cursor.execute(sql, [username, password, mobile])
    conn.commit()

    # 3.关闭连接
    conn.close()
    return "添加成功"

if __name__ == '__main__':
    app.run()

add_user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>添加用户</h1>
<form method="POST" action="/add/user">
    <input type="text" name="user" placeholder="用户名">
    <input type="text" name="pwd" placeholder="密码">
    <input type="text" name="mobile" placeholder="手机号">
    <input type="submit" value="提 交">
</form>
</body>
</html>

3.2 查看用户

from flask import Flask, render_template, request
import pymysql

app = Flask(__name__)

@app.route("/show/user")
def show_user():
    # 1.连接MySQL
    conn = pymysql.connect(host="127.0.0.1", port=3306,
                           user='root', passwd="root",
                           charset='utf8', db="unicom")
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

    # 2.执行SQL
    sql = "select * from admin"
    cursor.execute(sql)
    data_list = cursor.fetchall()

    # 3.关闭连接
    cursor.close()
    conn.close()

    print(data_list)

    return render_template("show_user.html", data_list=data_list)

if __name__ == '__main__':
    app.run()

show_user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>用户列表</h1>
<table border="1">
    <thead>
        <tr>
            <th>ID</th>
            <th>姓名</th>
            <th>密码</th>
            <th>手机号</th>
        </tr>
    </thead>
    <tbody>
    {% for item in data_list %}
        <tr>
            <td>{{ item.id }}</td>
            <td>{{ item.username }}</td>
            <td>{{ item.password }}</td>
            <td>{{ item.mobile }}</td>
        </tr>
    {% endfor %}
    </tbody>
</table>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/98030.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JVM类加载/双亲委派模型

类加载是一个复杂的过程, 那么我们平时说的类加载到底是干啥的呢? 一. 类加载是干啥的 我们都知道Java程序在运行之前, 需要进行编译, 由 .java > .class文件(二进制字节码文件) , 而在运行的时候呢, Java进程(JVM), 就会读取对应的 .class文件, 并且解析他的内容, 在内存…

MySQL --- 函数大全 8

目录 1.返回一个字符串在出现指定数量的分隔符之前的子字符串 SUBSTRING_INDEX() 2.减去时间 SUBTIME() 3.返回总和 SUM() 4.返回函数执行的时间 SYSDATE() 5.返回参数的切线 TAN() 6.提取表达式传递的时间部分 TIME() 7.格式…

ZY_BMP280大气压模块的使用和stm32程序

在搞设计时&#xff0c;用到了大气压模块BMP280&#xff0c;这玩意也不难&#xff0c;主要是淘宝店老板特别der一问三不知&#xff0c;真服了&#xff0c;而且资料里面没有给例程&#xff0c;只有51的例程&#xff0c;利用IIC通信&#xff0c;而且给的例程里面&#xff0c;乱七…

说说 fiber、DOM、ReactElement、实例对象之间的引用关系

大家好&#xff0c;我是前端西瓜哥。 本文探究 fiber、DOM、ReactElement、类组件实例之间的引用关系说明。 React 版本为 18.2.0 原生组件 fiber 原生组件 fiber&#xff0c;指的就是 type 为 “span”、“div” 的 fiber。 fiber.stateNode 指向真实 DOM 节点&#xff1b;n…

Tableau可视化设计案例-03基本表、树形图、气泡图、词云

文章目录Tableau可视化设计案例03基本表、树形图、气泡图、词云1.基本表1.1基本表的使用1.2凸显表的使用1.3二值凸显表2.树形图2.1不同类型酒店数量与评价人数2.2油尖旺不同类型酒店数量与价格3.气泡图与词云3.1不同地区酒店数量与平均价格气泡图3.2动作电影动态气泡图3.3词云图…

Dubbo 4 Dubbo 高级特性 4.2 Dubbo 常用高级配置 4.2.1 序列化

Dubbo 【黑马程序员Dubbo快速入门&#xff0c;Java分布式框架dubbo教程】 4 Dubbo 高级特性 文章目录Dubbo4 Dubbo 高级特性4.2 Dubbo 常用高级配置4.2.1 序列化4.2 Dubbo 常用高级配置 4.2.1 序列化 【一个问题】 两个机器传输数据&#xff0c;如何传输Java对象&#xff…

【YOLOv7-环境搭建⑥】PyTorch安装

下载链接&#xff1a; 来源&#xff1a;&#xff08;博主&#xff09;唐三. 链接:https://pan.baidu.com/s/1y6s_EScOqvraFcx7iPSy1g 提取码:m1oa 安装步骤&#xff1a; 在命令指示符中输入以下命令&#xff1a; activate→conda activate py37→输入以下命令&#xff08…

【Python机器学习】密度聚类DBSCAN、OPTICS的讲解及实战演示(附源码 超详细)

需要源码和数据集请点赞关注收藏后评论区留言私信~~~ 划分聚类、密度聚类和模型聚类是比较有代表性的三种聚类思路 1&#xff1a;划分聚类 划分&#xff08;Partitioning&#xff09;聚类是基于距离的&#xff0c;它的基本思想是使簇内的点距离尽量近、簇间的点距离尽量远。k…

UOS SDN

​ 文章目录 一.安装相关软件包二.上传并解压opendaylight软件包三.创建拓扑四.下发流表五.启动HTTP-server服务六.截图测试启动 OpenDayLight 的 karaf 程序,并安装如下组件: feature:install odl-restconf feature:install odl-l2switch-switch-ui feature:install odl-…

关于torch.fx的使用

torch.fx 前言 最近在学习一些AI编译器&#xff0c;推理框架的知识&#xff0c;恰好看到了torch.fx这个部分。这个其实在1.10就已经出来了&#xff0c;但是一直不知道&#xff0c;所以花了一点时间学习了这部分的内容。 以下所有的代码基于Mac M1 pytorch 1.13&#xff0c;其…

JavaScript(六):数组

JavaScript数组数组的创建方式数组的索引&#xff08;不使用内置方法&#xff09;数组的遍历数组中新增元素&#xff08;不使用内置方法&#xff09;数组的检测数组的方法数组的创建方式 1.利用new创建数组 var 数组名 new Array(); 例如&#xff1a; var arr new Array();…

一句话生成角色动画 # text2motion

‍‍‍‍当你和他人谈论人工智能的潜力时&#xff0c;很多人都表露出同样的担心&#xff1a;害怕被取代‍特别在最近几个月&#xff0c;随着生成式人工智能的投资和创新的爆炸性增长&#xff0c;这些不安的感觉更加强烈。机器学习中相对较新的创新&#xff0c;即扩散模型&#…

干货 | 轮廓逼近原理与OpenCV应用(附Python-OpenCV文档下载)

导 读 本文主要介绍轮廓逼近的原理及其在OpenCV中的使用演示。同时可在文末获取Python-OpenCV学习文档pdf。 背景介绍 轮廓逼近的应用比较广泛,如下路线俯视图的简化: 通过迭代平滑一些顶点,从而产出更加线性的路线: 当然这只是轮廓逼近的其中一个应用,后续我们将…

nodejs企业工厂设备维修管理系统vue

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 web简介 4 2.3 B/S结构 4 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;技术背景 5 …

【Linux权限】文件权限值,权限掩码,粘滞位,普通用户添加信任名单

目录 1.权限分为2种用户&#xff1a;超级用户&#xff0c;普通用户 2.文件类型和访问权限 ​3.权限掩码&#xff08;八进制&#xff09; 4.sudo短暂提升权限 5.粘滞位 1.权限分为2种用户&#xff1a;超级用户&#xff0c;普通用户 超级用户&#xff08;通常为root&#x…

【前端开发学习】5.JQuery

文章目录1 JQuery2 快速上手3 寻找标签3.1 直接寻找3.2 间接寻找案例&#xff1a;菜单转换4 操作样式5 值的操作案例&#xff1a;动态创建数据库6 事件案例&#xff1a;表格操作7 前端整合案例1 JQuery 一个 JavaScript 的第三方模块&#xff08;第三方类库&#xff09;。 基…

再学C语言7:数据类型(3)——char类型

char类型用于存储字母和标点符号之类的字符 在技术实现上&#xff0c;char是整数类型&#xff0c;因为char类型实际存储的是整数而不是字符 为了处理字符&#xff0c;计算机使用一种数字编码&#xff0c;用特定的整数表示特定的字符 经典和常用的是ASCII码&#xff0c;标准A…

React学习29(react-redux最终完整版)

说明 1&#xff09;所有变量名字要规范&#xff0c;尽量触发对象的简写形式 2&#xff09;reducers文件夹中&#xff0c;编写index.js专门用于汇总并暴露所有的reducer 项目结构 代码示例 index.js import React from react import ReactDOM from react-dom import App fr…

ios 证书与签名

证书与签名 XCode中配置的Code Signing Identity&#xff08;entitlements、certificate&#xff09;必须与Provisioning Profile匹配&#xff0c;并且配置的Certificate必须在本机Keychain Access中存在对应Public&#xff0f;Private Key Pair&#xff0c;否则编译会报错。 X…

Improved Techniques for Training Score-Based Generative Models论文阅读

论文链接&#xff1a;Improved Techniques for Training Score-Based Generative Models 文章目录摘要引言背景郎之万动力学基于分数的生成模型选择噪声尺度初始的噪声尺度其它噪声等级结合噪音信息配置退火朗之万动力学EMA改善稳定性组合所有技巧定量结果消融研究更高分辨率结…