使用SQL自带的SQL Server Profiler,以可视化界面的方式来查看。
Redis启动的时候,出现如下警告信息:
WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128.
默认Redis程序安装在/usr/local/redis目录下;
配置文件:/usr/local/redis/redis.conf,该配置文件中配置的端口为默认端口:6379;
Redis的启动命令路径:
/usr/local/bin/redis-server
可以指定端口启动多个Redis进程。
#/usr/local/bin/redis-server --port 6380 & #启动6380端口的redis实例。
Redis历时版本下载地址(3.x系列最新版本:redis-3.2.9.tar.gz)
今天同事在同步完订单数据后,由于订单总金额和数据源的总金额存在差异,选择使用LIMIT
和SUM()
函数计算当前分页的总金额来和对方比较特定订单的总金额,却发现计算出来的金额并不是分页的订单总金额,而是所有订单的总金额。
当然P和S的值不可以无限大的,它是有一个范围的:
在MySQL数据库里,p的范围[1, 65],s的范围[0, 33],其中 s<p
如果更新多个值的话,只需要稍加修改:
UPDATE categories SET orderId = CASE id WHEN 1 THEN 3 WHEN 2 THEN 4 WHEN 3 THEN 5 END, title = CASE id WHEN 1 THEN 'New Title 1' WHEN 2 THEN 'New Title 2' WHEN 3 THEN 'New Title 3' END WHERE id IN (1,2,3)
insert into values 或 insert into select批量插入时,都满足事务的原子性与一致性,一条出错整体都会回滚。在使用insert into select时,MySQL会对select的数据加S(读)锁,在事务较为复杂的场景下可能有死锁的风险。
MySQL莫名地报错:
2020-12-08T02:02:32.179362Z 0 [ERROR] InnoDB: The innodb_system data file 'ibdata1' must be writable
今天在把一个数据库的数据导出SQL,然后在另外一个库中执行的时候出现了这个问题,报错:
Row size too large (> 8126). Changing some columns to TEXT or BLOB or using ROW_FORMAT=DYNAMIC or ROW_FORMAT=COMPRESSED may help. In current row format, BLOB prefix of 768 bytes is stored inline.