五、Flask学习之MySQL

news2024/9/28 23:23:00

五、Flask学习之MySQL

1. 下载MySQL

下载教程:MySQL安装及可视化工具SQLyog下载

2.常用指令

2.1. 查看已有数据库

show databases;

在这里插入图片描述

2.2. 创建数据库

create database 名字 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

在这里插入图片描述

2.3. 删除数据库

drop database 名字;

在这里插入图片描述

2.4. 进入数据库

USE 名字;

在这里插入图片描述

2.5. 查看当前数据库下所有数据

show tables;

在这里插入图片描述

2.6. 创建数据表

数据表类似于Excel表格,有列名和类型

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

假设我要创建的表格为:

idNameage

那么就使用下面的代码:

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

在这里插入图片描述

然后运行show tables就能看到是否创建成功数据表了。

如果要求输入数据时某一列不能为空,那么就需要使用not null

create table info1(
    id int not null, -- 不能为空
    name varchar(16), -- 默认是可以为空的
    age int
)default charset=utf8;

也可以给某一列设置默认值,如果没有传入值,就使用默认值,如果传入值就使用传入的值

create table info1(
    id int, 
    name varchar(16),
    age int default 3 -- 设置默认值为3
)default charset=utf8;

也可以在创建表的时候设置主键:主键不允许重复

id int primary key, 

或者直接按照序号1.2.3…,内部维护:

id int auto_increament primary key, 

2.7. 删除数据表

删除数据表使用:

drop table 数据表名字;

在这里插入图片描述

2.8. 查看表结构

desc 表名称;
mysql> desc info1;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| id    | int(11)     | NO   | PRI | NULL    | auto_increment |
| name  | varchar(16) | YES  |     | NULL    |                |
| age   | int(11)     | YES  |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
3 rows in set (0.01 sec)

2.9. 添加数据

insert into 表名(列名1,列名2) values(数据1,数据2);
insert into 表名(列名1,列名2) values(数据1,数据2),(数据3,数据4); -- 批量添加
mysql> insert into info1(name,age) values("panda",20);
Query OK, 1 row affected (0.02 sec)

mysql> insert into info1(name,age) values("panda01",21),("panda02",22);
Query OK, 2 rows affected (0.01 sec)
Records: 2  Duplicates: 0  Warnings: 0

2.10. 查看表

select * from 表名;
mysql> select * from info1;
+----+---------+------+
| id | name    | age  |
+----+---------+------+
|  1 | panda   |   20 |
|  2 | panda01 |   21 |
|  3 | panda02 |   22 |
+----+---------+------+
3 rows in set (0.00 sec)

3.常用数据类型

3.1. 整数

tinyint:用来存储比较小的整数
有符号范围:-128~127(默认)
无符号范围:0-255

int:用来存储一般的整数
有符号范围:-231~231-1(默认)
无符号范围:0-232-1

bigint:用来存储比较大的整数
有符号范围:-263~263-1(默认)
无符号范围:0-264-1

3.2. 小数

floatdouble用于存储小数,但是不精准,所以存储小数的时候一般用的是decimal

create table info2(
    id int not null primary key auto_increment,
    salary decimal(m,n) -- m是指传入数据的最大位数,n是指保留小数的位数,我这里假设m=3,n=2
)default charset=uft8;

insert into info2(salary) values(3.14); -- 没问题,不报错
insert into info2(salary) values(3.146); -- 超过设置的小数位数会四舍五入
insert into info2(salary) values(323.14); -- 有问题,会报错,超过最大位数了

3.3. 字符串

  • char

    定长字符串,例如char(6)是指固定用6位来存储,如果输入的位数小于6位,也会按照六位去存储;

  • varchar

    变长字符串,例如varchar(6)是指按照传入多少位就存储多少位的规则,但是不能超过括号里的数(6);

  • text

    用于保存长文本,最多保存216-1个字符;

  • mediumtext

    最多保存224-1个字符;

  • longtext

    最多保存232-1个字符;

3.4. 时间

  • datetime:比较精准,年月日时分秒
  • date:只有年月日

4.数据表的增删改查

4.1. 增

insert into 表名(列名1,列名2) values(数据1,数据2);
insert into 表名(列名1,列名2) values(数据1,数据2),(数据3,数据4); -- 批量添加

创建一个表格:

create table info2(
    id int not null primary key auto_increment,
    name varchar(16),
    birth date,
    grade decimal(5,2)
);

插入数据:

insert into info2(name,birth,grade) values("小明","2002-3-2",98.66);
insert into info2(name,birth,grade) values("小赵","2003-4-1",99.99);
insert into info2(name,birth,grade) values("小张","2004-5-7",89.34);
insert into info2(name,birth,grade) values("小秦","2003-6-6",96.7);
insert into info2(name,birth,grade) values("大白","2002-4-15",95.9);

执行命令:

select * from info2;

效果:

mysql> select * from info2;
+----+------+------------+-------+
| id | name | birth      | grade |
+----+------+------------+-------+
|  1 | 小明 | 2002-03-02 | 98.66 |
|  2 | 小赵 | 2003-04-01 | 99.99 |
|  3 | 小张 | 2004-05-07 | 89.34 |
|  4 | 小秦 | 2003-06-06 | 96.70 |
|  5 | 大白 | 2002-04-15 | 95.90 |
+----+------+------------+-------+
5 rows in set (0.01 sec)

4.2. 删

delete from info2; -- 删除数据表info2中所有数据
delete from info2 where id=1; -- 删除数据表info2中id=1的数据
delete from info2 where id<3; -- 删除数据表info2中id<3的数据
-- 删除数据表info2中name="小明" 并且grade=98.66的数据
delete from info2 where name="小明" and grade=98.66; 

4.3. 改

update info2 set grade=100; -- 修改数据表info2中列grade的数据为100
update info2 set grade=100 where 条件; -- 修改数据表info2中满足条件的列grade的数据为100

4.4. 查

select * from 表名称;-- 查询数据表中所有的数据
select 列名,列名 from 表名称;-- 查询数据表中特定列名的数据
select 列名,列名 from 表名称 where 条件;-- 查询数据表中符合条件的特定列名的数据

5.使用Python语句操作数据库

5.1. 创建数据

创建数据库:

create database demo DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
use demo;

创建数据表:

create table info(
    id int not null primary key auto_increment,
    name varchar(16) not null,
    passwd varchar(64) not null,
    mobile char(11) not null
)default charset=utf8;

5.2. 使用python连接数据库

使用命令下载相关模块:

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple pymysql==1.0.2
import pymysql

# 1.连接mysql
conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", charset="utf8", passwd="123456", db="demo") # 这里的passwd和db要换成你自己密码和数据库
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

5.3. 添加数据

# 2.发送指令
cursor.execute("insert into info(name,passwd,mobile) values('panda','123465','12345678911') ")
conn.commit()  # 提交指令

如果使用Pycharm可能会标红显示错误,不用管,直接运行即可

检查数据表是否添加上了:

mysql> select * from info;
+----+-------+--------+-------------+
| id | name  | passwd | mobile      |
+----+-------+--------+-------------+
|  1 | panda | 123465 | 12345678911 |
+----+-------+--------+-------------+
1 row in set (0.00 sec)

格式化输入

上面的形式是比较死板的,如果你想使用格式化字符串的方法,不能使用Python自己的方法,而是要使用pymysql自带:

列表形式:

# 列表形式
sql = "insert into info(name, passwd, mobile) values(%s, %s, %s)"
my_list = ["小明", "qwe789", "11111111111"]
cursor.execute(sql, my_list)
conn.commit()  # 提交指令

数据已添加上:

mysql> select * from info;
+----+-------+--------+-------------+
| id | name  | passwd | mobile      |
+----+-------+--------+-------------+
|  1 | panda | 123465 | 12345678911 |
|  2 | 小明  | qwe789 | 11111111111 |
+----+-------+--------+----

字典形式:

# 字典形式
sql = "insert into info(name, passwd, mobile) values(%(name)s, %(passwd)s, %(mobile)s)"
data = {"name": "小李", "passwd": "pythonmysql", "mobile": "22222222222"}
cursor.execute(sql, data)
conn.commit()  # 提交指令

数据已添加上:

mysql> select * from info;
+----+-------+-------------+-------------+
| id | name  | passwd      | mobile      |
+----+-------+-------------+-------------+
|  1 | panda | 123465      | 12345678911 |
|  2 | 小明  | qwe789      | 11111111111 |
|  3 | 小李  | pythonmysql | 22222222222 |
+----+-------+-------------+-------------+
3 rows in set (0.00 sec)

5.4. 关闭连接

前面连接成功了,但是在文件运行结束之前要关闭连接

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

5.5. 第一个小案例

结合上述知识,可以让用户自定义输入:

import pymysql

while True:
    username = input("请输入用户名:")
    if username.upper() == "Q":
        break
    passwd = input("请输入密码:")
    mobile = input("请输入电话:")
    # 1.连接mysql
    conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", charset="utf8", passwd="4636996", db="demo")
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    # 2.发送指令
    # 列表形式
    sql = "insert into info(name, passwd, mobile) values(%s, %s, %s)"
    my_list = [username, passwd, mobile]
    cursor.execute(sql, my_list)

    conn.commit()  # 提交指令
    # 3.关闭连接
    conn.close()
    cursor.close()

在这里插入图片描述

然后查询表格,发现已添加上:

mysql> select * from info;
+----+-------+-------------+-------------+
| id | name  | passwd      | mobile      |
+----+-------+-------------+-------------+
|  1 | panda | 123465      | 12345678911 |
|  2 | 小明  | qwe789      | 11111111111 |
|  3 | 小李  | pythonmysql | 22222222222 |
|  4 | 小C   | 123456      | 33333333333 |
|  5 | 小S   | 456798      | 44444444444 |
+----+-------+-------------+-------------+
5 rows in set (0.00 sec)

5.6. 查询数据

import pymysql

# 1.连接mysql
conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="4636996", charset="utf8", db="demo")
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
# 2.发送指令
# cursor.execute("insert into info(name,passwd,mobile) values('panda','123465','12345678911')")

# 列表形式
sql = "select * from info"
cursor.execute(sql)
# 获取返还的数据
my_list = cursor.fetchall()
for each in my_list:
    print(each)
# 3.关闭连接
conn.close()
cursor.close()

得到:

{'id': 1, 'name': 'panda', 'passwd': '123465', 'mobile': '12345678911'}
{'id': 2, 'name': '小明', 'passwd': 'qwe789', 'mobile': '11111111111'}
{'id': 3, 'name': '小李', 'passwd': 'pythonmysql', 'mobile': '22222222222'}
{'id': 4, 'name': '小C', 'passwd': '123456', 'mobile': '33333333333'}
{'id': 5, 'name': '小S', 'passwd': '456798', 'mobile': '44444444444'}

5.7 删除数据

import pymysql

# 1.连接mysql
conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="4636996", charset="utf8", db="demo")
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
# 2.发送指令
# cursor.execute("insert into info(name,passwd,mobile) values('panda','123465','12345678911')")

# 列表形式
cursor.execute("delete from info where id=%s",[5])
conn.commit()

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

查询数据库数据得知已被删除:

mysql> select * from info;
+----+-------+-------------+-------------+
| id | name  | passwd      | mobile      |
+----+-------+-------------+-------------+
|  1 | panda | 123465      | 12345678911 |
|  2 | 小明  | qwe789      | 11111111111 |
|  3 | 小李  | pythonmysql | 22222222222 |
|  4 | 小C   | 123456      | 33333333333 |
+----+-------+-------------+-------------+
4 rows in set (0.00 sec)

5.8. 修改数据

import pymysql

# 1.连接mysql
conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="4636996", charset="utf8", db="demo")
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
# 2.发送指令
# cursor.execute("insert into info(name,passwd,mobile) values('panda','123465','12345678911')")

# 列表形式
cursor.execute("update info set mobile='99999999999' where mobile=%s", ["22222222222"])
conn.commit()

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

查询数据库数据得知已被修改:

mysql> select * from info;
+----+-------+-------------+-------------+
| id | name  | passwd      | mobile      |
+----+-------+-------------+-------------+
|  1 | panda | 123465      | 12345678911 |
|  2 | 小明  | qwe789      | 11111111111 |
|  3 | 小李  | pythonmysql | 99999999999 |
|  4 | 小C   | 123456      | 33333333333 |
+----+-------+-------------+-------------+
4 rows in set (0.00 sec)

6.Flask+前端+MySQL案例

MySQL数据库使用的是上面的demo下的info表

项目的目录结构:

在这里插入图片描述

app.py完整代码:(把数据库的密码设置成你自己的)

from flask import Flask, render_template, request
import pymysql

app = Flask(__name__)


@app.route('/add/user', methods=['POST', 'GET'])
def add_user():
    if request.method == 'GET':
        return render_template("add_user.html")
    else:
        # 接收数据
        name = request.form.get("username")
        passwd = request.form.get("passwd")
        mobile = request.form.get("mobile")
        # 与数据库建立连接
        conn = pymysql.connect(host="127.0.0.1", user="root", passwd="123456", db="demo", charset="utf8", port=3306)
        cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
        # 添加数据
        sql = "insert into info(name,passwd,mobile) values(%s,%s,%s)"
        data_list = [name, passwd, mobile]
        cursor.execute(sql, data_list)
        conn.commit()
        # 关闭连接
        conn.close()
        cursor.close()
        return "添加成功"


@app.route('/show/user')
def show_user():
    # 与数据库建立连接
    conn = pymysql.connect(host="127.0.0.1", user="root", passwd="123456", db="demo", charset="utf8", port=3306)
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    # 查询数据
    sql = "select * from info"
    cursor.execute(sql)
    data_list = cursor.fetchall()
    # 关闭连接
    conn.close()
    cursor.close()
    return render_template("show_user.html", data_list=data_list)


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

用户注册界面add_user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>注册</title>
</head>
<body>
<h1>注册</h1>
<div>
    <form method="post" action="/add/user">
        <label>
            用户名:<input type="text" name="username" placeholder="请输入用户名......">
            密码:<input type="password" name="passwd" placeholder="请输入密码......">
            手机号:<input type="text" name="mobile" placeholder="请输入手机号......">
        </label>
        <input type="submit" value="提 交">
    </form>
</div>
</body>
</html>

效果:

在这里插入图片描述

查询用户列表界面show_user.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <!--替换为自己的BootSrap路径-->
    <link rel="stylesheet" href="/static/plugins/bootstrap-3.4.1-dist/css/bootstrap.css">
</head>
<body>
<div class="container">
    <h1 style="text-align: center">
        用户列表
    </h1>
    <div style="margin-top: 50px">
        <table class="table table-bordered">
            <thead>
            <tr>
                <td>序号</td>
                <td>用户名</td>
                <td>密码</td>
                <td>手机号</td>
            </tr>
            </thead>
            <tbody>
            {% for each in data_list %}
            <tr>
                <td>{{each.id}}</td>
                <td>{{each.name}}</td>
                <td>{{each.passwd}}</td>
                <td>{{each.mobile}}</td>
            </tr>
            {% endfor%}
            </tbody>
        </table>
    </div>
</div>
<!--替换为自己的BootSrap里JS路径-->
<script src="/static/plugins/bootstrap-3.4.1-dist/js/bootstrap.js"></script>
<!--替换为自己的JS路径-->
<script src="/static/js/jquery-3.7.1.min.js"></script>
</body>
</html>

效果:

在这里插入图片描述

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

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

相关文章

计算机毕业设计 | SSM 凌云招聘平台(附源码)

1&#xff0c;绪论 人力资源是企业产生效益、创造利润的必不可少的、最重要的资源。人作为人力资源的个体可看作是一个承载着有效知识、能力的信息单元。这样的信息单元可看作是一个为企业产生价值和利润的个体。从而使得这样的信息单元所具有的信息就是一个有价值的信息。 校…

stripped文件描述以及gdb反汇编工具使用

往期地址&#xff1a; 操作系统系列一 —— 操作系统概述操作系统系列二 —— 进程操作系统系列三 —— 编译与链接关系操作系统系列四 —— 栈与函数调用关系操作系统系列五 —— 目标文件详解操作系统系列六 —— 详细解释【静态链接】操作系统系列七 —— 装载操作系统系列…

缓存问题 | 缓存穿透,缓存击穿,缓存雪崩

缓存穿透 关键字&#xff1a;强调缓存和数据库都没有数据并发访问 缓存穿透是指数据库和缓存都没有的数据&#xff0c;每次都要经过缓存去访问数据库&#xff0c;大量的请求有可能导致DB宕机。 应对策略&#xff1a; 使用布隆过滤器&#xff08;Bloom Filter&#xff09;&am…

PythonPDF编辑库之pypdf使用详解

概要 PDF&#xff08;Portable Document Format&#xff09;是一种常见的文档格式&#xff0c;广泛用于存储和共享文本和图像数据。在 Python 中&#xff0c;有许多库可以用于处理 PDF 文件&#xff0c;其中之一就是 PyPDF。PyPDF 是一个功能强大的库&#xff0c;它允许你读取…

RK3568平台 麦克风PDM接口录音

一.PDM接口简介 PDM Pulse Density Modulation是一种用数字信号表示模拟信号的调制方法。 PDM则使用远高于PCM采样率的时钟采样调制模拟分量&#xff0c;只有1位输出&#xff0c;要么为0&#xff0c;要么为1。因此通过PDM方式表示的数字音频也被称为Oversampled 1-bit Audio…

Leetcode—145. 二叉树的后序遍历【简单】

2023每日刷题&#xff08;九十七&#xff09; Leetcode—145. 二叉树的后序遍历 实现代码 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr…

Go、容器以及Linux调度器

在容器中运行Go应用程序时&#xff0c;需要设置合理的GOMAXPROCS&#xff0c;从而避免调度中因为资源不足而造成STW。原文: Go, Containers, and the Linux Scheduler Go开发的应用程序通常部署在容器中。在容器中运行时&#xff0c;重要的一点是要设置CPU限制以确保容器不会耗…

十款数据可视化工具横评:优缺点大揭秘

作为一位热衷于数据可视化的爱好者&#xff0c;我深知选择一款得心应手的数据可视化工具对于呈现数据的魅力至关重要。在市面上众多的数据可视化工具中&#xff0c;我精选了十款备受瞩目的产品&#xff0c;下面就为大家简单介绍一下它们的优缺点&#xff0c;以帮助大家进行选择…

Windows下载安装并启动 Elasticsearch(ES)

我们先访问官网链接 https://www.elastic.co/cn/downloads/elasticsearch 进入官网后 Choose platform 选择我们自己的电脑系统 我这里是 Windows 然后 点击如下图 箭头指向的这个下载按钮 它就开始下了 这个文件还是偏大的 然后 这里 我创建一个目录 专门用来装它 然后 我…

SD342X-16Q双偏心软密封蝶阀的选型技巧分享

SD342X-16Q双偏心软密封蝶阀的选型技巧分享 选择SD342X-16Q双偏心软密封蝶阀软密封蝶阀时&#xff0c;需要考虑以下几个事项&#xff1a; 1.流体性质&#xff1a; 了解流体的压力、温度、粘度等特性&#xff0c;选择适合的软密封材料。不同材料对于不同流体具有不同的耐腐蚀性…

mac滚动截图

参考博客 https://www.zhihu.com/question/313673726/answer/2938671835 首先去AppStore搜索 iShot 这个也是要钱的&#xff0c;不过我输入appleID后&#xff0c;并没有扣我钱&#xff0c;不知道设么回事 然后打开iShot 点击观看视频&#xff0c;然后mac会自动打开一个新的…

OpenAI 降低价格并修复拒绝工作的“懒惰”GPT-4,另外ChatGPT 新增了两个小功能

OpenAI降低了GPT-3.5 Turbo模型的API访问价格&#xff0c;输入和输出价格分别降低了50%和25%。这对于使用API进行文本密集型应用程序的用户来说是一个好消息。 OpenAI官网&#xff1a;OpenAI AIGC专区&#xff1a;aigc 教程专区&#xff1a;AI绘画&#xff0c;AI视频&#x…

【HarmonyOS应用开发】TypeScript快速入门(二)

内容比较长&#xff0c;干货满满&#xff0c;全是实战操作内容&#xff0c;希望耐心观看&#xff0c;如果对你有所帮助&#xff0c;请点个赞&#xff01; ArkTS是HarmonyOS优选的主力应用开发语言。它在TypeScript&#xff08;简称TS&#xff09;的基础上&#xff0c;匹配ArkUI…

CSDN年度报告图片卡通小人收集

摘要&#xff1a;CSDN推出的年度报告真的太赞了&#xff0c;还定制了诸如“情感的编织者”“敏锐的激励者”“灵感的捕捉者”“组织的表达者”“洞悉的指挥家”“心灵的领航员”“生动的记录者”“温暖的叙述者”“理性的探索者”等等精准且浪漫的标签&#xff0c;加上非常有灵…

嵌入式linux学习之实践操作

​ 前沿 1. 安装交叉编译器 在开发板光盘 A-基础资料->5、开发工具->1、交叉编译器路径下找到 st-example-image-qt wayland-openstlinux-weston-stm32mp1-x86_64-toolchain-3.1-snapshot.sh。将它拷贝到 Ubuntu 虚拟机上。 拷贝到 Ubuntu 后&#xff0c;赋予 st-exam…

快速搭建一个基于MVC架构的Spring Boot应用

提示&#xff1a;如果对 MVC 架构模式不熟悉可以看我的博客 > MVC架构模式与三层架构 快速搭建一个基于MVC架构的Spring Boot应用 一、Web 服务二、快速构建一个Spring Web MVC的 Web 应用1.使用脚手架快速的搭建环境&#xff1a;2.准备数据库&#xff1a;3.编写Dao层访问数…

Vue3在css中使用v-bind绑定js/ts变量,也可以在scss和less中使用方式

主要介绍Vue3中的新增的v-bind()的常用使用方式&#xff0c;主要包括在css,less,scss中的使用&#xff0c;可以参考官方文档查看&#xff1a;Vue3官方文档 特别提醒 如果你想在scss中或者less中使用&#xff0c;可能会报各种乱七八糟的错误&#xff0c;最快最好用的方式就是单…

远程git开发

两种本地与远程仓库同步 """ 1&#xff09;你作为项目仓库初始化人员&#xff1a;线上要创建空仓库 > 本地初始化好仓库 > 建立remote链接(remote add) > 提交本地仓库到远程(push)2&#xff09;你作为项目后期开发人员&#xff1a;远程项目仓库已经创…

Github 2024-01-27 开源项目日报 Top10

根据Github Trendings的统计&#xff0c;今日(2024-01-27统计)共有10个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Python项目3Jupyter Notebook项目2非开发语言项目2JavaScript项目1Go项目1Rust项目1Shell项目1 Papers We Lo…

IDC机房交换机核心技术与应用指南

IDC机房交换机核心技术与应用指南 ​ 在这个快速发展的数字时代&#xff0c;数据中心作为信息技术的心脏&#xff0c;不仅承载着海量数据的处理、存储和传输&#xff0c;更是支撑着全球企业运营和互联网服务的关键基础设施。在众多构成数据中心的组件中&#xff0c;IDC机房交换…