大家好,又见面了,我是你们的朋友全栈君。...1.PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.UNIQUE(唯一索引...) mysql>ALTER TABLE `table_name` ADD UNIQUE (`column` ) 3.INDEX(普通索引) mysql>ALTER TABLE `table_name...` ADD INDEX index_name ( `column` ) 4.FULLTEXT(全文索引) mysql>ALTER TABLE `table_name` ADD FULLTEXT...( `column` ) 5.多列索引 mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`
MySQL DML语句insert全表数据添加语句以及注意事项 官方语法: INSERT INTO 表名 [(字段名列表)] VALUES (值列表); 字段名是可选的,如省略则依次插入所有字段...多个列表和多个值之间使用逗号分隔 值列表和字段名列表逐一对应 如插入的是表中部分数据,字段名列表必填 全表语法: INSERT INTO 表名 VALUES (值列表); 需要添加表中所有的数据列信息...select * from student; # 添加语句insert insert into student values (0,'2023-9-16 10:00:00','2023-9-28...2、由于我们没有独立的写列信息,故而添加值数量一定与列数匹配 3、数字类型直接写,而字符/字符串类型以及时间类型需要使用单引号包括 4、要输入中文,其数据库编码集一定为utf8,排序规则【utf8..._general_ci】 5、确认关键字insert into ,values,显示颜色为蓝色,否则书写错误 6、每一条sql语句结束都需要添加一个【;】代表书写完毕。
MySQL中的join语法 在MySQL中,join语句想必大家都不陌生,今天我们围绕join语句展开,说一些可能平时不关注的知识点。...整个join语句的执行过程如下: a、从表t1中拿到一条记录的字段a值 b、拿a的值去t2表中查找,查找匹配的行 c、找到结果,和表t1中的行拼接成一行记录,作为结果的一条记录 d、重复以上三个步骤,直到...t1的数据全部被遍历一遍。...这肯定是不合适的,事实上,MySQL也不会这么处理,在这种数据量比较大的情况下,MySQL会使用一种叫做Block Nested-Loop join的算法(简称BNLJ)来代替SNLJ,BNLJ和SNLJ...最后介绍下,MySQL中通过下面的参数来控制join buffer的大小: mysql> show variables like '%join_buffer%'; +------------------
45.00); 注:如果要更新自增字段需要把IDENTITY_INSERT选项开启,用完后记得关闭 SET IDENTITY_INSERT ON; INSERT SELECT 把select 语句的查询结果插入到表中...FROM Sales.Orders WHERE shipcountry = N'Norway'; SET IDENTITY_INSERT Sales.MyOrders OFF; INSERT EXEC 该语句可以让你把动态语句或者存储过程的结果插入表格...,可以用以下方式变动(这里直接拷贝参考文章中的内容。...几乎所有SQL语句都可以使用。...,而是直接拷贝数据源或者查询结果数据定义:比如列名,类型,是否为空,自增等来建立目标表。
MySQL中SQL语句的索引分析 了解过 索引 的概念以及 B+树 的概念之后,我们就来看看怎么分析一条查询语句的索引使用情况。...相信不少同学应该都使用过 EXPLAIN 来分析 SQL 语句,但是具体到 EXPLAIN 中每个字段的作用,可能有不少同学还是会有点晕的。...插入数据的话我就直接使用 PHP 简单的插入一些随机数据。...目前,我们的表中没有建立任何索引,只有一个主键索引,因此,上面的查询中,大部分的分析结果都是 NULL ,同时 rows 显示的行数也是全部数据的数量,也就是说,在没走索引的情况下,现在我们的查询是一个全表扫描...system 当表中只有一要记录并且使用的是 MyISAM、MEMORY 的统计数据是精确的,那么查询计划结果就是 system 。
大家好,又见面了,我是你们的朋友全栈君。...查看索引 show index from 数据库表名 alter table 数据库add index 索引名称(数据库字段名称) PRIMARY KEY(主键索引) ALTER TABLE `table_name...ADD PRIMARY KEY ( `column` ) UNIQUE(唯一索引) ALTER TABLE `table_name` ADD UNIQUE (`column`) INDEX(普通索引) mysql...这是最基本的索引,它没有任何限制。...它与前面的”普通索引”类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。
Mysql中的条件语句在我们对数据进行转换的时候比较有用,这样就不需要创建中转表。...= "" IF ELSE 流程控制语句 在mysql存储过程中的用法: IF search_condition THEN statement_list [ELSEIF search_condition...[ELSE statement_list] END IF IF作为一条语句,在END IF后需要加上分号“;”以表示语句结束,其他语句如CASE、LOOP等也是相同的。...= '' Swap Salary Leetcode中有一道题目就是根据条件来转换数据的,就需要用条件控制语句来实现。...UPDATE salary SET sex = IF(sex = 'm', 'f', 'm') 也可以利用条件语句,在搜索的时候,直接进行数据转换 select *,(CASE WHEN sex='1'
VIP学员所写,学员有权匿名,对文章有最终解释权;凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记。...mysql数据操作语句 在我操作数据库里的数据时我们有三种数据操作语句,分别是INSERT,DELETE,UPDATE。...语句时我们要注意以下几点: 如果有列是必填,那就需要带上。...自动编号的列不用填写,它会自动获得。 填入值得时候除了数值不用加单引号,其他类型的值都要加单引号。 我们还可以用SYSDATE()获取系统时间。 可以用PASSWORD(值),将数值MD5加密。...DELETE语句如下: DELETE FROM 表名; 可以在后面加上WHERE条件语句。 UPDATE语法如下: UPDATE 表名 SET 列=值,列=值; 也可以在后面加上WHERE条件语句。
在mysql数据库中,有时候我们会使用到类似if else的判断操作。那么mysql中怎么处理这种需求呢?...mysql 判断操作一种语法: case ..when语句 语法有两种 语法一: case when 语法1 示例: SELECT (CASE state WHEN 1 THEN '启用中' WHEN...0 THEN '已停用'END ) AS stateStr, t.* FROM tbl_msg_manager t case when 语法1的示例 执行结果: cease when 语法1...执行结果 语法二: case when语法2 说明: when 后面跟上的是 判断语句。...语法二示例: SELECT t.*, (CASE WHEN t.state= 1 THEN '启用中' WHEN t.state = 0 THEN '已停用' END ) AS stateStr FROM
在mysql数据库中,有时候我们会使用到类似if else的判断操作。那么mysql中怎么处理这种需求呢? mysql 判断操作一种语法: case ..when语句 语法有两种 语法一: ? ?...请点击此处输入图片描述 示例: SELECT (CASE state WHEN 1 THEN '启用中' WHEN 0 THEN '已停用'END ) AS stateStr, t.* FROM tbl_msg_manager...说明: when 后面跟上的是 判断语句。....*, (CASE WHEN t.state= 1 THEN '启用中' WHEN t.state = 0 THEN '已停用' END ) AS stateStr FROM tbl_msg_manager
数据查询语言(DQL):用于从数据库中的一个或多个表中查询数据,主要使用SELECT语句。2....数据操作语言(DML):用于修改数据库中的数据,包括插入(INSERT)、更新(UPDATE)和删除(DELETE)等操作。3....数据定义语言(DDL):用于创建、修改和删除数据库内的数据结构,如创建和删除数据库、创建和删除表、创建和删除索引等。...主要的DDL语句包括CREATE、ALTER、DROP、RENAME和TRUNCATE等。4....数据控制语言(DCL):用于对数据库的访问进行控制,包括给用户授予访问权限(GRANT)和取消用户访问权限(REVOKE)等操作。SQL通用语法在书写SQL语句时,需要注意以下几点通用语法:1.
1.1 if 语句 1.1.1 语法 # 当条件表达式为 true 的时候,返回 值1,否则返回 值2 if(条件表达式, 值1, 值2); # 类似 java 中的 if ··· else if...后面 case 可以省略 1.2.2 示例 # 第一种用法 # 类似 java 中的 switch ··· case mysql> select id as '编号',(case sex when 1...3 | 女 | 小姐姐 | | 4 | 男 | 牛魔王 | +------+------+--------+ 4 rows in set (0.20 sec) # 类似 java 中的...☞ 循环控制 # 类似 java中的 continue iterate 循环标签; # 类似 java 中的 break leave 循环标签; ☞ 示例 # 求 1 ~ n 的和 # 创建存储过程...procedure if exists sumnum; Query OK, 0 rows affected (0.07 sec) 1.3.3 repeat 循环 repeat 循环类似于 java 中的
命令:mysql>select id, Sum(score) from result group by id; 多表查询 一、等值查询 现在有两个表: 现在要查询年龄小于20岁学生的不及格成绩...如果存在左表中过滤出来的数据,右表没有匹配上,这样的话右表就会出现NULL; (2)右外连接查询 select a.id,score from (select id,age from stu where...如图: 我们发现过滤出来的表进行的匹配只有两条满足条件(红色代表条件满足),但最后的结果却是: 左表不匹配的数据改为空,右表过滤出来的数据都要存在。...(3)全外连接查询 结合了左外连接和右外连接,使得左表和右表的数据都存在。...2、内连接查询 只筛选匹配结果 比如过滤的结果如下: 最后的结果为: 只匹配我们需要的结果 语句为: select a.id,score from (select id,
' AND table_name ='表名groups' SHOW FULL COLUMNS FROM groups -- 这个可以按条件的去搜索某名字或某数据类型的列的信息:例如 SHOW FULL...COLUMNS FROM tableName WHERE FIELD = 'add_time' OR TYPE LIKE '%date%' -- 查看tableName表中列名是add_time的或类型是...date的列 SELECT column_name, column_comment FROM information_schema.columns WHERE table_schema ='db'...AND table_name = 'groups' SHOW CREATE TABLE communication_group 3.修改表中字段的长度 1.表中已存有数据:ALTER table 表名...MODIFY (字段名 字段类型(长度));2.表中未存有数据:ALTER TABLE 表名 MODIFY 字段名 字段类型(长度);
在MySQL数据库中使用select语句来查询数据 在数据库中通用的select语句语法如下: SELECT column_name, column_name FROM table_name [WHERE...where age>20 修改数据 我们使用update来更新数据表中的数据。...age=22 where id=1; 删除数据 可以使用sql的delete from命令来删除mysql数据表中的记录 语法如下 delete from table_name [where clause...] 删除年龄在25岁以上的用户 delete from user where age >25; replace操作 如果数据库中存在相同主键的数据,replace的作用相当于修改操作;如果数据库中不存在相同主键的数据...举个实际的例子,在这个例子中,id是数据表的主键 mysql> select * from user -> ; +----+---------+------+--------------+ |
前言 大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎!...语句总览&注意事项 如下所示 注意事项 插入数据时,指定的字段顺序需要与值的顺序是 一 一对应的 字符串和日期型数据应该包含在 引号 中。...插入的数据大小,应该在字段的 规定范围内 1.给指定字段添加数据 INSERT INTO表名(字段名1,字段名2,.…)VALUES(值1,值2,.…); 如下图所示,添加职工1信息成功 insert...,(值1,值2,…),(值1,值2,…);//2 注意 用逗号分开 即可 四.DML-修改数据 语句总览&注意事项 如下所示 注意事项 修改语句的条件可以有,也可以没有, 如果没有where...2008-01-01 update employee set entrydate = '2008-01-01'; 五.DML-删除数据 语句总览&注意事项 如下所示 注意事项 DELETE语句的条件可以有
代码示例: 只插入一个指定数据: insert into b_user(name) values('张三'); 不指定插入数据(需要与字段列表顺序一致): insert into b_user values...(1,'李四','男','2020-01-01'); 注意: 1.如果表名后没有字段列表,values后的值列表中的个数和表字段个数一致,并且值列表的顺序和字段列表的顺序一致。...一般如果主键列自增,不显示的给自增列赋值; 2.在值列表中字符、日期字段都应该使用单引号括起来 ; 3.如果表中有NOT NULL字段,该字段必须赋值 ; 4.如果表中没有NOT NULL,可以赋值,也可以不赋值...birthday) values('王1','男','2020-01-01'),('王2','男','2020-01-01'),('王3','男','2020-01-01'); 批量插入 将一个查询结果全部插入到数据库中...代码示例: 删除ID=3的用户信息 DELETE FROM temp_user WHERE user_id=3; 注意:企业开发过程中谨慎的去使用delete语句 建议书写方式: 1.先用查询语句 SELECT
sql中declare是声明的意思32313133353236313431303231363533e58685e5aeb931333365653236,就是声明变量的,这个一般是用在函数和存储过程中的。...mysql存储过程中,定义变量有两种方式: 1.使用set或select直接赋值,变量名以 @ 开头. 例如:set @var=1; 可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。...在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。...,需要多条语句的查询,因此需要多次修改 declare可以满足多次执行,但数据只修改一次。...语句中就可以使用@local_variable来调用变量 声明中可以提供值,否则声明之后所有变量将初始化为NULL。
优化器: 按照 MySQL 认为最优的方案去执行。 执行器: 执行语句,然后从存储引擎返回数据。 ...主要负责用户登录数据库,进行用户的身份认证,包括校验账户密码,权限等操作,如果用户账户密码已通过,连接器会到权限表中查询该用户的所有权限,之后在这个连接里的权限逻辑判断都是会依赖此时读取到的权限数据,也就是说...2) 查询缓存(MySQL 8.0 版本后移除) 查询缓存主要用来缓存我们所执行的 SELECT 语句以及该语句的结果集。 ...连接建立后,执行查询语句的时候,会先查询缓存,MySQL 会先校验这个 sql 是否执行过,以 Key-Value 的形式缓存在内存中,Key 是查询预计,Value 是结果集。...MySQL 查询不建议使用缓存,因为查询缓存失效在实际业务场景中可能会非常频繁,假如你对一个表更新的话,这个表上的所有的查询缓存都会被清空。
student); [Err] 1093 - You can't specify target table 'student' for update in FROM clause 描述: 如果子查询的...解决方法: 通过给 from 子句中的结果集起别名。...student m where m.id = 1; [Err] 1064 - You have an error in your SQL syntax; 描述: delete from table 这样的句子中
领取专属 10元无门槛券
手把手带您无忧上云