697 | +----------+ 查看明细 SELECT * FROM INFORMATION_SCHEMA.KEYWORDS; 这里列出的都是关键字,但是在使用上还有点小的区别的。...保留字: SELECT * FROM INFORMATION_SCHEMA.KEYWORDS where RESERVED=1; 【必须加反引号才能用作标识符】 非保留字: SELECT * FROM...INFORMATION_SCHEMA.KEYWORDS where RESERVED=0; 【不用加反引号就可以用作标识符】 示例: -- YEAR是非保留字 mysql> create table...efddf333 (a int , YEAR int); Query OK, 0 rows affected (0.01 sec) -- XOR是保留字 mysql> create table...int , `XOR` int); Query OK, 0 rows affected (0.02 sec) 在建表语句中,上述的这些关键字都是不建议使用的,为了避免引起歧义。
大家好,又见面了,我是你们的朋友全栈君。...mysql> create table ts01 like ti_o_sms; #创建表结构.这样的建表方式,不仅仅是表的结构,连带着索引也会同时创建....Query OK, 0 rows affected (0.02 sec) mysql> alter table ts01 rename to ts01_new; #修改表名的语法:alter table...rename to/as new_tablename; Query OK, 0 rows affected (0.00 sec) //这样 mysql> alter table ts01_new rename...AS ts02; Query OK, 0 rows affected (0.03 sec) mysql> show tables; +--------------------+ | Tables_in_mytest
' and table_type='base table' and table_name like '%_copy'; information_schema 是MySQL系统自带的数据库,提供了对数据库元数据的访问...information_schema.tables 指数据库中的表(information_schema.columns 指列) table_schema 指数据库的名称 table_type 指是表的类型...(base table 指基本表,不包含系统表) table_name 指具体的表名 如查询work_ad数据库中是否存在包含”user”关键字的数据表 select table_name from...如何查询表名中包含某字段的表 select * from systables where tabname like 'saa%' 此法只对Informix数据库有用 查询指定数据库中指定表的所有字段名column_name...中查询到包含该字段的所有表名 SELECT TABLE_NAME FROM information_schema.COLUMNS WHERE COLUMN_NAME='字段名' 如:查询包含status
01 MySQL中的kill语法 在MySQL中,kill命令分为如下两种: 1、kill query + pid 2、kill connection + pid 其中connection可以省略...第二种kill pid的方法指的是断开该线程的连接,如果线程中有正在执行的语句,那么也会停止这个语句。 当收到kill query 的命令后,MySQL将会执行哪些动作?...可以肯定的是,不会直接kill线程,因为如果直接kill掉的话,如果该线程中还持有元数据的MDL锁,那么这个锁就没有办法释放了,实际上,kill query的命令会执行如下的动作: 1、首先将session...在MySQL中,如果一个线程的状态是KILL_CONNECTION,就把Command列显示Killed。...03 ctrl + c 指令 在一些客户端上,当我们发现输入错误之后,往往会使用ctrl + c的命令去终止当前操作,本质上ctrl + c 指令其实是相当于在另外的session中,执行了一个
要说幻读,就要从MySQL的隔离级别说起。MySQL的4钟隔离级别分别是: Read Uncommitted(读取未提交内容) 在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。...Read Committed(读取提交内容) 这是大多数数据库系统的默认隔离级别(但不是MySQL默认的)。它满足了隔离的简单定义:一个事务只能看见已经提交事务所做的改变。...事务B提交事务以后,事务A再次查询,查询到了新增的这条数据。在事务A中,多次查询的结果不一致,这就是我们说的“不可重复读”。...Repeatable Read(可重读) 这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。...“可重读”这种隔离级别解决了上面例子中的问题,保证了同一事务内,多次查询的结果是一致的。
简介 该篇文章对MySQL中的日志进行总结与简单介绍,不会涉及的太深。主要的目的是为了对MySQL中的日志文件有一个体系化的了解。后面会对每一种日志文件做具体的分析与总结。...8:00' 错误日志文件 错误日志文件记录了MySQL从启动、运行和关闭几个环节中的日志信息。...只要在MySQL中的配置文件中配置意向log_error即可。...配置file则会记录在日志文件中,配置none则不会记录,配置table则会在MySQL默认的MySQL数据中创建一张表(表名叫做general-log)来记录日志。...的DML语句,记录了操作之后的物理日志内容,不会记录MySQL中的select、show等语句。
1.锁 我们先来大致说一下 MySQL 中的锁。...当多个事务或者多个进程访问同一个资源的时候,为了保证数据的一致性,就需要用到 MySQL 锁机制,从锁定资源的角度来看,MySQL 中的锁大致上可以分为三种: 表级锁(table-level locking...在 MySQL 中,MyISAM 引擎是表级锁,而 InnoDB 引擎则支持行级锁,不过需要注意,其实 InnoDB 也支持表级锁,只不过默认情况下是行级锁。...需要注意的是,如果在同一条 SQL 中,同一个表名出线了 N 次,该表就要锁定 N 次,如下: ?...❝需要注意的是,在 MySQL5.5.3 之前,NEVER、AUTO 以及 ALWAYS 分别使用 0、1、2 代替。
导读 最近在学习查找MySQL中"锁"的相关资料时,发现网上各种言论观点杂乱不堪且版本混乱,很容易让人深陷其中、很是蒙圈。...笔者认真研读了MySQL8.0官方指导手册,并广泛搜集各家观点,整理了一份参考性较强的关于MySQL中"锁"机制的知识点合集,以供参考学习。...,MySQL中不加锁实现这一机制的方法是MVCC,即大名鼎鼎的多版本并发控制;与之对应,加锁实现的并发机制则叫做LBCC(locking-based concurrency control) 07 加"...特指MySQL读取过程中存在的副作用,例如脏读、幻读等 read phenomena,主要是指数据库中三种"错误"的读取结果: 脏读:dirty read,即A事务读取了B事务更改但未提交的信息,主要发生在...如果能看到这里,相信应该已对MySQL中锁机制有较为全面的了解,那就赏个转发或者在看吧! ---- 参考资料: 1. MySQL8.0官方文档(公众号:小数志 后台回复"教程"提供下载) 2.
背景 有一个商品的名称配置错误了,需要进行修改,但是涉及到的表太多了,因为商品的sku_name被冗余到了很多表中,一个一个的找非常的费事费力,特地记下便捷查询操作以备后用。...数据库SQL快捷查询 1.查询包含某个字段的所有表名 SELECT DISTINCT table_name FROM information_schema.columns WHERE table_schema...= 'db_lingyejun' and column_name='sku_id'; 2.查询同时含有两个字段的所有表名 SELECT DISTINCT a.table_name FROM information_schema.columns...a.column_name='sku_id' and b.table_schema = 'db_lingyejun' and b.column_name='sku_name'; 3.拼接SQL动态生成针对此字段的所有更新语句
但是稍微涉及细节一点,这四大特性在数据库中的实现原理是怎么样的?那就没有几个人能够答得上来了。因此,我们这篇文章着重讨论一下四大特性在Mysql中的实现原理。...在Mysql中,为了解决CPU和磁盘速度不一致问题,Mysql是将磁盘上的数据加载到内存,对内存进行操作,然后再回写磁盘。好,假设此时宕机了,在内存中修改的数据全部丢失了,持久性就无法保证。...正如之前说的,Mysql是先把磁盘上的数据加载到内存中,在内存中对数据进行修改,再刷回磁盘上。如果此时突然宕机,内存中的数据就会丢失。 怎么解决这个问题?...还是拿转账例子来说明,有一个账户表如下 表名t_balance ? 其中id是主键,user_id为账户名,balance为余额。还是以转账两次为例,如下图所示 ?...但是当事务隔离级别为可重复读(Repeateable Read)中,是满足隔离性的。 总结 本文讲了Mysql中事务ACID四大特性的实现原理,希望大家有所收获。
MySQL是一款广泛使用的关系型数据库管理系统,其临时表功能在处理大量数据和复杂查询时非常有用。然而,使用临时表可能会对性能产生一定的影响。...在了解临时表对性能的影响之前,首先需要了解临时表的工作原理。MySQL的临时表是在内存或磁盘上创建的临时存储结构,用于存储查询过程中的中间结果。临时表在查询结束后自动被销毁,不会占用永久表的空间。...可以使用合适的索引、优化查询条件、使用覆盖索引等手段,尽量避免全表扫描和临时表的创建。 优化内存配置:合理配置MySQL的内存参数,确保有足够的内存用于存储临时表。...可以调整tmp_table_size和max_heap_table_size参数的值来控制临时表在内存中的大小。 使用内存临时表:将临时表存储在内存中,可以避免磁盘IO的开销,提高查询性能。...可以通过设置tmp_table_size和max_heap_table_size参数为较大的值,让MySQL尽可能地将临时表存储在内存中。
如何避免:所有的库名,表名,字段名使用小写,单词用下划线"_"间隔,所有命名中,不允许使用 反引号,双引号包裹,ODS 层遇到特别骚的,需要提审批。这个规则保你在数据库使用达到 95% 以上的幸福。...反引号是表名中的一部分 Databend 默认支持大小写敏感,兼容了 Pg 和 MySQL 两种风格的大小写 MySQL 在 Linux 下默认支持大小写敏感,需要有反引号包裹 PostgreSQL...第二个句可以在 Databend 中执行,也是两个独立的字段。 到这里 MySQL 不跟了, MySQL 在字段上不区分大小写。MySQL 字段命名也可以用反引号包裹,但这块规则和表名库名不一致。...双引号和单引号在字符串上的区别 在谈这个问题的时间如果你是一个 MySQL 用户,可能从来都不知道这两个还有啥区别吗?...【强制】对象名(表名、列名、函数名、视图名、序列名、等对象名称)规范,对象名务必只使用小写字母,下划线,数字。不要以数字开头,不要使用保留字。
02-23无意中在在论坛看到一个帖;具体的问题大概就是MySQL与MariaDB对子查询中order by的查询结果不一样; 具体的问题的描述看查看如下的连接;论坛帖子连接:https://bbs.csdn.net...通过上述的查看结果可以发现: 和论坛中发帖者的结果是一样的,这也是发帖者所期望的结果; 但是相同的操作,难道在mysql数据库就不行了吗?结果就不一样了?这么神奇吗?...那就查看官方文档的说明: 分别查看了一下MYSQL和MariaDB的官方文档关于 MYSQL数据库关于order by的官方说明: https://dev.mysql.com/doc/refman/5.7...通过对比MYSQL和MariaDB的官方文档的说明,得出如下的结论: MySQL与MariaDB对子查询语句当中的order by的处理方法不同。...大家可以自己实验一下;但是反过来想一下,我的查询结果是未知的,如果使用limit去做限制,在实际的使用中不太现实,那要怎么办呢?只能改写SQL语句了,还能咋办呢?
作用:确保事务的持久性,防止在数据库 crash 的时候上有脏页未写入磁盘,在重启 MySQL 的时候会根据 redo log 进行重做。...DML 的执行流程 如果你对 MySQL 的这两个日志没有了解过的话,上面的特性是很难理解的,如果结合着 DML 语句执行流程就会好理解一点,比如我现在要在数据库的表中更新 id = 1 这一行中的 value...首先 MySQL 的 server 层会通过调用执行器去获取指定数据行 苦差事当然交给引擎(这里是innodb)来做,InnoDB 首先会去查看当前内存中是否存在该数据行,如果存在之间从内存中取出,如果不在那么会从磁盘中...主要的流程如下,MySQL会从内存中获取相应的数据行(如果没有先从磁盘 load 到内存中),然后将数据行进行更新并将新行写入内存后进行redo log的写入和 bin log 的写入,在一开始 redo...对于这个问题就可以总结为两点: 通过日志的顺序写提高磁盘效率 通过组提交减少系统调用 总结 这里我们主要介绍了在 MySQL 中 一条 DML 语句是如何执行的,redo log 、bin log又是如何和
MySQL中的 查询缓存 和Buffer Pool是一个东西吗?MySQL数据库可以看作是分为了两层,server层和存储引擎层。...如果此次的查询语句在缓存中有,那么就会直接返回缓存中的结果,如果没有则会将该sql语句放行到下一步。类似一个拦截器一样。...每个DML语句都会导致查询缓存清空,所以在查询和更改操作差不多的业务场景下,查询缓存反而成为了性能的瓶颈,在mysql8.0版本的时候,mysql官方已经将这个功能删除了。...每次更新操作都会更新Buffer Pool中的数据,然后会有一个后台线程定期将Buffer Pool中的脏页(修改过的、与磁盘文件中的不一致的)刷新到磁盘中。...所以就引入了redo log以及WAL(Write-Ahead Logging)技术,每次修改都会把这个修改操作(以数据的物理形式,不是以sql的逻辑形式)记录在redo log文件中,这样每次就相当于只进行少量的磁盘
Mysql数据类型 MySQL数据库中的数据类型是数据库设计的基石,它们决定了数据的存储方式、数据的有效范围以及数据的处理方式。...本文将详细介绍MySQL中的数据类型,包括数值类型、日期和时间类型、字符串类型等,并通过Markdown格式的表格进行展示。 数值类型 数值类型用于存储数值数据,包括整数类型和浮点数类型。...整数类型 MySQL中的整数类型一共有5种,包括TINYINT、SMALLINT、MEDIUMINT、INT(或INTEGER)和BIGINT。...然而,需要注意的是,这里的“自动去掉空格”是指在MySQL客户端或应用程序层面,MySQL数据库本身在存储时还是保留了这些空格。...更多关于MySQL字符串类型的详细信息,可以访问MySQL字符串类型官方文档进行了解。 JSON类型 MySQL 5.7及更高版本引入了JSON数据类型,用于存储JSON格式的数据。
问题解答 对于这种特殊字符,我们一般想到的是用转义符进行处理,所以试了下"/"、引号、单引号等常见的转义符,发现依然语法错误,又查了下MySQL的官方说明: 特殊字符位于列名中时必须进行转义,如果列名中包含...ls .c会生成具有.c扩展名的所有文件列表。这个文件列表随后被赋予变量listc。...mysql中反引号的作用 为了区分MYSQL的保留字与普通字符而引入的符号 举个例子:SELECT `select` FROM `test` WHERE select='字段值' 在test表中,有个select...字段,如果不用反引号,MYSQL将把select视为保留字而导致出错,所以,有MYSQL保留字作为字段的,必须加上反引号来区分。...引号一般用在字段的值,如果字段值是字符或字符串,则要加引号,如:select='字段值' 不加反引号建的表不能包含MYSQL保留字,否则出错 反引号`,数字1左边的符号 保留字不能用于表名,比如desc
MySQL数据库中的锁还是非常重要的,本文重点给大家详细的来介绍下MySQL数据中的各种锁。...:开销大;加锁慢;会出现死锁 行锁的优势:锁的粒度小,发生锁冲突的概率低;处理并发的能力强 加锁的方式:自动加锁。...3.表锁和行锁对比 锁定粒度:表锁 > 行锁 加锁效率:表锁 > 行锁 冲突概率:表锁 > 行锁 并发性能:表锁 < 行锁 二、锁的细分 锁名 锁级别 英文名称 共享锁 行锁 Shared Locks...三、扩展问题 1.和Java中的锁区别 这两个种类的锁的作用都是一样的,都是为了解决资源并发的情况下,对资源的写问题的控制。简单来说就是解决并发。...2.MySQL中锁的本质 在MySQL数据库中,锁的本质就是对索引打上标记,如果当前表没有索引,则直接找到sequence/rownum这样的默认表序列,完成锁表。