《SQL初学者指南(第2版)》——1.2 Microsoft SQL Server、MySQL和Oracle

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
简介:

本节书摘来自异步社区出版社《SQL初学者指南(第2版)》一书中的第1章,第1.2节,作者:【美】Larry Rockoff,更多章节内容可以访问云栖社区“异步社区”公众号查看。

1.2 Microsoft SQL Server、MySQL和Oracle

尽管我们的目标是介绍SQL的核心语言,因为它适用于所有的实现,但是,我也会提供SQL语法的一些具体示例。由于各个厂商的语法各异,我决定重点关注如下这3种数据库所使用的SQL语法:

Microsoft SQL Server;
Oracle;
MySQL。
大多数情况下,这些数据库有着相同的语法。然而,偶尔也会有所不同。如果这3种数据库之间有任何的差异,本书的正文中将会采用Microsoft SQL Server的语法,我会像下面这样,专门指出MySQL或Oracle在语法上的不同之处。

数据库的差异
 

当我要介绍Oracle数据库或MySQL数据库的不同语法时,就会以“数据库的差异”这样的版块给出。正文中则会给出Microsoft SQL Server的语法。
Microsoft SQL Server有好几个可用的版本。最新的版本叫做Microsoft SQL Server 2016;既有基础的Express版,又有功能齐全的企业(Enterprise)版。尽管Express版是免费的,但是它仍然有着丰富的功能,可以用来进行完整的数据库开发。企业版包括许多高级的数据库管理功能以及高级的商务智能组件。

尽管MySQL属于Oracle公司,但它是一款开源的数据库,这意味着没有一家独立的机构控制其开发。除了Windows外,MySQL还可以在许多平台上运行,诸如Mac OS X和Linux。MySQL提供了社区版(Community Edition)供免费下载。其最新版本是MySQL 5.7。

Oracle数据库也有多个可用的版本。最新的版本是Oracle Database 12c。Oracle数据库的免费版本叫做Express版。

作为初学者,请根据自己的选择去下载数据库,以便能够进行尝试,这么做有时候是很有用的。但是,本书并不需要你这么做。本书的编写方法是,允许你通过只阅读正文来学习SQL。在正文中,我会提供足够的数据,你无需下载软件或亲自输入语句,也能理解各种SQL语句的结果。

尽管如此,如果你想要下载这些数据库的免费版本,本书的附录A到附录C针对如何下载给出了一些介绍和建议。附录A针对如何开始使用Microsoft SQL Server给出了详尽的说明,包括如何安装软件以及执行SQL命令的详细介绍。附录B介绍的是MySQL,而附录C介绍的是Oracle。

正如前言所提到的,本书的配套网站提供了本书在3种数据库中所用到的、所有SQL语句的辅助材料。然而,你很可能会发现根本不需要下载或阅读配套网站上的补充材料。本书中所有的示例,都是一看便知的,不需要为了理解这些内容而做任何事情。但是,如果你愿意去下载的话,那就利用好这些额外材料吧!

此外应该注意的是,除了Microsoft SQL Server、Oracle和MySQL以外,还有一些其他的比较流行的关系型数据库值得了解。例如:

IMB的DB2;
IBM的Informix;
Sybase的SQL Anywhere;
开源数据库PostgreSQL;
Microsoft的Microsoft Access。
在这些数据库中,Microsoft Access有一些特别,它有一个图形化元素。其实,Access是关系型数据库的一个图形化界面。换句话讲,Access允许我们完全通过图形化的方法,来为关系型数据库创建一个查询。对于初学者来讲,Access最有用的一点,就是可以用可视化的方法很容易地创建一个查询,然后切换到SQL视图去查看刚刚创建的SQL语句。Access的另一个不同之处在于,它是一个桌面数据库。因此,我们不仅可以使用Access来创建一个完全以单个的文件形式保存在计算机上的数据库,而且还可以连接到用其他工具(诸如Microsoft SQL Server)创建的数据库。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
SQL 数据采集 关系型数据库
实现MySQL与SQL Server之间数据迁移的有效方法
总的来说,从MySQL到SQL Server的数据迁移是一个涉及到很多步骤的过程,可能会遇到各种问题和挑战。但只要精心规划、仔细执行,这个任务是完全可以完成的。
134 18
|
3月前
|
Oracle 关系型数据库 MySQL
Oracle linux 8 二进制安装 MySQL 8.4企业版
Oracle linux 8 二进制安装 MySQL 8.4企业版
101 1
|
3月前
|
SQL Oracle 关系型数据库
解决大小写、保留字与特殊字符问题!Oracle双引号在SQL中的特殊应用
在Oracle数据库开发中,双引号的使用是一个重要但易被忽视的细节。本文全面解析了双引号在SQL中的特殊应用场景,包括解决标识符与保留字冲突、强制保留大小写、支持特殊字符和数字开头标识符等。同时提供了最佳实践建议,帮助开发者规避常见错误,提高代码可维护性和效率。
150 6
|
4月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
|
5月前
|
SQL Oracle 关系型数据库
MySQL 和 Oracle 的区别?
本文对比了Oracle和MySQL数据库的多个方面。Oracle适用于大型数据库,支持高并发和大访问量,市场占有率为40%,安装占用空间较大,约3G;而MySQL适合中小型应用,是开源免费的,安装仅需152M。两者在主键生成、字符串处理、SQL语句、事务处理等方面存在差异。Oracle功能更为强大,尤其在企业级应用中表现突出,而MySQL则以简单易用见长。
519 7
MySQL 和 Oracle 的区别?
|
4月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】yashandb执行包含带oracle dblink表的sql时性能差
【YashanDB知识库】yashandb执行包含带oracle dblink表的sql时性能差
|
4月前
|
Oracle 关系型数据库 MySQL
使用崖山YMP 迁移 Oracle/MySQL 至YashanDB 23.2 验证测试
这篇文章是作者尚雷关于使用崖山YMP迁移Oracle/MySQL至YashanDB 23.2的验证测试分享。介绍了YMP的产品信息,包括架构、版本支持等,还详细阐述了外置库部署、YMP部署、访问YMP、数据源管理、任务管理(创建任务、迁移配置、离线迁移、校验初始化、一致性校验)及MySQL迁移的全过程。
|
5月前
|
SQL 关系型数据库 MySQL
基于SQL Server / MySQL进行百万条数据过滤优化方案
对百万级别数据进行高效过滤查询,需要综合使用索引、查询优化、表分区、统计信息和视图等技术手段。通过合理的数据库设计和查询优化,可以显著提升查询性能,确保系统的高效稳定运行。
180 9
|
4月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】共享利用Python脚本解决Oracle的SQL脚本@@用法
本文来自YashanDB官网,介绍如何处理Oracle客户端sql*plus中使用@@调用同级目录SQL脚本的场景。崖山数据库23.2.x.100已支持@@用法,但旧版本可通过Python脚本批量重写SQL文件,将@@替换为绝对路径。文章通过Oracle示例展示了具体用法,并提供Python脚本实现自动化处理,最后调整批处理脚本以适配YashanDB运行环境。
|
6月前
|
监控 Oracle 关系型数据库
Mysql、Oracle审计日志的开启
通过上述步骤,可以在 MySQL 和 Oracle 数据库中启用和配置审计日志。这些日志对于监控数据库操作、提高安全性和满足合规性要求非常重要。确保正确配置审计参数和策略,定期查看和分析审计日志,有助于及时发现并处理潜在的安全问题。
273 11

推荐镜像

更多