MySQL其一,概念学习,可视化软件安装以及增删改查语句

目录

MySQL

1、数据库的概念

2、数据库分类

3、MySQL的安装

4、安装过程中的问题

DataGrip的使用:

SQLynx的使用:

5、编写SQL语句

6、DDL语句

7、DML

新增数据:

删除数据:

修改数据:


MySQL

SQL其实是一门开发语言。

大数据为啥要学习SQL语句?大数据起步比较晚。

起步晚,要流行:1)方便使用 2)简单易学 学习成本小

我们所有的大数据组件,每个组件都有自己的用法。想使用大数据,要求会SQL即可。能够吸引大批老的程序员使用新技术。

数据库:SQL语句

Hadoop(Hive): 类似的SQL语句

Spark : Spark SQL

Flink : Flink SQL

数仓学科: Python语言(打个基础)

1、数据库的概念

DB: 数据库的意思,其实本质上就是文本文件而已。我们一般无法察觉,也查看不了,原因是安全性。

数据库管理系统(DataBase Management System,DBMS):文件文件就是数据库的本质,数据库管理系统其实就是用来管理数据文本内容的工具(软件)而已。

数据库管理系统就i是一套软件而已,别人开发出来供我们使用的。

Java : API (开发帮助文档)

2、数据库分类

两大派(华山派 -- 剑宗和 气宗 ):关系型数据 和 非关系型数据库

关系型数据库:主流

MySQL:免费的,以前是SUN公司,后来Oracle 一个表500万数据的时候开始考虑性能问题

Oracle: Oracle 收费的,软件贼大,安全型贼好。 一般政府部门,银行系统。互联网公司都在去O。

MS Server: 微软的

DB2 : IBM的

Access : 微软出来的。小垃圾 其实就是一个excel表格。

非关系型数据库

互联网发达起来

  • HBase是一个分布式的、面向列的开源数据库 上亿行,百万列
  • MongoDB是一个基于分布式文件存储的数据库 H5
  • Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API 每个公司都在用。是基于内存的数据库。

非关系型书库的出现不是为了革命,而是辅助。

什么是关系型数据库呢?

通过行和列存储数据,这样设计出来的数据库都是关系型数据库。

3、MySQL的安装

SQL和数据库的关系?

SQL是一种语言,标准语言。

mysql、oracle 都可以编写和执行sql。

官方了两种安装包:

Oracle: 1G
MS Server:  特别大

数据库的密码: 统一 123456

mysql8.0 它底层进行了优化,同样的sql语句,在mysql8.0 比 mysql5.x 运行速度快。

4、安装过程中的问题

版本要注意:mysql 5.5 和 5.7 特别多

我们现在用的是mysql 8.0版本,他们之间存在一定的兼容问题。

假如你有一个新的电脑:安装软件的时候,比如jdk、mysql、idea等跟工作相关的软件安装C盘。

这些软件是数据库的Server端。 服务器端是不要钱。

安装玩之后,可以使用黑窗口操作。

进入bin之后,输入cmd

登录进去后,就可以编写sql了。

展示所有数据库
show databases;

黑窗口编写SQL语句太费劲了,如果有可视化的软件就好了:

软件购买

远程连接:

可以连接本地和远程,比如同桌的数据库

点击"测试连接" 看是否连接成功!

    原因是Navicat 12版本,连接高版本的数据库,使用的密码校验机制跟 mysql8.0 的机制有不一样的地方。

人工修复一下这个Bug:

ALTER USER 'root'@'localhost' IDENTIFIED BY 'root' PASSWORD EXPIRE NEVER;//更新一下用户的密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'root';//刷新权限
FLUSH PRIVILEGES;alter user 'root'@'localhost' identified by 'root';

如何使用Navicat编写命令:

F6 或者 Fn + F6

远程连接工具都有哪些?

Navicat 、 SQLYog 、DataGrip

粘贴激活码即可。

DataGrip的使用:

先创建项目:起个英文名

添加数据源mysql:

选择mysql:

SQLynx的使用:

无需安装,解压即用。

该客户端的优点:1)支持国产的一些数据库 2)运行速度比较快(导入导出)

5、编写SQL语句

1) SQL语句的分类

SQL: Structure Query Language(结构化查询语言),SQL最早是被美国国家标准局(ANSI)确定为关系型数据库语言的美国标准。后来被国际化标准组织(ISO)采纳为关系型数据库语言的国际标准。

国家的统一的语言:普通话 各个地方都有方言。每一个数据库都有方言。方言就是独自。

  • DDL(Data Definition Language):数据定义语言,用来定义数据库对象(数据库、表、列)

创建一个数据库、创建表、添加字段等

  • DML(Data Manipulation Language):数据操作语言,用于定义数据库记录(数据)

数据的新增、修改、删除

  • DQL(Data Query Language):数据查询语言,用于查询记录(数据)

专门针对数据的查询的

  • TCL(Transaction Control Language):事务控制语言,DCL(Data Control Language):数据控制语言,用于定义访问权限和安全级别

控制事务、添加用户、赋予权限、修改密码等。

6、DDL语句

数据库的操作:

展示所有的数据库
show databases;
# 创建数据库
CREATE DATABASE mydb01;
# 创建数据库,并采用指定的字符集
CREATE DATABASE mydb02 CHARACTER SET UTF8;
utf8字符集是可以支持中文的,非常的方便。查看数据库(了解)
# 查看创建数据库mydb1定义的信息
SHOW CREATE DATABASE mydb01;
mysql> show create database mydb01;1 row in set (0.07 sec)mysql> alter database mydb01 character set gbk;
Query OK, 1 row affected (0.09 sec)mysql> show create database mydb01;# 将数据库mydb1的字符集修改为GBK
ALTER DATABASE mydb1 CHARACTER SET GBK;DROP DATABASE mydb1; (不重要)# 切换当前使用的数据库
USE mydb1; 
# 查询当前使用的数据库
SELECT DATABASE();查看mysql的版本:
select verion();

关于表的操作:

展示该数据库中的所有表:
show tables;创建一个表:
语法:
create table 表名( 字段一 数据类型(数据长度),.....);
实战:
create table stu (name varchar(255),phone varchar(11),age int(3));查看表结构:
desc stu;# 查看创建一个表的信息
SHOW CREATE TABLE t_users; #不常见在sql语句中 # 后面的语句不执行,代表注释
修改表的名字
alter table stu rename to student;
以下内容可以练习一遍即可:
# 给一张表添加一个字段
ALTER TABLE t_users ADD score DOUBLE(5,2);
# 修改一张表的字段类型
ALTER TABLE t_users MODIFY score INT;
# 修改一张表的字段名
ALTER TABLE t_users CHANGE name uname VARCHAR(50);
# 修改一张表的字符集
ALTER TABLE t_users CHARACTER SET GBK;修改表添加一个身高字段:
int 整数   1 2 3 4... 不能写1.11
double 小数 (5,2)  带小数为总共有5个长度,2 表示小数点后能存2位,所以整数为长度是3.double(5,2)  最大能表示到 999.99alter table student add height double(5,2);
# 删除一张表中的字段
ALTER TABLE t_users DROP score;表的删除:
drop table student ;-- 创建一个跟这个表一模一样的表结构
create table stu2  like stu;
-- 创建一个表,表结构跟另一个表一模一样,并且数据也跟它一模一样,类似于copy 某个表
create table stu3 as select * from stu;
-- ------------展示table的DDL语句------------------
-- 查看所有的表
show tables;
-- 创建一个表
create table stu01(id int(20),name varchar(20),age int(3)
);
-- 查看表结构
desc stu01;
describe stu01;
-- 修改表结构,不是修改表中的数据
-- 重命名
alter table stu01 rename to student;desc student;
-- 添加列
alter table student add score double(5,2);
-- 修改一个列的数据类型
alter table student modify score int(3);
-- 修改字段的名字
alter table student change name sname varchar(30);
-- 修改一张表的字符集
alter table student character set utf8;
show create table student;
-- 删除一个字段
alter table student drop score;
-- 新建一个表,该表的表字段跟student 一模一样
create table stu like student;
desc stu;
-- 创建一个表,表结构和数据都跟你一模一样
create table stu2 as select * from student;
-- 删除表
drop table student;
DDL语句:数据库的新增修改删除查看。表的新增修改删除查看表字段的新增修改删除查看(已经涵盖在了表的修改操作中了)

假如 编写sql语句 回车代表换行,不代表执行,一个sql语句见 ; 表示写完了。

建表语句中,经常出现字段的类型:

比如 age 年龄 数据类型 数字表示 int

常见的数据类型:

数据类型

类型描述

示例

int

整型,整数类型

double

浮点型

double(5,2): 表示最多有5位,其中必须有两位数小数,即最大值是999.99

char

固定长度的字符串

char(5): 固定5位字符,即'aa'也占用5位字符

varchar

可变长度的字符串

varchar(5): 可以根据内容动态分配空间,'aa'只占用两位。括号里的5表示最大的位数。

text

字符串类型

blob

字节类型

很少用的,一般存在 比如 音乐,图片

date

日期类型

yyyy-MM-dd

time

时间类型

hh:mm:ss

timestamp

时间戳类型

yyyy-MM-dd hh:mm:ss,会自动赋值

datetime

时间类型

yyyy-MM-dd hh:mm:ss

作业:字段类型 5遍
其实特别简单: 记住 int  varchar 就可以了。

DDL语句都可以使用图形化界面解决(练习练习即可!)

图形化界面操作(必须掌握):

7、DML

DML指的是对数据库中的数据进行增、删、改的操作。不要和DDL搞混了。

新增数据:

语法-- 必须遵循的法则

INSERT INTO 表名(列名1,列名2 ...)VALUES(列值1,列值2...);注意:列名与列值的类型、个数、顺序要一一对应。

mysql> use mydb03;
Database changed
mysql> show tables;
+------------------+
| Tables_in_mydb03 |
+------------------+
| stu              |
+------------------+
1 row in set (0.08 sec)mysql> desc stu;
+--------+--------------+------+-----+---------+-------+
| Field  | Type         | Null | Key | Default | Extra |
+--------+--------------+------+-----+---------+-------+
| name   | varchar(255) | YES  |     | NULL    |       |
| age    | int(11)      | YES  |     | NULL    |       |
| height | double(5,2)  | YES  |     | NULL    |       |
+--------+--------------+------+-----+---------+-------+
3 rows in set (0.12 sec)mysql> insert into stu(name,age,height) values('zhangsan',22,190.9);
Query OK, 1 row affected (0.07 sec)mysql> insert into stu(name,age,height) values('lisi',23,180);
Query OK, 1 row affected (0.11 sec)mysql> select * from stu;  # 该语句是查询语句,表示查询stu中所有的数据
+----------+-----+--------+
| name     | age | height |
+----------+-----+--------+
| zhangsan |  22 | 190.90 |
| lisi     |  23 | 180.00 |
+----------+-----+--------+
2 rows in set (0.08 sec)# insert into 表名  如果表名后面不添加任何的字段名,就是向所有字段插入值。
mysql> insert into stu values('wangwu',24,175);
Query OK, 1 row affected (0.06 sec)mysql> select * from stu;
+----------+-----+--------+
| name     | age | height |
+----------+-----+--------+
| zhangsan |  22 | 190.90 |
| lisi     |  23 | 180.00 |
| wangwu   |  24 | 175.00 |
+----------+-----+--------+
3 rows in set (0.09 sec)
# insert into 表名  如果表名后面添加字段名,说明想向这个字段设置值,其他字段不管了。
mysql> insert into stu(name) values('zhaoliu');
Query OK, 1 row affected (0.09 sec)mysql> select * from stu;
+----------+------+--------+
| name     | age  | height |
+----------+------+--------+
| zhangsan |   22 | 190.90 |
| lisi     |   23 | 180.00 |
| wangwu   |   24 | 175.00 |
| zhaoliu  | NULL | NULL   |
+----------+------+--------+null 就是空的意思,没有任何值,不是 0 也不是 '' desc stu;
insert into stu(id,sname,age) values(1,'zhangsan',20);
select * from stu;
insert into stu values(2,'lisi',20);
insert into stu(id,sname) values(3,'王五');
insert into stu(id,sname) values (4,'sisi'),(5,'五仁'),(6,'六子');

课下练习:

create table emp(id int,name varchar(100),gender varchar(10),birthday date,salary double(10,2),entry_date date,resume text
);INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(1,'zhangsan','female','1990-5-10',10000,'2015-5-5','good girl');INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(2,'lisi','male','1995-5-10',10000,'2015-5-5','good boy');INSERT INTO emp(id,name,gender,birthday,salary,entry_date,resume)
VALUES(3,'你好','male','1995-5-10',10000,'2015-5-5','good boy');

创建一个新的表,跟stu表不一样

需求是:从stu中,查询数据导入到emp表中。

insert into emp(sname,sage,sheight)  select * from stu;mysql> insert into emp(sname,sage,sheight)  select * from stu;
Query OK, 4 rows affected (0.11 sec)
Records: 4  Duplicates: 0  Warnings: 0mysql> select * from emp;
+----------+------+---------+--------+
| sname    | sage | sheight | gender |
+----------+------+---------+--------+
| zhangsan |   22 |     191 | NULL   |
| lisi     |   23 |     180 | NULL   |
| wangwu   |   24 |     175 | NULL   |
| zhaoliu  | NULL | NULL    | NULL   |
+----------+------+---------+--------+
4 rows in set (0.07 sec)

stu

emp

name varchar

sname varchar

age int

sage int

height double

sheight double

select 语句查询出来的数量以及字段类型和顺序都必须 和 insert into 中表的字段数量、类型、顺序一样,跟表名字、表字段的名字没有半毛钱关系。
对比:
这个语句执行的时候必须有表
insert into 表名  select * from 表2这个语句执行的时候可以没有表,sql语句帮创建表
create table 表名 as select * from 表2

删除数据:

# 删除数据
DELETE FROM 表名;
# 删除掉表中所有的数据
TRUNCATE TABLE 表名;delete from stu where name='zhaoliu';
# where 后面可以添加条件,满足条件的删除掉
DELETE 和 TRUNCATE1. delete删除表中的数据,表结构还在;删除的数据可以恢复。
2. truncate是直接将表DROP掉,然后再按照原来的结构重新创建一张表。数据不可恢复。
3. truncate删除效率比delete高。

where条件:

如何造数据:

字段

解释

name

姓名

groupid

小组

score

成绩

# 删除姓名叫"张三"的数据
delete from student where name='张三';# 删除成绩不是100的数据
delete from student where score != 100;
delete from student where score <> 100;# 删除不及格的数据
delete from student where score < 60;
# 删除成绩在[60, 80]范围的数据
delete from student where score >= 60 and score <= 80;delete from student where score between 60 and 80;
# 删除小组是1,3,5的数据
delete from student where groupid = 1 or groupid = 3 or groupid =5;
delete from student where groupid in (1,3,5);
# 删除成绩是空的数据
delete from student where score is null;
# 删除成绩不及格的第三组的数据
delete from student where score < 60 and groupid = 3;# 删除姓张的数据
delete from student where name  like '张%';% 表示任意0个或者多个字符
# 删除名字中含有  伟 字的同学
delete from student where name  like '%伟%';

修改数据:

需求:只要这个同学姓张,就加10分
考虑语法:
UPDATE 表名 SET 列名1=列值1,列名2=列值2 。。。 WHERE 列名=值根据语法编写sql语句:
score = 10 是将 score 的数据重置为 10
update student set score = 10 where name like '张%';
修改为:
update student set score = score + 10 where name like '张%';
# 将所有员工薪水修改为5000元。
UPDATE emp SET salary=5000 # 将姓名为’zhangsan’的员工薪水修改为3000元。
UPDATE emp SET salary=3000 WHERE name=’ zhangsan’;# 将姓名为’lisi’的员工薪水修改为4000元,job改为ccc。
UPDATE emp SET salary=4000,job='ccc' WHERE name='lisi';# 将wu的薪水在原有基础上增加1000元。
UPDATE emp SET salary=salary+1000 WHERE name='wu';ifnull(字段名,默认值)
update stu set age = ifnull(age,0) + 1;

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

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

相关文章

05 在 Linux 使用 AXI DMA

DMA简介 DMA 是一种采用硬件实现存储器与存储器之间或存储器与外设之间直接进行高速数据传输的技术&#xff0c;传输过程无需 CPU 参与&#xff08;但是CPU需要提前配置传输规则&#xff09;&#xff0c;可以大大减轻 CPU 的负担。 DMA 存储传输的过程如下&#xff1a; CPU 向…

linux 安装 vsftpd 服务以及配置全攻略,vsftpd 虚拟多用户多目录配置,为每个用户配置不同的使用权限

linux 安装 vsftpd 服务以及配置全攻略&#xff0c;vsftpd 虚拟多用户多目录配置&#xff0c;为每个用户配置不同的使用权限。 linux 安装 vsftpd 服务以及配置全攻略 FTP 是 File Transfer Protocol 的简称&#xff0c;用于 Internet 上的控制文件的双向传输。同时&#xff0…

SQL语句在MySQL中如何执行

MySQL的基础架构 首先就是客户端&#xff0c;其次Server服务层&#xff0c;大多数MySQL的核心服务都在这一层&#xff0c;包括连接、分析、优化、缓存以及所有的内置函数&#xff08;时间、日期、加密函数&#xff09;&#xff0c;所有跨存储引擎功能都在这一层实现&#xff1…

ragflow连不上ollama的解决方案

由于前期wsl默认装在C盘&#xff0c;后期部署好RagFlow后C盘爆红&#xff0c;在连接ollama的时候一直在转圈圈&#xff0c;问其他人没有遇到这种情况&#xff0c;猜测是因为内存不足无法加载模型导致&#xff0c;今天重新在E盘安装wsl 使用wsl装Ubuntu Win11 wsl-安装教程 如…

C#常见错误—空对象错误

System.NullReferenceException&#xff1a;未将对象引用设置到对象的实例 在C#编程中&#xff0c;System.NullReferenceException是一个常见的运行时异常&#xff0c;其错误信息“未将对象引用设置到对象的实例”意味着代码试图访问一个未被初始化或已被设置为null的对象的成…

沁恒CH32V208蓝牙串口透传例程:修改透传的串口;UART-CH32V208-APP代码分析;APP-CH32V208-UART代码分析

从事嵌入式单片机的工作算是符合我个人兴趣爱好的,当面对一个新的芯片我即想把芯片尽快搞懂完成项目赚钱,也想着能够把自己遇到的坑和注意事项记录下来,即方便自己后面查阅也可以分享给大家,这是一种冲动,但是这个或许并不是原厂希望的,尽管这样有可能会牺牲一些时间也有哪天原…

Scala的隐式对象

Scala中&#xff0c;隐式对象&#xff08;implicit object&#xff09;是一种特殊的对象&#xff0c;它可以使得其成员&#xff08;如方法和值&#xff09;在特定的上下文中自动可用&#xff0c;而无需显式地传递它们。隐式对象通常与隐式参数和隐式转换一起使用&#xff0c;以…

矩阵的乘(包括乘方)和除

矩阵的乘分为两种&#xff1a; 一种是高等代数中对矩阵的乘的定义&#xff1a;可以去这里看看包含矩阵的乘。总的来说&#xff0c;若矩阵 A s ∗ n A_{s*n} As∗n​列数和矩阵 B n ∗ t B_{n*t} Bn∗t​的行数相等&#xff0c;则 A A A和 B B B可相乘&#xff0c;得到一个矩阵 …

DVWA亲测sql注入漏洞

LOW等级 我们先输入1 我们加上一个单引号&#xff0c;页面报错 我们看一下源代码&#xff1a; <?php if( isset( $_REQUEST[ Submit ] ) ) { // Get input $id $_REQUEST[ id ]; // Check database $query "SELECT first_name, last_name FROM users WHERE user_id …

机器学习01-发展历史

机器学习01-发展历史 文章目录 机器学习01-发展历史1-传统机器学习的发展进展1. 初始阶段&#xff1a;统计学习和模式识别2. 集成方法和核方法的兴起3. 特征工程和模型优化4. 大规模数据和分布式计算5. 自动化机器学习和特征选择总结 2-隐马尔科夫链为什么不能解决较长上下文问…

想了解操作系统,有什么书籍推荐?

推荐一本操作系统经典书&#xff1a; 操作系统导论 《操作系统导论》虚拟化(virtualization)、并发(concurrency)和持久性(persistence)。这是我们要学习的3个关键概念。通过学习这3个概念&#xff0c;我们将理解操作系统是如何工作的&#xff0c;包括它如何决定接下来哪个程序…

[Collection与数据结构] 位图与布隆过滤器

&#x1f338;个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 &#x1f3f5;️热门专栏: &#x1f9ca; Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 &#x1f355; Collection与…

微信小程序横屏页面跳转后,自定义navbar样式跑了?

文章目录 问题原因&#xff1a;解决方案&#xff1a; 今天刚遇到的问题&#xff0c;横屏的页面完成操作后跳转页面后&#xff0c;自定义的tabbar样式乱了&#xff0c;跑到最顶了&#xff0c;真机调试后发现navbar跑到手机状态栏了&#xff0c;它正常应该跟右边胶囊一行。 知道问…

Vivado ILA数据导出MATLAB分析

目录 ILA数据导出 分析方式一 分析方式二 有时候在系统调试时&#xff0c;数据在VIVADO窗口获取的信息有限&#xff0c;可结合MATLAB对已捕获的数据进行分析处理 ILA数据导出 选择信号&#xff0c;单击右键后&#xff0c;会有export ILA DATA选项&#xff0c;将其保存成CS…

《探索形象克隆:科技与未来的奇妙融合》

目录 一、什么是形象克隆 二、形象克隆的技术原理 三、形象克隆的发展现状 四、形象克隆的未来趋势 五、形象克隆的应用场景 六、形象克隆简单代码案例 Python 实现数字人形象克隆 Scratch 实现角色克隆效果&#xff08;以猫为例&#xff09; JavaScript 实现 Scratc…

MATLAB深度学习(七)——ResNet残差网络

一、ResNet网络 ResNet是深度残差网络的简称。其核心思想就是在&#xff0c;每两个网络层之间加入一个残差连接&#xff0c;缓解深层网络中的梯度消失问题 二、残差结构 在多层神经网络模型里&#xff0c;设想一个包含诺干层自网络&#xff0c;子网络的函数用H(x)来表示&#x…

前端入门之VUE--vue组件化编程

前言 VUE是前端用的最多的框架&#xff1b;这篇文章是本人大一上学习前端的笔记&#xff1b;欢迎点赞 收藏 关注&#xff0c;本人将会持续更新。 文章目录 2、Vue组件化编程2.1、组件2.2、基本使用2.2.1、VueComponent 2、Vue组件化编程 2.1、组件 组件&#xff1a;用来实现…

设计模式-装饰器模式(结构型)与责任链模式(行为型)对比,以及链式设计

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言1.装饰器模式1.1概念1.2作用1.3应用场景1.4特点1.5类与对象关系1.6实现 2责任链模式2.1概念2.2作用2.3应用场景2.4特点2.5类与对象关系2.6实现 3.对比总结 前言…

操作系统:死锁与饥饿

目录 死锁概念 饥饿与饿死概念 饥饿和死锁对比 死锁类型 死锁条件&#xff08;Coffman条件&#xff09; 死锁恢复方法 死锁避免 安全状态与安全进程序列&#xff1a; 银行家算法&#xff1a; 死锁检测时机&#xff08;了解&#xff09;&#xff1a; 死锁检测 死锁案…

RPO: Read-only Prompt Optimization for Vision-Language Few-shot Learning

文章汇总 想解决的问题对CoOp的改进CoCoOp尽管提升了性能,但却增加了方差(模型的准确率波动性较大)。 模型的框架一眼看去,跟maple很像(maple跟这篇文章都是2023年发表的),但maple的视觉提示是由文本提示经过全连接转换而来的,而这里是文本提示和视觉提示是独立的。另外m…