今天写代码的时候,老是提示在You have an error in your SQL syntax; check the manual that corresponds to your MySQL server...语句的时候删掉这个字段就不会报错,加上这个字段添加和查询又会报错,纠结了很久,最后终于试着把describe改为describes,可以正常插入数据,也可以正常查询了,后面在网上一查,describe竟然是mysql...中的关键词,我们不能用这个作为数据库中的表的字段。...在SQL语句中出现的关键字和保留字 如果要使用人他们的字符意思而不是作为关键字、保留字使用,关键字可以正常使用,但是保留字必须使用`(键盘tab键上面,数字1左边的那个按键)来分割。...这个在SQLServer里面是使用[]中括号实现的。所以我们要尽量避免使用关键字和保留字来作为表名和字段名。
8.0官方文档: https://dev.mysql.com/doc/refman/8.0/en/information-schema-keywords-table.html mysql> \s --...------------ mysql Ver 8.0.19 for linux-glibc2.12 on x86_64 (MySQL Community Server - GPL) 查看有多少关键字...697 | +----------+ 查看明细 SELECT * FROM INFORMATION_SCHEMA.KEYWORDS; 这里列出的都是关键字,但是在使用上还有点小的区别的。...int , `XOR` int); Query OK, 0 rows affected (0.02 sec) 在建表语句中,上述的这些关键字都是不建议使用的,为了避免引起歧义。...TIPS: MySQL 8.0 Keywords and Reserved Words: https://dev.mysql.com/doc/refman/8.0/en/keywords.html
RIGHT JOIN 关键字会右表 (table_name2) 那里返回所有的行,即使在左表 (table_name1) 中没有匹配的行。 DISTINCT 用于返回唯一不同的值。...FROM Persons WHERE City LIKE 'N%' + 通配符 + % 替代一个或多个字符 + _ 仅替代一个字符 + [charlist] 字符列中的任何单一字符...charlist] 不在字符列中的任何单一字符 LIMIT MySQL的方言 SELECT * FROM operation WHERE type = 'SQLStats' AND name = 'SlowLog...允许行重复 SELECT INTO 从一个表中选取数据,然后把数据插入另一个表中。 常用于创建表的备份复件或者用于对记录进行存档。...制作 "Persons" 表的备份复件: SELECT * INTO Persons_backup FROM Persons IN 子句可用于向另一个数据库中拷贝表: SELECT * INTO
一、Explain是什么 使用 EXPLAIN 关键字可以模拟优化器执行 SQL 查询语句,从而知道 MySQL 是如何处理你的 SQL 语句的。分析你的查询语句或是表结构的性能瓶颈。...在 FROM 列表中包含的子查询被标记为 DERIVED(衍生)MySQL 会递归执行这些子查询, 把结果放在临时表里 SUBQUERY 在SELECT或WHERE列表中包含了子查询 DEPEDENT...因为只匹配一行数据,所以很快 如将主键置于 where 列表中,MySQL 就能将该查询转换为一个常量。 eq_ref 唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配。...8、rows rows 列显示 MySQL 认为它执行查询时必须检查的行数。越少越好!...9、extra Using filesort 说明 mysql 会对数据使用一个外部的索引排序,而不是按照表内的索引顺序进行读取。MySQL 中无法利用索引 完成的排序操作称为“文件排序”。
我们常说,MySQL 中的 like 要慎用,因为会全表扫描,这是一件可怕的事!...最左匹配既可以是匹配复合索引中的前几个字段,也可以是匹配第一个字段的前几个字符,在上面的案例中,我们匹配的是复合索引中的第一个字段。...如果大家不懂回表戳这里:什么是 MySQL 的“回表”?。...最后的 Extra 为 Using where 表示 MySQL 首先从数据表(存储引擎)中读取记录,返回给 MySQL 的 server 层,然后在 server 层过滤掉不满足条件的记录。 3....小结 好啦,通过这样两个小案例,松哥和大家分享了 MySQL 索引中的最左匹配原则,也希望小伙伴们能够藉此理解索引的存储结构。
,会被标记为衍生查询,会把查询结果放到一个临时表中5、union:如果有两个 select 查询语句,他们之间用 union 连起来查询,那么第二个 select 会被标记为 union6、union...,system 是 const 的特例,几乎不会出现这种情况,可以忽略不计2、const:将主键索引或者唯一索引放到 where 条件中查询,MySQL 可以将查询条件转变成一个常量,...、and、、in 等范围查找中。...7、all:没用到索引,单纯的将表数据全部都遍历一遍,查找到符合条件的数据 possible_keys /ˈpɒsəb(ə)l/ 此次查询中涉及字段上若存在索引,则会被列出来,表示可能会用到的索引...,但并不是实际上一定会用到的索引 key 此次查询中实际上用到的索引 key_len 索引字段的长度 rows 扫描行的数量 extra 执行情况的说明和描述
利用mysql explain来对sql语句进行优化,你需要懂这些关键字各表示的含义,这样优化才有的放矢。...语法格式如下: EXPLAIN SELECT SQL 语法格式说明: EXPLAIN:分析查询语句的关键字。 SELECT:执行查询语句的关键字。 SQL:查询语句。...(7)key:执行查询语句时MySQL实际会使用到的索引。如果MySQL实际没有使用索引,则此列为NULL。...(8)key_len:执行查询语句时实际用到的索引按照字节计算的长度值,可以通过此字段计算MySQL实际上使用了复合索引中的多少字段。如果key列值为NULL,则key_len列值也为NULL。...mysql中无法利用索引完成的排序称为文件排序。 using temporary(性能非常差):新建了内部临时表,使用了临时表保存中间结果。
关键字介绍 SQL 是由关键字组成的语言,关键字是一些用于执行 SQL 操作的特殊词汇。在命名数据库、表、列和其他数据库对象时,一定不要使用这些关键字。因此,这些关键字是一定要保留的。...=null COLLATE 关键字 在 mysql 中执行show create table 指令,可以看到一张表的建表语句,example 如下: CREATE TABLE `table1...这里顺便讲个题外话,mysql中有utf8和utf8mb4两种编码,在mysql中请大家忘记utf8**,永远使用 utf8mb4。...这是 mysql 的一个遗留问题,mysql中的utf8最多只能支持 3 bytes 长度的字符编码,对于一些需要占据 4 bytes 的文字,mysql的utf8就不支持了,要使用 utf8mb4 才行...以上就是关于 mysql 的 COLLATE 相关知识。不过,在系统设计中,我们还是要尽量避免让系统严重依赖中文字段的排序结果,在 mysql 的查询中也应该尽量避免使用中文做查询条件。
MySQL官方只提供了三种join方式,内连接、左连接和右连接,不支持其他的连接关键字。但是可以通过一定的语法将达到其他的连接的效果。...这意味着,如果在ON子句在右边的表匹配0(零)个记录,则连接将仍然在结果返回一行,但用NULL显示在右表中的每一列中。...左连接 从这一个开始,MySQL不提供正式的一步到位的关键字,效果全靠自己模拟。 左连接是得到A表中去除B表内容的剩下的部分,也就是A表独有的一部分。...全连接 全连接顾名思义是获得AB两表全部的数据,oracle提供了 full join关键字完成这一功能,但是MySQL没有。...不过MySQL中可以借助union达到这个效果,union的作用是合并两个查询的结果。 ? 差集 两表的全连接中除去重合的部分,即两张表分别的特有部分的合集。 ? ?
在Java中this关键字和super关键字* 一个对象对应一个this,this是一个变量,是一个引用。this保存当前对象的内存地址指向自身。...super关键字代表的就是“当前对象”的那部分父类型特征。 this和super出现在实例方法和构造方法中。this的语法是:“this.”、“this()”、super的语法是:“super.”...this和super不能使用在静态方法中。this.在区分局部变量和实例变量时不能省略;super.在“父类中有,子类中又有,如果在子类中访问‘父类的特征’时”,super.不能省略。...this()和super()都只会出现在构造方法的第一行,前者是通过当前的构造方法去调用”本类“中的其它构造方法,目的是实现代码复用。...后者是通过当前的构造方法去调用”父类“中的构造方法,目的是创建子类对象时先初始化父类型特征。
当对非 volatile 变量进行读写的时候,每个线程先从内存拷贝变量到CPU缓存中。...如果计算机有多个CPU,每个线程可能在不同的CPU上被处理,这意味着每个线程可以拷贝到不同的 CPU cache 中。 ...而声明变量是 volatile 的,JVM 保证了每次读变量都从内存中读,跳过 CPU cache 这一步。...volatile 性能 volatile 的读性能消耗与普通变量几乎相同,但是写操作稍慢,因为它需要在本地代码中插入许多内存屏障指令来保证处理器不发生乱序执行 面试中可能遇到的问题 单例模式中volatile...volatile防止指令重排,在DCL中,防止高并发情况下,指令重排造成的线程安全问题。
大家可能在CSS中见到过字符@然后加一些关键字的用法,这种用法就称之为AT规则,在CSS中,种类还是很多的,这里总结列举下。...某些软件,例如Dreamweaver新建CSS文件时候,自动会带有下面所示代码,但实际开发时候,作用不大,因为meta中已经有所设置(),会覆盖,所以我都是直接删掉的
在Web开发中,前端掌握JavaScript,后台掌握PHP成为一个趋势。当然后台掌握C#/Java,当然还有Python,Ruby其中的一种,都是可以的。...JavaScript中的this关键字经常被开发者滥用。我刚进入项目组,看到很多如下写法: _this=this; <!...this关键字可以作为对象方法调用,作为函数调用,作为构造函数调用,最后还可以使用apply或call调用。
Java中的53个关键字 一、 48个关键字 abstract、assert boolean、break、byte case、catch、char、class、continue default、do、double...switch、synchronized this、throw、throws、transient、try void、volatile while 二、2个保留字 goto、const 现在没用以后可能用到作为关键字
---- 严格关键字 as - 强制类型转换,消除特定包含项的 trait 的歧义,或者对 use 和 extern crate 语句中的项重命名 async - 返回一个 Future 而不是阻塞当前线程...move - 使闭包获取其所捕获项的所有权 mut - 表示引用、裸指针或模式绑定的可变性 pub - 表示结构体字段、impl 块或模块的公有可见性 ref - 通过引用绑定 return - 从函数中返回...表示当前模块的父模块 trait - 定义一个 trait true - 布尔字面值 true type - 定义一个类型别名或关联类型 union - 定义一个 union 并且是 union 声明中唯一用到的关键字...use - 引入外部空间的符号 where - 表示一个约束类型的从句 while - 基于一个表达式的结果判断是否进行循环 保留关键字 以下关键字目前没有任何功能,不过由 Rust 保留以备将来使用...、函数、trait 或实现 static 可以使用原始标识符的方式,做到使用这些关键字也能通过编译 原始标识符(Raw identifiers)允许你使用通常不能使用的关键字,其带有 r# 前缀
二、this的值 在全局环境(任何函数调用的外部)中,this的值都是全局对象(浏览器中是window对象,node中是global对象) 在函数内部环境,this的值取决于函数被调用的方式 三、this...obj foo.call(obj)// name obj foo.bind(obj)()// name obj 这时候的this指向都被显式绑定至obj,此后,无论如何调用函数,总会将obj绑定到foo中的...new绑定 通过new关键字调用的函数,属于new绑定模式。这时this关键字指向这个新创建的对象。...如果是,则this指向指定的对象; 函数是否在某个上下文对象中隐式调用?如果是,this绑定的是那个上下文对象; 上述全不是,则使用默认绑定。...this的指向 本文首发于:你不知道的this关键字
一、this关键字主要有三个应用: (1)this调用本类中的属性,也就是类中的成员变量; (2)this调用本类中的其他方法; (3)this调用本类中的其他构造方法,调用时要放在构造方法的首行...此时this这个关键字就起到作用了。this这个关键字其代表的就是对象中的成员变量或者方法。...从这个应用中,我们可以看出this关键字其代表的就是对象的名字。 其实如果是局部变量的话,也是相同的道理。如在上面的代码中,name不是形式参数,而是一个局部变量。...在第一个没有带参数的构造方法中,使用了this(“Hello!”)这句代码,这句代码表示什么含义呢?在构造方法中使this关键字表示调用类中的构造方法。...此时这个this关键字就代表类的名称。如代码在上面student类中,那么代码代表的含义就是return student。
1. 找到表 from join on 2. 确定过滤条件 where and/or 3. 分组&过滤 group by having(将分组的结果进行havi...
*Java中的关键字* 说明: 关键字是Java中的一些具有特定含义的单词,定义的变量名不能和关键字冲突。...implements关键字之前。...五、用于异常处理的关键字 1.try 2.catch 3.finally 这三个关键字通常一起使用,形如try{...}catch{...}finally{...}...时,会先将try或catch中的返回结果保存在局部变量表中,直到finally中的语句执行结束然后返回; (3)try和catch中的return语句不可能同时执行,因为如果try中return了,说明没有发生异常....html 5.assert(断言) *说明:assert关键字,笔者知之甚少,几乎不使用,通过下面的博客,有了一定的认知了解。
1、java是严格区分大小写的 2、关键字有几个特点:全部是小写 Abstract 抽象的 一个Java语言中的关键字,用在类的声明中来指明一个类是不能被实例化的,但是可以被其它类继承。...implements Java(TM)编程语言的一个关键字,在类的声明中是可选的,用来指明当前类实现的接口。...protected Java语言的一个关键字,在方法和变量的声明中使用,它表示这个方法或变量只能被同一个类中的,子类中的或者同一个包中的类中的元素所访问 。...public Java语言的一个关键字,在方法和变量的声明中使用,它表示这个方法或变量能够被其它类中的元素访问。 return Java语言的一个关键字,用来结束一个方法的执行。...它后面可以跟一个方法声明中要求的值。 short Java语言的关键字,用来定义一个short类型的变量。 static Java语言的关键字,用来定义一个变量为类变量。
领取专属 10元无门槛券
手把手带您无忧上云