复杂sql语句集锦

本文主要讲一下笔者在工作中遇到的一些逻辑比较复杂的sql语句,下面是具体写法:

SELECT IF(LOCATE(‘familyKey‘,link,1)=0,NULL,
SUBSTRING(link,LOCATE(‘familyKey‘,link,1)+LENGTH(‘familyKey‘)+1,
IF(LOCATE(‘&‘,link,LOCATE(‘familyKey‘,link,1))=0,LENGTH(link),
LOCATE(‘&‘,link,LOCATE(‘familyKey‘,link,1))-(LOCATE(‘familyKey‘,link,1)+LENGTH(‘familyKey‘)+1)
)
)
) familyKey
FROM illustrations;

  这条语句是将illustrations表中的link字段,如:

...&episType=239&familyKey=90897&illustrationId=6837275...

  这样的字条串中familyKey=后面的90897这样的编号取出来,说白了就是将字符串按关键字截取,得到的数据可组成新表进行下一步数据分析工作。

我们也可以将其分拆一下,写成下面的语句:

SELECT IF(strbegin=0,NULL,SUBSTRING(link,strbegin+strlen+1,IF(strend=0,LENGTH(link),strend-(strbegin+strlen+1)))) familyKey,mainId
FROM (
SELECT mainId,link,strbegin,LOCATE(‘&‘,link,strbegin) strend, LENGTH(‘familyKey‘) strlen
FROM (
SELECT mainId,link,LOCATE(‘familyKey‘,link,1) strbegin
FROM illustrations
) tmp) tmp;

  这样看起来就有条理多了,一,两条语句中都涉及了IF条件判断这些所谓的动态查询的知识点,写完还是小有成就感。

下面介绍一下mysql5.7中的一大亮点改进——对Json数据类型的支持

CREATE TABLE maingroup_id_parentId AS
SELECT n1.id AS parentId,n2.id AS id
FROM nav n1,nav n2
WHERE n1.meta->‘$.model‘ = n2.parent_meta->‘$.model‘
AND n1.meta->‘$.spec‘ = n2.parent_meta->‘$.spec‘
AND n1.meta->‘$.lang‘ = n2.parent_meta->‘$.lang‘
AND n1.meta->‘$.startup‘ = n2.parent_meta->‘$.startup‘
AND n1.meta->‘$.localMarketOnly‘ = n2.parent_meta->‘$.localMarketOnly‘
AND n2.nav_table = ‘nav-mainGroup-table‘
AND n1.nav_table <> ‘nav-mainGroup-table‘;

  这条语句是将nav表中建立在以model,spec,lang,startup,localMarketOnly这几个关键字为联系的基础上的上下层级关系找出来,建成子表maingroup_id_parentId,然后做进一步数据整理。语句中用到了meta这个Json类型的字段,其使用方式简便、表义清晰,十分适合对类似带数据参数的请求地址的存储。在处理大数据量的表间关系时,上面的用法可能就不实用了,因为效率太差,一条语句可能很久都跑不出来,盲目地等待是没有任何意义的,我是不会做这种事情,所以我们必须找到更高效的关联方案。这里可将这些关键字对应的信息从Json字段中提出来单独作为一个字段,并建立索引,然后将它们进行匹配:

-- pnc字段关键字提取
ALTER TABLE pnc ADD pnc_number VARCHAR(20) generated always AS (json_extract(meta,‘$.pnc‘)) virtual;
ALTER TABLE pnc ADD drawingVar VARCHAR(8) generated always AS (json_extract(meta,‘$.drawingVar‘)) virtual;
ALTER TABLE pnc ADD drawing VARCHAR(8) generated always AS (meta->"$.drawing") virtual;
ALTER TABLE pnc ADD subGroup VARCHAR(8) generated always AS (json_extract(meta,‘$.subGroup‘)) virtual;
ALTER TABLE pnc ADD mainGroup VARCHAR(8) generated always AS (json_extract(meta,‘$.mainGroup‘)) virtual;
ALTER TABLE pnc ADD spec VARCHAR(150) generated always AS (json_extract(meta,‘$.spec‘)) virtual;
ALTER TABLE pnc ADD model VARCHAR(50) generated always AS (json_extract(meta,‘$.model‘)) virtual;
-- pnc建索引
ALTER TABLE pnc ADD INDEX link(pnc_number,drawingVar,drawing,subGroup,mainGroup,spec,model);

-- 修改bom表
ALTER TABLE bom ADD pnc_number VARCHAR(20) generated always AS (json_extract(parent_meta,‘$.pnc‘)) virtual;
ALTER TABLE bom ADD drawingVar VARCHAR(8) generated always AS (json_extract(parent_meta,‘$.drawingVar‘)) virtual;
ALTER TABLE bom ADD drawing VARCHAR(8) generated always AS (parent_meta->"$.drawing") virtual;
ALTER TABLE bom ADD subGroup VARCHAR(8) generated always AS (json_extract(parent_meta,‘$.subGroup‘)) virtual;
ALTER TABLE bom ADD mainGroup VARCHAR(8) generated always AS (json_extract(parent_meta,‘$.mainGroup‘)) virtual;
ALTER TABLE bom ADD spec VARCHAR(150) generated always AS (json_extract(parent_meta,‘$.spec‘)) virtual;
ALTER TABLE bom ADD model VARCHAR(50) generated always AS (json_extract(parent_meta,‘$.model‘)) virtual;
-- bom建索引
ALTER TABLE bom ADD INDEX link(pnc_number,drawingVar,drawing,subGroup,mainGroup,spec,model);

-- 造表间关系
DROP TABLE IF EXISTS pnc_bom_id;
CREATE TABLE pnc_bom_id
SELECT bom.id AS bomId,pnc.id AS pncId
FROM nissan_bom bom,nissan_pnc pnc
WHERE bom.pnc_number=pnc.pnc_number
AND bom.drawingVar=pnc.drawingVar
AND bom.drawing=pnc.drawing
AND bom.mainGroup=pnc.mainGroup
AND bom.subGroup=pnc.subGroup
AND bom.spec=pnc.spec
AND bom.model=pnc.model;

时间: 2024-11-04 12:51:38

复杂sql语句集锦的相关文章

SqlServer教程:经典SQL语句集锦

SQL分类: DDL-数据定义语言(CREATE,ALTER,DROP,DECLARE) DML-数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL-数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK) 首先,简要介绍基础语句: 1.说明:创建数据库CREATE DATABASE database-name 2.说明:删除数据库drop database dbname3.说明:备份sql server --- 创建 备份数据的 deviceUSE

sql语句集锦

-语 句--           --功 能-- --数据操作select             --从数据库表中检索数据行和列insert             --向数据库表添加新数据行delete             --从数据库表中删除数据行update             --更新数据库表中的数据 --数据定义create table       --创建一个数据库表drop table         --从数据库中删除表alter table        --修改数据

Mysql 常用 SQL 语句集锦

基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day from table_name"; //int 时间戳类型 $sql = "select from_unixtime(create_time, '%Y-%m-%d') as day from table_name"; //一个sql返回多个总数 $sql = "select count(*) all, &qu

Mysql 常用SQL语句集锦

基础篇 //查询时间,友好提示$sql = "select date_format(create_time, '%Y-%m-%d') as day from table_name";//int 时间戳类型$sql = "select from_unixtime(create_time, '%Y-%m-%d') as day from table_name";//一个sql返回多个总数$sql = "select count(*) all, " ;

常用的sql语句集锦

在当前时间增加时间段 在当前时间加30s update stu_info set last_changed=date_add(now() interval 30 second) 在当前日期减一天 update stu_info set last_changed=date_add(curdate() interval 1 day)

SQL Server中一些有用的日期sql语句

1.一个月第一天的 SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) 2.本周的星期一 SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0) 3.一年的第一天 SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0) 4.季度的第一天 SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0) 5.当天的半夜 SELECT DATEAD

sql语句操作集锦

SQL操作全集 下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK) 首先,简要介绍基础语句: 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname

SQL 函数集锦

一.字符转换函数1.ASCII()返回字符表达式最左端字符的ASCII 码值.在ASCII()函数中,纯数字的字符串可不用‘’括起来,但含其它字符的字符串必须用‘’括起来使用,否则会出错. 2.CHAR()将ASCII 码转换为字符.如果没有输入0 ~ 255 之间的ASCII 码值,CHAR() 返回NULL . 3.LOWER()和UPPER()LOWER()将字符串全部转为小写:UPPER()将字符串全部转为大写. 4.STR()把数值型数据转换为字符型数据.STR (<float_exp

oracle sql语句运行效率

--当前执行sql语句 SELECT a.SID , a.SERIAL# , a.USERNAME , b.PARSE_CALLS , b.PARSING_SCHEMA_NAME , b.CPU_TIME / 1000000 , b.ELAPSED_TIME / 1000000 , b.DISK_READS , b.DIRECT_WRITES , b.BUFFER_GETS , a.event , b.sql_text , b.SQL_FULLTEXTFROM v$session a INNER