修改:先删除后增加 删除主键:alter table 表名 drop primary key 查看复合主键 desc 表名查询表结构 当出现两个PRI的时候 不代表有两个主键,代表由两个字段共同组成复合主键...); -- 错误 唯一键与主键不同,主键一张表只有一个,而唯一键可能有多个,所谓唯一键的删除,需要额外的指定要删除的唯一键的名字 语法:alter table 表名 drop index 唯一键名字/字段名
很多时候我们有这样的需求,数据库的字段名与实体类的属性名不一致,这个时候我们需要怎么做呢?有两种解决方案: 直接在查询的时候使用别名,将别名设置成与实体类的属性名一致。...-- mysql驱动包 --> mysql mysql-connector-java...): jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/test jdbc.user=root jdbc.password...private IStudentDao dao; @Before public void Before(){ dao=new StudentDaoImpl(); } /* * 查询列表...students){ System.out.println(student); } } } /* * 通过id来查询
在Mysql 众多表中查找一个表名或者字段名的 SQL 语句: SELECT table_name, column_name from information_schema.columns WHERE
很多时候我们有这样的需求,数据库的字段名与实体类的属性名不一致,这个时候我们需要怎么做呢?有两种解决方案,第一种:直接在查询的时候使用别名,将别名设置成与实体类的属性名一致。...-- mysql驱动包 --> mysql mysql-connector-java...): jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/test?...private IStudentDao dao; @Before public void Before(){ dao=new StudentDaoImpl(); } /* * 查询列表...students){ System.out.println(student); } } } /* * 通过id来查询
1、查看mysql的慢查询日志是否开启 show variables like ‘%query%’; 可以看到slow_query_log的值是OFF,也就是mysql默认是不启用慢查询日志的。...这里还有个long_query_time,默认是10秒,也就是超过了10秒即为慢查询。...log_queries_not_using_indexes,如果设置为ON,则会将所有没有使用索引的查询都记录为慢查询。 2、如何启用慢查询日志呢?...3、指定日志的输出格式 MySQL支持TABLE和FILE两种输出格式,可以用下面的命令来查看当前的输出格式: show variables like ‘%log_output%’; 设置输出格式: set...select sleep(11); 查看TABLE记录的慢日志: select * from mysql.slow_log; 这里面记录了查询时间、发起查询的客户端、扫描行数、执行的sql语句等信息
大家好,又见面了,我是全栈君 在连sqlite数据库时,用fetchall()查询结果,是用row[0],row[1]这样的方式来打印每列的结果 但是我想用row[“字段名”]方式查询怎么办?
1 修改字段类型、字段名、字段注释、类型长度、字段默认值 mysql修改字段类型: --能修改字段类型、类型长度、默认值、注释 --对某字段进行修改 ALTER TABLE 表名 MODIFY [...COLUMN] 字段名 新数据类型 新类型长度 新默认值 新注释; -- COLUMN关键字可以省略不写 alter table table1 modify column column1...修改字段名: ALTER TABLE 表名 CHANGE [column] 旧字段名 新字段名 新数据类型; alter table table1 change column1 column1...varchar(100) DEFAULT 1.2 COMMENT '注释'; -- 正常,此时字段名称没有改变,能修改字段类型、类型长度、默认值、注释 alter table table1 change...change column2 column1 decimal(10,1) DEFAULT NULL COMMENT '注释' -- 正常,能修改字段名、字段类型、类型长度、默认值、注释 alter
一、前言 1,有人问我,count查询为啥有时候快有时候慢 2,首先要明白count查询的真正作用 2-1:统计某个列的数量 2-1:统计行数 二、原理 1,统计列时,会查询这个列不为空的数量,它是需要计算的...where,它可以直接取到结果,因为它可以利用存储引擎的特性直接获得这个值,比如count(*) 3,统计列时,如果知道这个列不能为空,会转化为count(*),从而加快速度 所以:你要知道自己要干什么,该怎么样去用...在无可用的二级索引情况下,执行count会使MySQL扫描全表数据,当数据中存在大字段或字段较多时候,其效率非常低下(每个页只能包含较少的数据条数,需要访问的物理页较多) 三、实际应用 1,50万条数据...,没有索引,大约耗时13分钟 2,50万条数据,有索引,大约耗时354毫秒 3,原理 mysql一个数据页为:16k(默认) 能存16*1024/(4+8) =1365条数据(为什么是4+8可以看看mysql...存储页的原理) 假设每页数据耗损不存满,50% 50万条数据,需要500000/1365*2 为 732个物理页 大小为16k*732为11.4M mysql空间按区分配,一区1M,假设连续的话,需要连续读
子查询系列文章的主题,在写作过程中可能会根据情况调整,也可能会插入其它不属于这个系列的文章。 本文我们先来看看不相关子查询是怎么执行的? 本文内容基于 MySQL 8.0.29 源码。 目录 1....执行流程 我们介绍的执行流程,不是整条 SQL 的完整执行流程,只会涉及到子查询相关的那些步骤。 查询优化阶段,MySQL 确定了要使用物化策略执行子查询之后,就会创建临时表。...自动优化 为了让 SQL 执行的更快,MySQL 在很多细节处做了优化,对包含子查询的 where 条件判断所做的优化就是其中之一。...MySQL 没有为这种场景做优化,我们可以手动优化,写 SQL 的时候,把这种包含子查询的 where 条件放在最后,尽可能让 MySQL 少做一点无用工,从而让 SQL 可以执行的更快一点。 6....相关文章: 你好奇过 MySQL 内部临时表存了什么吗? where field in(...) 是怎么执行的? ----
在工作中,有时候我们更新一个表数据的时候,需要更新的数据来自其他查询出来的结果,这个时候sql怎么写? 如下: 将tb_option表中name 和valued的值进行互换 ?
修改字段 类型、名、注释、类型长度、默认值 ALTER TABLE 表名 MODIFY [COLUMN] 字段名 新类型 新类型长度 新默认值 新注释; -- COLUMN关键字可以省略不写...-- 字段名称未改变,修改字段类型、类型长度、默认值、注释 ALTER TABLE 表名 CHANGE [column] 旧字段名 新字段名 新数据类型; alter table table1...column1 decimal(10,1) DEFAULT NULL COMMENT '注释' alter table table1 change column1 column2; -- 报错 mysql...Duplicates: 0 Warnings: 0 更改表名 Table 从 db_a 要搬到 db_b RENAME TABLE db_a.old_table TO db_b.new_table; MySQL...Table 改名字(重命名) RENAME TABLE old_table TO new_table; MySQL 两个 Table 互换名 RENAME TABLE old_table TO tmp_table
但是,我记得 MySQL 是没有递归查询功能的,那 MySQL 中应该怎么实现呢? 于是,就有了这篇文章。...MySQL 自定义函数 手动实现 MySQL 递归查询 Oracle 递归查询 在 Oracle 中是通过 start with connect by prior 语法来实现递归查询的。...MySQL 递归查询 可以看到,Oracle 实现递归查询非常的方便。但是,在 MySQL 中并没有帮我们处理,因此需要我们自己手动实现递归查询。...MySQL 自定义函数,实现递归查询 可以发现以上已经把字符串拼接的问题也解决了。那么,问题就变成怎样构造有递归关系的字符串了。 我们可以自定义一个函数,通过传入根节点id,找到它的所有子节点。...在 MySQL 中,单个字母占1个字节,而我们平时用的 utf-8下,一个汉字占3个字节。 这个对于递归查询还是非常致命的。因为一般递归的话,关系层级都比较深,很有可能超过最大长度。
昨天讲到了索引的基础知识,没看的小伙伴记得看: 《爱上面试官》系列-数据库索引 MySQL 的索引长什么样子?索引到底是怎么加速查询的?...这个 MySQL 无论如何都会建起来,并且存储有完整行数据的索引,就叫聚簇索引(clustered index)。 2、二级索引 聚簇索引只能帮你加快主键查询,但是如果你想根据姓名查询呢?...不想全表扫描,怎么办?...B+树 查询,快速查到有两条姓名是“David”的记录,并且拿到它们的主键,分别是 4 和 5,但是你要的是select *呀,怎么办?...3、复合索引 继续,如果我还想根据姓名和年龄同时查询呢?
单表查询 1、普通查询 (1)命令:select * from ;//通匹 (2)命令:select from ; 2、去重查询(distinct) 命令:select...distinct from 3、排序查询(order by) 升序:asc 降序:desc 降序排列命令:select from order...by desc 不加desc一般默认为升序排列 4、分组查询(group by) 命令:select , Sum(score) from group...命令:mysql>select id, Sum(score) from result group by id; 多表查询 一、等值查询 现在有两个表: 现在要查询年龄小于20岁学生的不及格成绩...: 可见等值查询效率太低 二、连接查询 1、外连接查询 (1)左外连接查询 假设我们依旧使用的是上面的两个表,任然查询年龄小于20岁学生的不及格成绩 我们利用左外连接查询,先将学生表中所有年龄小于
sql 分页查询语句(mysql分页语句) 2020-07-24 11:18:53 共10个回答 intpageCount=15(每页显示的行数)intTotalCount=30(页数*每页显示的行数)...分页:一般会把当前页通过get方式传递,PHP通过$_GET[‘page’]接收.查询:可以从当前乘以每页显示数通过limit来实现分页效果....’2’asnumfromtwherereadcount>10))orderbynum,weight把前5个加上标签1,后10个加上标签2,最后按照标签排序就ok了 四种方式实现SQLServer分页查询...*,ROWNUMRNFROM(SELECT*FROMTABLE_Oracle的分页查询语句基本上可以按照本文给出的格式来进行套用.分页查询格式: 你说的应该是利用SQL的游标存储过程来分页的形式代码如下...:createprocedurefenye@sqlstrnvarchar(4000),–查询字符串@currentpageint,–第N页@pagesizeint 发布者:全栈程序员栈长,转载请注明出处
MySQL联合查询 联合查询:union,将多次查询(多条select语句)的结果,在字段数相同的情况下,在记录的层次上进行拼接。...执行如下 SQL 语句,进行测试: — 联合查询,默认去重 select * from class union distinct select * from class; — 联合查询,保留所有记录 select...特别地,联合查询只要求字段数相同,而跟类型无关。...意义 联合查询的意义有两种,分别为: 查询同一张表,按时需要不同,例如查询学生信息,要求男生按年龄升序排序,女生按年龄降序排序; 多表查询,多张表的结构是完全一样的,保持的数据结构也是一样的。...根据我们刚刚学到的联合查询,貌似很容易啊!
Mysql 一、.mysql修改 1.修改字段类型、字段名、字段注释、字段默认值 #修改字段类型、字段注释、字段默认值 ALTER TABLE 表名 MODIFY [COLUMN] 字段名 新数据类型...新注释; -- COLUMN关键字可以省略不写 alter table box modify column boxnum varchar(40) not null comment '编号' 2.修改字段名...mysql修改字段名: ALTER TABLE 表名 CHANGE [column] 旧字段名 新字段名 新数据类型; alter table table1 change column1 column1...varchar(100) DEFAULT 1.2 COMMENT '注释'; -- 正常,此时字段名称没有改变,能修改字段类型、类型长度、默认值、注释 alter table table1 change...change column2 column1 decimal(10,1) DEFAULT NULL COMMENT '注释' -- 正常,能修改字段名、字段类型、类型长度、默认值、注释 alter
虽然知道了是什么,也知道了为什么,但是我也一直好奇底层是怎么实现的,所以今天我们来扒一扒它的庐山真面目。 1....语法回顾 先来简单的回顾一下 select 语句中 limit, offset 的语法,MySQL 支持 3 种形式: LIMIT limit: 因为没有指定 offset,所以 offset = 0,...最佳实践 既然在 offset 变大之后,使用 limit, offset 效率越来越低,那应该怎么办呢?...如果要支持跳着翻页,怎么办?...ID,然后用这些主键 ID 去 MySQL 中查询对应的数据,从而用两把锤子间接的实现了分页功能。
虽然知道了是什么,也知道了为什么,但是我也一直好奇底层是怎么实现的,所以今天我们来扒一扒它的庐山真面目。 1....最佳实践 既然在 offset 变大之后,使用 limit, offset 效率越来越低,那应该怎么办呢?...如果要支持跳着翻页,怎么办?...ID,然后用这些主键 ID 去 MySQL 中查询对应的数据,从而用两把锤子间接的实现了分页功能。...以上就是本文全部内容了,给坚持看到的这点的朋友点个赞 ^_^ 预告一下,接下来会写一篇不带 WHERE 条件的查询语句的执行过程,敬请期待!
一、分页需求: 客户端通过传递start(页码),pageSize(每页显示的条数)两个参数去分页查询数据库表中的数据,那我们知道MySql数据库提供了分页的函数limit m,n,但是该函数的用法和我们的需求不一样...,所以就需要我们根据实际情况去改写适合我们自己的分页语句,具体的分析如下: 比如: 查询第1条到第10条的数据的sql是:select * from table limit 0,10; ->对应我们的需求就是查询第一页的数据...:select * from table limit (1-1)*10,10; 查询第11条到第20条的数据的sql是:select * from table limit 10,10; ->对应我们的需求就是查询第二页的数据...:select * from table limit (2-1)*10,10; 查询第21条到第30条的数据的sql是:select * from table limit 20,10; ->对应我们的需求就是查询第三页的数据...三、附文: 上文仅介绍了MySQL分页的计算公式,如果数据较多时直接使用limit会耗时比较长,详情请阅读: https://www.cnblogs.com/youyoui/p/7851007.html
领取专属 10元无门槛券
手把手带您无忧上云