温故知新-MYSQL-一些查询技巧
2022-07-28 本文已影响0人
gao922699
查询表里的重复值:
SELECT
first_name, COUNT(first_name),
last_name, COUNT(last_name),
email, COUNT(email)
FROM contacts
GROUP BY first_name , last_name , email
HAVING COUNT(first_name) > 1
AND COUNT(last_name) > 1
AND COUNT(email) > 1;
查询两个表里的差异值:
SELECT id,title FROM (
SELECT id, title FROM t1
UNION ALL
SELECT id,title FROM t2) AS tbl
GROUP BY id, title
HAVING count(*) = 1
ORDER BY id;
UUID()和自增INT主键的对比
优点
使用UUID
作为主键具有以下优点:
-
UUID值在表,数据库甚至在服务器上都是唯一的,允许您从不同数据库合并行或跨服务器分发数据库。
-
UUID值不会公开有关数据的信息,因此它们在URL中使用更安全。例如,如果
ID
为10
的客户通过URL: http://www.example.com/customers/10/ 访问他的帐户,那么很容易猜到有一个客户11
,12
等,这可能是攻击的目标。 -
可以在避免往返数据库服务器的任何地方生成
UUID
值。它也简化了应用程序中的逻辑。 例如,要将数据插入到父表和子表中,必须首先插入父表,获取生成的id
,然后将数据插入到子表中。通过使用UUID
,可以生成父表的主键值,并在事务中同时在父表和子表中插入行。
缺点
除了优势之外,UUID值也有一些缺点:
-
存储UUID值(16字节)比整数(4字节)或甚至大整数(8字节)占用更多的存储空间。
-
调试似乎更加困难,想像一下
WHERE id ='9d6212cf-72fc-11e7-bdf0-f0def1e6646c'
和WHERE id = 10
那个舒服一点? -
使用UUID值可能会导致性能问题,因为它们的大小和没有被排序。
复制表数据
老表数据复制到新表
CREATE TABLE new_table
SELECT col1, col2, col3
FROM
existing_tableWHERE
conditions;
正则查询
REGEXP/NOT REGEXP
SELECT
column_list
FROM
table_name
WHERE
string_column REGEXP pattern;
获取第N个最高纪录
SELECT * FROM table_name ORDER BY column_name DESC LIMIT n - 1, 1;
NULL值替换
SELECT customername,
IFNULL(state,"N/A") state,
countryFROM customersORDER BY country;