实际开发中我印象最深的一道SQL题目

简介: SQL不仅是一个工具,更是一种思维方式,它可以帮助我们发掘数据中的潜在价值,为业务决策提供有效的支持。在软件开发过程中,数据库也是很重要的一环。

SQL概述以及发展历程:

大多数数据库均使用SQL作为共同的数据存取语言和标准接口,使不同数据库系统之间的互操作有了共同的基础。SQL提出1974年,由IBM研究员发布了一篇揭开数据库技术的论文《SEQUEL:一门结构化的英语查询语言》,直到现在这门结构化的查询语言并没有太大的变化,想对比其他语言,SQL的半衰期可以说非常长了。SQL(Structured Query Language,结构化查询语言),称为许多数据库的标准语言,SQL标准也经历了不断发展的过程,增加了很多的功能与改变。目前没有一个数据库能够支持SQL标准的所有概念和特性,许多软件厂商对SQL基本命令集还进行了不同程度的扩充和修改,又可以支持标准以外的一些特性。

image.png


开发中遇到的SQL功能点:

在实际的开发中,可以说任何一个项目来说,都要使用到数据库的操作,也就离不开与sql进行打交道,目前市场上面常用的数据库有mysql、SQL Server、Oracle,这三种关系型数据库;还有一些就是NSQL的数据库,一般很少使用常规的sql语句进行编写处理。常用的功能就是报表的处理,在sql中实现报表的方式有很多种,最经典的是分页查询,然后汇总结果集的处理;比如说在一个大的数据库中需要查询出来本月里面,关于门票的售卖最多的是那个经典,这个就要使用到关联查询以及分页查询还有就是求出最大值的计算等等;涉及到的函数有max、group by、datediff、等等操作;

在查询比较慢的时候,需要对数据库表进行创建索引的方式提升查询的速度,比如说门票的基本信息表、门票的售卖表、订单表等等,这些表至少每个表都要一个主键、多个外键的处理。还有就是时间字段需要创建聚合索引等等方式来进行处理,便于根据时间查询的时候速度表快。

image.png

阿里云瑶池数据库SQL挑战赛题目解析:

通过本次参与阿里云瑶池数据库sql挑战赛,发现本次的三道题目都比较经典,本次参与的题目是:“编写一个SQL查询,找出每个考试中 得分最高的的考生 。若同一个考生有多条考试记录,则取最高分。如果存在并列,将并列的考生都列举出来,直到列举的考生达到或超过三人。”,这个是平时我们所经常会见到的题目,本人的解题思路是,首先需要查询分数表,求出分数表里面的最大值,然后关联查询测试表以及学生信息表,需要根据分数表查询出来,分数的个数,然后进行倒叙排列出来。

image.png

最后:

SQL已经深入到开发者的日常工作中,因为项目是要与数据打交道的,一个项目的核心就是数据,只不过是数据化的信息,比如说任何一个项目都有主业务一样,如何把项目可以数字化的帮助企业进行增加营收,以及减轻员工的工作是每个开发者的目标,只有不断的提升自己的能力,掌握更加先进的技术,才能实现这个目标。

相关文章
|
5月前
|
SQL 关系型数据库 MySQL
【MySQL】根据binlog日志获取回滚sql的一个开发思路
【MySQL】根据binlog日志获取回滚sql的一个开发思路
|
4月前
|
SQL 安全 Go
SQL注入不可怕,XSS也不难防!Python Web安全进阶教程,让你安心做开发!
在Web开发中,安全至关重要,尤其要警惕SQL注入和XSS攻击。SQL注入通过在数据库查询中插入恶意代码来窃取或篡改数据,而XSS攻击则通过注入恶意脚本来窃取用户敏感信息。本文将带你深入了解这两种威胁,并提供Python实战技巧,包括使用参数化查询和ORM框架防御SQL注入,以及利用模板引擎自动转义和内容安全策略(CSP)防范XSS攻击。通过掌握这些方法,你将能够更加自信地应对Web安全挑战,确保应用程序的安全性。
106 3
|
5月前
|
SQL NoSQL 数据库
开发效率与灵活性:SQL vs NoSQL
【8月更文第24天】随着大数据和实时应用的兴起,数据库技术也在不断发展以适应新的需求。传统的SQL(结构化查询语言)数据库因其成熟的数据管理机制而被广泛使用,而NoSQL(Not Only SQL)数据库则以其灵活性和扩展性赢得了众多开发者的青睐。本文将从开发者的视角出发,探讨这两种数据库类型的优缺点,并通过具体的代码示例来说明它们在实际开发中的应用。
137 1
|
4月前
|
SQL 分布式计算 大数据
大数据开发SQL代码编码原则和规范
这段SQL编码原则强调代码的功能完整性、清晰度、执行效率及可读性,通过统一关键词大小写、缩进量以及禁止使用模糊操作如select *等手段提升代码质量。此外,SQL编码规范还详细规定了代码头部信息、字段与子句排列、运算符前后间隔、CASE语句编写、查询嵌套、表别名定义以及SQL注释的具体要求,确保代码的一致性和维护性。
121 0
|
5月前
|
SQL 关系型数据库 MySQL
SQL Server、MySQL、PostgreSQL:主流数据库SQL语法异同比较——深入探讨数据类型、分页查询、表创建与数据插入、函数和索引等关键语法差异,为跨数据库开发提供实用指导
【8月更文挑战第31天】SQL Server、MySQL和PostgreSQL是当今最流行的关系型数据库管理系统,均使用SQL作为查询语言,但在语法和功能实现上存在差异。本文将比较它们在数据类型、分页查询、创建和插入数据以及函数和索引等方面的异同,帮助开发者更好地理解和使用这些数据库。尽管它们共用SQL语言,但每个系统都有独特的语法规则,了解这些差异有助于提升开发效率和项目成功率。
565 0
|
6月前
|
JSON 数据格式 SQL
SQL开发问题之直接使用join方法在处理字符串类型属性时可能会遇到性能问题如何解决
SQL开发问题之直接使用join方法在处理字符串类型属性时可能会遇到性能问题如何解决
|
6月前
|
SQL
SQL开发问题之使用distmapjoin的问题如何解决
SQL开发问题之使用distmapjoin的问题如何解决
|
6月前
|
SQL
SQL开发问题之当从数据源读取多个字段时优化 COUNT(DISTINCT ...) 的查询的问题如何解决
SQL开发问题之当从数据源读取多个字段时优化 COUNT(DISTINCT ...) 的查询的问题如何解决
|
6月前
|
SQL 分布式计算 MaxCompute
SQL开发问题之对于ODPS中的UNION操作,执行计划的问题如何解决
SQL开发问题之对于ODPS中的UNION操作,执行计划的问题如何解决
|
6月前
|
分布式计算 MaxCompute SQL
SQL开发问题之如何判断mapjoin是否生效
SQL开发问题之如何判断mapjoin是否生效