起因: 年前写了条SQL,随后直接投产,导致过年期间出现重大事故!!生产环境数据库直接宕机自动触发主备切换,随后出现的该问题,年前新增过的ID在删除数据后,年后新增其他数据的时候出现了之前新增过的ID。 环境: MySQL5.7 问题复现: 往表里增加5条数据,对应的id分别是1、2、3、4、5,这个时候删除掉id是5的数据,show一下表可以看到…
应用场景: 表a为主表,表b为备份表,当表a的数据出现问题,需要根据表b的数据进行回滚 sql: update test a inner join (select b.id, c.name, c.address from test b left join test_tmp c on b.id = c.id) d on a.id = d.id set…
mysql 替换字符串的实现方法: mysql中replace函数直接替换mysql数据库中某字段中的特定字符串,不再需要自己写函数去替换,用起来非常的方便。 mysql 替换函数replace() UPDATE `table_name` SET `field_name` = replace (`field_name`,'from_s…
MySQL目前主要有以下几种索引类型: 普通索引 INDEX 允许出现相同的索引内容 (normal) 唯一索引 UNIQUE 不可以出现相同的值,可以有NULL值 主键索引 PROMARY KEY 不允许出现相同的值(唯一性,且只能有一个) 组合索引 实质上是将多个字段建到一个索引里,列值的组合必须唯一 …
前言 在做一个从api中发起请求获取数组然后同步到本地数据库的功能的时候,数据库太大了,几百万几千万的数据,本身发起请求获取数据的时候就有限制,每次最多只能获取到2w条数据,得请求多次,请求响应又慢,每次请求几乎需要两秒钟才能收到回复,这个时间长,再加上还需要插入数据到数据库(插入是用的foreach),时间更长,唉,只能找解决办法了。晚上看手机的…
记一次事故吧,唉。技术去客户现场部署环境后,运行软件结果发现显示的时候不对。 尽量mysql默认值能不用默认的时间就不要用吧,唉,有坑。 还有,注意实体类date导入的包,千万不要导入sql的包,千万不要!!!! 时间朝前产生的原因还是因为mysql的时区问题。 先在数据库执行show variables like '%time_zone%'; 看…
一、引入Jar包:# <!--Spring Boot依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> &…
Step1:先停止MySQL服务 接下来是卸载旧的MySQL5.7,记得卸载前备份好数据库~ Step2:卸载所有MySQL相关的程序 Step3:我之前5.7的MySQL安装目录在C盘,首先打开C:\Program Files,删除之前的MySQL文件夹 Step4:打开隐藏文件夹ProgramData,删除下面的MySQL文件夹 接下来就是卸载…
新添一列 随着需求的变化,数据库表也不得不随之改变,这个时候就需要插入列到现有表中,插入sql语句格式如下(注意是alter(改变)不是alert(报警)): alter table 表名 add column 列名 类型 ... 加到所有列末尾 ALTER TABLE users ADD COLUMN sex INT(1) NOT NULL DE…
mysql数据库中的关于查询日期的一些操作如下: --今天 select * from 表名 where to_days(时间字段名) = to_days(now()); --昨天 SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1 --本周 SELECT * FRO…