首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

一次事故,我对MySql时间char(10)还是int(10)有了全新的认识

抓住那只bug 经过我缜密的排查,发现是一个“获取今天之前登录的用户”接口调用严重超时: 这个接口其实调用的数据表不多,在mysql只读取了1张表,表结构如下: 获取今天之前登录的用户列表的SQL如下...如果多人同时访问,MySql不崩溃才怪。 此时,应该确信是这个表出问题无疑了,但是字段log_dtime明明建立了索引,怎么还这么慢呢?...我的数据恰巧都是数字组成(时间),查询的时候也没有刻意去加引号,导致查询的时候不走索引。 这就是问题所在了,于是进行如下尝试: 尝试1: SQL的值加上引号 如上图,果然极快。...尝试2: 果断将数据表结构log_dtime设计为INT型,如图: 再次执行SQL: SELECT log.user_id FROM `log_user_active` WHERE `log_dtime...总结 char类型字段想走索引的话,必须用引号括起来。如果是时间类型的纯数字,建议还是存为int型吧。 愉快的周末,又向我招手了。

97230
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    golang 时间获取、类型转换、时间比较

    获取当前时间、秒级时间time.Now()// 获取当前时间类型为time.Timetime.Unix()// 获取当前时间的秒级时间,时间的起始时间是2006-01-02 15:04:05,go...语言的诞生时间获取任意时间的秒级时间t.Unix()// 获取秒级时间时间时间转换为字符串时间时间字符串timeStr := time.Now().Format("2006-01-02")时间时间字符串...timeTemplate1 := "2006-01-02 15:04:05"t := int64(1546926630) //外部传入的时间(秒为单位),必须为int64类型timeStr...:= time.Unix(t, 0).Format(timeTemplate1)字符串转时间对象方式一time.ParseInLocation()转换成本地时区的时间timeTemplate1 := "...,t1和t2都是time.Time类型hour = diff / 3600 // 相差的小时数

    2.5K40

    日期、时间、PosixTime 和时间数据类型

    数据类型(三)日期、时间、PosixTime 和时间数据类型可以定义日期、时间时间数据类型,并通过标准 SQL 日期和时间函数相互转换日期和时间。...该日期之后的时间由正 %PosixTime 值表示,该日期之前的时间由负 %PosixTime 值表示。 %PosixTime 支持最多 6 位精度的小数秒。...%TimeStamp 是包含 ODBC 格式时间的字符串。...不适合上述任何逻辑值的用户定义时间数据类型应将数据类型的 SqlCategory 定义为 TIMESTAMP,并在数据类型类中提供 LogicalToTimeStamp() 方法以将用户定义的逻辑时间值转换为...DATE 数据类型不能表示 BCE(也称为 BC)日期。TIMESTAMP 数据类型默认为 1840–12–31 00:00:00 作为最早允许的时间

    1.8K10

    java生成时间类型_Java获取当前时间的方法有哪些

    Java获取当前时间的方法有哪些 时间:2017-08-22 来源:华清远见JAVA学院 时间就是一种类型,只是精度很高,比datetime要精确的多,通常用来防止数据出现脏读现象。...那么Java中如何获得时间,Java获得当前时间的方法有哪些呢?...Java获取当前时间的三种方法 //方法 一 System.currentTimeMillis(); //方法 二 Calendar.getInstance().getTimeInMillis();...mm:ss”);//设置日期格式 String date = df.format(new Date());// new Date()为获取当前系统时间,也可使用当前时间 Java获取时间三种方法执行效率比较...以上给出了三种Java获取当前时间的方法,并给出了一个实例,说明哪一种方式速度更慢。

    2.3K10

    mysql时间转为日期格式_mysql时间与日期格式的相互转换

    (‘Y-m-d H:i:s’, 1156219870); 日期转换为UNIX时间用函数:strtotime() strtotime(‘2010-03-24 08:15:42’); MySQL 时间与日期格式的相互转换...U … mysql 时间与日期格式的相互转换 1.UNIX时间转换为日期用函数: FROM_UNIXTIME() ); 输出:2006-08-22 12:11:10 2.日期转换为UNIX时间用函数...: UNIX_TIMESTAMP() Sel … 【学习】mysql 时间与日期格式的相互转换 1.UNIX时间转换为日期用函数: FROM_UNIXTIME() ); 输出:2006-08-22...’, 效果 PHP 代码实现: &l … MySQL 时间与日期互相转换 MySQL 时间与日期互相转换 1.时间转换成日期 函数:FROM_UNIXTIME() ,’%Y年%m月%d日’) 结果为...:2015年04月15日 2.把日期转换为时间,和 FROM_UNIX … MySQL时间时间格式转换函数 MySQL时间时间格式转换函数:unix_timestamp and from_unixtime

    17.6K11

    mysql 获取当前的时间

    1.获取系统当前时间类型:timestamp 格式yyyy-MM-dd HH:mm:ss select NOW(),CURRENT_TIMESTAMP(),SYSDATE(); 结果: 三者基本没有区别...,稍微一点的区别在于:NOW(),CURRENT_TIMESTAMP()都表示SQL开始执行的时间;SYSDATE()表示执行此SQL时的当前时间 select NOW(),CURRENT_TIMESTAMP...,SYSDATE(); 结果:sleep(2)表示等待2s再执行,从结果可以看出SYSDATE在中断前后则相差了2秒;NOW(),CURRENT_TIMESTAMP()完全没区别 2.获取系统当前时间时间...,类型:long 单位:s select unix_timestamp(NOW()), unix_timestamp(CURRENT_TIMESTAMP()), unix_timestamp...unix_timestamp(CURRENT_TIMESTAMP(3)), unix_timestamp(SYSDATE(3)); 结果: 如果直接输出毫秒单位的时间,就是去掉上面中间的小数点

    8.1K30

    遇到的各种时间类型:UTC时间、GMT时间、本地时间、Unix时间

    每次遇到各种时间傻傻分不清,特意记录一下,给自己提个醒。 GMT和UTC GMT,即格林尼治标准时间,也就是世界时。GMT的正午是指当太阳横穿格林尼治子午线(本初子午线)时的时间。...若英国时间为6点整,则GMT时间为6点整,则北京时间为14点整。...UNIX时间 计算机中的UNIX时间,是以GMT/UTC时间「1970-01-01T00:00:00」为起点,到具体时间的秒数,不考虑闰秒。这么做当然是为了简化计算机对时间操作的复杂度。...比如我的电脑现在的系统时间为2015年2月27日15点43分0秒,因为我的电脑默认时区为东8区,则0时区的时间为2015年2月27日7点43分0秒,则UNIX时间为1425022980秒。...int 时间 10 位 带T时间 本地时间 本地时间 = UTC + 时区差 参考 & 引用 世界时_百度百科

    3.3K30

    mysql 时间换成日期格式_mysql 时间与日期格式的相互转换

    1、UNIX时间转换为日期用函数: FROM_UNIXTIME() select FROM_UNIXTIME(1156219870); 输出:2006-08-22 12:11:10 2、日期转换为UNIX...时间用函数: UNIX_TIMESTAMP() Select UNIX_TIMESTAMP(‘2006-11-04 12:23:00’); 输出:1162614180 Select UNIX_TIMESTAMP...(NOW()); 输出当前时间 例:mysql查询当天的记录数: $sql=”select * from message Where DATE_FORMAT(FROM_UNIXTIME(chattime...),’%Y-%m-%d’) = DATE_FORMAT(NOW(),’%Y-%m-%d’) order by id desc”; PHP方式转换: UNIX时间转换为日期用函数: date() date...(‘Y-m-d H:i:s’, 1156219870); 日期转换为UNIX时间用函数:strtotime() strtotime(‘2010-03-24 08:15:42’); 发布者:全栈程序员栈长

    7.3K20
    领券