
1.计算年数
如果您想通过生日来计算这个人的年龄,可以用以下的语句来实现:
SELECT
DATE_FORMAT(FROM_DAYS(TO_DAYS(now())
-
TO_DAYS(@dateofbirth)),
'%Y')
+
0
2.两个时间的差
取得两个
datetime
值的差。假设
dt1
和
dt2
是
datetime
类型,其格式为
‘yyyy-mm-dd
hh:mm:ss',那么它们之间所差的秒数为:UNIX_TIMESTAMP(
dt2
)
-
UNIX_TIMESTAMP(
dt1
)
除以60就是所差的分钟数,除以3600就是所差的小时数,再除以24就是所差的天数。
3.显示某一列出现过N次的值
SELECT
id
FROM
tbl
GROUP
BY
id
HAVING
COUNT(*)
=
N
4.计算两个日子间的工作日
所谓工作日就是除出周六周日和节假日。
SELECT
COUNT(*)
FROM
calendar
WHERE
d
BETWEEN
Start
AND
Stop
AND
DAYOFWEEK(d)
NOT
IN(1,7)
AND
holiday=0
5.查找表中的主键
SELECT
k.column_name
FROM
information_schema.table_constraints
t
JOIN
information_schema.key_column_usage
k
USING
(constraint_name,table_schema,table_name)
WHERE
t.constraint_type='PRIMARY
KEY'
AND
t.table_schema='db'
AND
t.table_name=tbl'
6.查看你的数库有多大
SELECT
table_schema
AS
'Db
Name',
Round(
Sum(
data_length
+
index_length
)
/
1024
/
1024,
3
)
AS
'Db
Size
(MB)',
Round(
Sum(
data_free
)
/
1024
/
1024,
3
)
AS
'Free
Space
(MB)'
FROM
information_schema.tables
GROUP
BY
table_schema
关于MySQL数据库的比较有用的SQL语句的介绍就到这里了.
当MySQL表字段设置 unique key 或者 primary key 时,被约束的字段就必须是唯一的。新插入数据直接使用 insert into ,如果出现唯一性冲突,就会抛出异常。我们应该根据需求选择合适的插入语句。
为了演示,我们先新建一张user表,SQL语句如下:
当插入数据时,如果唯一性校验出现重复问题,则报错;
如果没有重复性问题,则执行插入 *** 作。
简单总结:重复则直接报错,sql 语句不执行,不重复则插入。
执行结果
当插入数据时,如果唯一性校验出现重复问题,则忽略错误,只以警告形式返回,不执行此SQL语句;
如果没有重复性问题,则执行插入 *** 作。
简单总结:重复则忽略,sql 语句不执行,不重复则插入。
示例
执行结果
当插入数据时,如果唯一性校验出现重复问题,则在原有记录基础上,更新指定字段内容,其它字段内容保留;
如果没有重复性问题,则执行插入 *** 作。
简单总结:重复则更新指定字段,不重复则插入。
示例
执行结果
表记录, mobile_phone_number 从 '13800000077' 更新为 '13800000088' 了, update_time 也从 NULL 更新为有值了,但是 id 没有变:
replace into表示插入替换数据,当插入数据时,如果唯一性校验出现重复问题,删除旧记录,插入新记录;
如果没有重复性问题,则执行插入 *** 作,效果和insert into是一样的。
简单总结:重复则先删除再插入新记录,不重复则插入
。
示例
执行结果
表记录, id 和 mobile_phone_number 变了, update_time 变为了字段默认值 NULL :
replace into 执行的逻辑:
示例一
示例一 insert into ... on deplicate key update *** 作在 binlog 中记录为:
示例二
示例二 replace into *** 作在binlog中记录为:
从示例可以看出,使用 replace into 会有以下问题:
执行结果
因为全部列都是指定的值,所以,相当于所有字段全部更新了一次。
binlog 中的记录:
如果出现重复异常,希望捕获异常,则使用 insert into
如果出现重复异常,希望保存旧纪录,忽略新纪录,则使用 insert ignore into
如果出现重复异常,希望更新指定字段,则使用 insert into … on duplicate key update
如果出现重复异常,希望删除旧记录,插入新记录,则使用 replace into 。
https://blog.csdn.net/ThinkWon/article/details/106610789
https://dsb123dsb.github.io/2019/01/13/%E4%B8%80%E6%AE%B5replace-into-%E5%BC%95%E5%8F%91%E7%9A%84%E8%A1%80%E6%A1%88/
https://blog.csdn.net/quuqu/article/details/110636263
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)