首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL自增id超大问题查询

问题排查 这张表是一个简单的接口服务在使用,每天大数据会统计一大批信息,然后推送给小A,小A将信息更新到数据库中,如果是新数据就插入,旧数据就更新之前的数据,对外接口就只有查询了。...查了资料之后,小A得知,原来,mysql主键自增有个参数innodb_autoinc_lock_mode,他有三种可能只0,1,2,mysql5.1之后加入的,默认值是1,之前的版本可以看做都是0。...可以使用下面的语句看当前是哪种模式 select @@innodb_autoinc_lock_mode;  小A使用的数据库默认值也是1,当做简单插入(可以确定插入行数)的时候,直接将auto_increment...ON DUPLICATE KEY UPDATE ...语句拆开,先去查询,然后去更新,这样就可以保证主键不会不受控制的增大,但增加了复杂性,原来的一次请求可能变为两次,先查询有没有,然后去更新。...删除表的自增主键 删除自增主键,让唯一索引来做主键,这样子基本不用做什么变动,只要确定目前的自增主键没有实际的用处即可,这样的话,插入删除的时候可能会影响效率,但对于查询多的情况来说,小A比较两种之后更愿意选择后者

4.9K20

Mysql数据库-子查询

Mysql数据库-子查询 1. 什么是子查询 # 子查询定义 ## B语句作为A语句的一部分,B语句是select查询语句,那么B语句称之为子查询,内层查询(子集,subquery) -- 1....查询每个部门的id,name和对应的员工个数 -- 方案一: 连接查询:通过部门连接查询,然后分组统计来查询员工的个数(常用解法) select dept....select count(*) from emp where emp.dept_id = dept.id ) 个数 from dept; -- 执行如下: mysql> select...若子查询中使用了聚合函数,必须取别名, 外部语句引用时会报错 1. 查询每个部门的id,name和对应的员工个数(需求同上,换种写法) -- a....查询每个部门的id,name和对应的员工个数(需求同上,换种写法) -- 1.1 从员工表按dept_id分组得到对应的员工个数 mysql> select dept_id,count(dept_id

45.4K10

MySQL数据库查询

group by + 聚合函数的使用 -- 统计不同性别的人的平均年龄 select gender,avg(age) from students group by gender; -- 统计不同性别的人的个数...as s inner join classes as c on s.cls_id = c.id; 3、小结 内连接使用inner join .. on .., on 表示两个表的连接查询条件 内连接根据连接查询条件取出两个表的...查询学生在班的所有班级名字: select name from classes where id in (select cls_id from students where cls_id is not...SQL语句,子查询被嵌入到一对小括号里面 数据库设计之三范式 1、数据库设计之三范式的介绍 范式: 对设计数据库提出的一些规范,目前有迹可寻的共有8种范式,一般遵守3范式即可。...E-R模型由 实体、属性、实体之间的关系构成,主要用来描述数据库中表结构。

18.5K20

MYSQL数据库-复合查询

MYSQL数据库-复合查询 零、前言 一、基本查询 二、多表查询 三、自连接 四、子查询 1、单行子查询 2、多行子查询 3、多列子查询 3、在from子句中使用子查询 五、合并查询 1、union 2...、union all 零、前言 本章主要讲解学习MYSQL数据库中的复合查询,前面我们讲解的mysql表的查询都是对一张表进行查询,在实际开发中这远远不够 一、基本查询 示例: 查询工资高于500...worker,给自己的表起别名,因为要先做笛卡尔积,所以别名可以先识别 四、子查询查询是指嵌入在其他sql语句中的select语句,也叫嵌套查询 1、单行子查询 返回一行记录的子查询...,单行数据;多行子查询是指返回单列多行数据,都是针对单列而言的,而多列子查询则是指查询返回多个列数据的子查询语句 示例:查询和SMITH的部门和岗位完全相同的所有雇员,不含SMITH本人 3、在from...子句中使用子查询查询语句出现在from子句中。

13.2K30

MySQL数据库——连接查询

概述: 连接查询的作用将多张表进行内容上的连接,查看数据时可以同时看到多张表的多个数据 连接查询的分类 内连接查询 左连接查询 右连接查询 自连接查询 语法 #内连接 SELECT * FROM...a_table a inner join b_table b on a.a_id = b.b_id; #左连接 SELECT * FROM a_table a left join b_table b...ON a.a_id = b.b_id; #右连接 SELECT * FROM a_table a right outer join b_table b on a.a_id = b.b_id;...#自连接 SELECT * FROM a_table a inner join a_table a on a.a_id = a.b_id; 分类 内连接查询 inner join 实现多表查询查询共有记录...SELECT * FROM 表1 right join 表2 on 表1.字段=表2.字段 自连接查询 inner join 左表和右表是同一个表,查询两个表中的数据。

53.8K85

mysql数据库查询数据的语句怎么写_mysql数据库多表查询

命令:mysql>select id, Sum(score) from result group by id; 多表查询 一、等值查询 现在有两个表: 现在要查询年龄小于20岁学生的不及格成绩...语句:select stu.id,score from stu,result where stu.id = result.id and age < 20 and score < 60; 它的查询如下图所示...: 可见等值查询效率太低 二、连接查询 1、外连接查询 (1)左外连接查询 假设我们依旧使用的是上面的两个表,任然查询年龄小于20岁学生的不及格成绩 我们利用左外连接查询,先将学生表中所有年龄小于...如果存在左表中过滤出来的数据,右表没有匹配上,这样的话右表就会出现NULL; (2)右外连接查询 select a.id,score from (select id,age from stu where...2、内连接查询 只筛选匹配结果 比如过滤的结果如下: 最后的结果为: 只匹配我们需要的结果 语句为: select a.id,score from (select id,

29.8K20

MySQL数据库】详细讲解MySQL查询

图片多表查询⭐多表关系在项目开发中,在进行数据库表结构设计时,会根据业务需求以及业务模块之间的关系,分析并设计表结构,由于业务之间相互关联,所以各个表结构之间也存在各种联系,基本分为以下三种一对多(多对一...into course values (null,'java'),(null,'php'),(null,'mysql'),(null,'c嘎嘎');图片️‍创建第三个表 通过第三个表来维护他们之间的关系...=student.id;图片⭐内连接图片隐式内连接select 字段列表 from 表1,表2 where 条件……;查询学生的姓名以及关联的课程select student.name,course.name...查询学生的姓名以及关联的课程select student.name,course.name from student inner join course on student.id=course.id...,或者文章有问题,欢迎大家在评论区讨论,指正我正在参与 腾讯云开发者社区数据库专题有奖征文。

23240

MySQL 模糊查询MySQL 数据库 like 语句通配符模糊查询小结

MySQL 报错:Parameter index out of range (1 > number of parameters, which is 0)——MySQL 数据库 like 语句通配符模糊查询小结...文章目录 MySQL 报错:Parameter index out of range (1 > number of parameters, which is 0)——MySQL 数据库 like 语句通配符模糊查询小结...前言 一、分析 SQL 语句 1.1、普通 SQL 语句的查询分析 1.2、普通 SQL 查询语句如何处理 1.3、使用 like 通配符模糊查询语句分析 二、like 语句使用通配符模糊查询剖析 2.1...、like 语句的应用场景 2.2、模糊查询剖析 2.3、正确语句 三、MyBatis like 模糊查询及关键字区分 总结 ---- 前言 今天在使用 MySQL 语句执行增删改查操作时,控制台报出了以下错误...like concat('%',#{name},'%') order by ${id}; ---- 总结 本文分别对执行普通 SQL 语句以及使用 like 语句进行通配符模糊查询遇到错误进行了剖析

14.8K40

sql语句查询到整个数据库的容量

在需要备份数据库里面的数据时,我们需要知道数据库占用了多少磁盘大小,可以通过一些sql语句查询到整个数据库的容量,也可以单独查看表所占容量。...2、查询所有的数据大小 select concat(round(sum(DATA_LENGTH/1024/1024),2),'M') from tables; -- 查询所有的数据大小   3、查询某个表的数据...中有一个information_schema数据库,这个数据库中装的是mysql的元数据,包括数据库信息、数据库中表的信息等。...所以要想查询数据库占用磁盘的空间大小可以通   过对information_schema数据库进行操作。...information_schema中的表主要有:   schemata表:这个表里面主要是存储在mysql中的所有的数据库的信息   tables表:这个表里存储了所有数据库中的表的信息,包括每个表有多少个列等信息

1.2K70

MySQL数据库——多表查询之内连接查询、外连接查询、子查询

`id`; 3)内连接查询注意事项: 从哪些表中查询; 条件是什么; 查询哪些字段; 1.2.2 外连接查询 1)左外连接:查询的是左表所有的数据及其交集部分。...`dept_id` = t2.`id`; -- 使用左外连接查询 SELECT t1.*,t2.`NAME` FROM emp t1 LEFT JOIN dept t2 ON t1....`dept_id` = t2.`id`; ? 2)右外连接:查询的是右表所有的数据及其交集部分。...2)子查询的结果是多行单列的 子查询可以作为条件,使用运算符in来判断 -- 查询财务部、市场部所有的员工信息 SELECT id FROM dept WHERE NAME = '财务部' OR NAME...= '市场部'; SELECT * FROM emp WHERE dept_id IN(2,3); -- 查询结果多行单列 SELECT * FROM emp WHERE dept_id IN(

11.7K10
领券