《SQL与关系数据库理论——如何编写健壮的SQL代码》一2.6 SQL中的标量类型

简介: 本节书摘来华章计算机《SQL与关系数据库理论——如何编写健壮的SQL代码》一书中的第2章 ,第2.6节 C. J. Date 著 单世民 何英昊 许侃 译 更多章节内容可以访问云栖社区“华章计算机”公众号查看。</span> 2.

本节书摘来华章计算机《SQL与关系数据库理论——如何编写健壮的SQL代码》一书中的第2章 ,第2.6节 C. J. Date 著 单世民 何英昊 许侃 译 更多章节内容可以访问云栖社区“华章计算机”公众号查看。

2.6 SQL中的标量类型

SQL或多或少支持下列可自解释的系统定义标量类型(SQL也允许用户定义自己的类型,不过本章中基本上都会忽略用户定义类型):

BOOLEAN    INTEGER            CHARACTER(n)
        SMALLINT        CHARACTER VARYING(n)
        BIGINT            CHARACTER LARGE OBJECT(n)
        NUMERIC(p,q)        BINARY(n)
        DECIMAL(p,q)        BINARY VARYING(n)
        FLOAT(p)        BINARY LARGE OBJECT(n)

这并不是一个完全列表;其他的SQL系统定义类型包括:“XML document”类型(XML),各种“国家字符串类型”(NATIONAL CHARACTER(n)等),各种日期时间类型(DATE,TIME,TIMESTAMP,INTERVAL)。然而,从本书的目标出发,我基本会忽略这些类型。要点包括:

  • 支持大量的默认缩写或别名(比如,对应INTEGER的INT,对应CHARACTER的CHAR,对应CHARACTER VARYING的VARCHAR,对应CHARACTER LARGE OBJECT的CLOB)。
  • 与Tutorial D不同,SQL要求它的各种字符串类型都要有关联的长度声明。
  • 对于各种BINARY类型也是一样。注意:BINARY实际上指的是位串,或者字节串(可能更好);关联的长度说明是按八进制(octets)计算的长度。注14另外,尽管BINARY LARGE OBJECT可以缩写为BLOB,但BINARY和BINARY VARYING根本不能缩写(可能与期望相反)。
  • 严格来说,CHAR并不是真的类型,它应该算是类型生成器。相反,CHAR(25)就是一个类型,可使用值25作为唯一实参来调用CHAR类型生成器获得。而且,类似的说明也适用于前面列表中除了BOOLEAN和各种整数类型(SMALLINT,INTEGER,BIGINT)之外的所有类型事务物。注15然而,简单起见,我会在后文中(至少是大部分时候)忽略此点,继续将CHAR及其他类型生成器按照类型进行使用。
  • 支持这些类型基本惯用格式的字面值。
  • 所有这些类型都支持一个显式赋值运算符。语法是:
SET <scalar variable ref> = <scalar exp> ;

标量赋值在很多其他运算(比如FETCH)被执行时也会被隐式执行。注意:在本书中,所有如上例所示的规范语法定义中,我都会分别使用ref和exp作为reference和expression的缩写。

  • 所有这些类型也都支持一个显式的相等比较运算符。注16语法为:

    
    <scalar exp> = <scalar exp>

    当很多其他运算(比如连接和集合并、分组、消除重复等运算)执行时,相等比较也会被隐式执行。

  • 尤其要注意BOOLEAN类型,需要指出的是尽管它包括在SQL标准之中,但它只被非常少量的主流SQL产品所支持。当然,即使系统并不支持BOOLEAN类型,布尔表达式也总是出现在WHERE、ON和HAVING子句之中。然而,在这样的系统中,所有表都不可以有BOOLEAN类型列,也不能声明BOOLEAN类型的变量。最后,变通(比如,“yes/no列”)在有的时候还是需要的。
  • 最后,除了前述标量类型,SQL也支持所谓的域。然而,SQL的域根本不是类型。相反,它们只是一种不被考虑的“公共列定义”,具有大量超出本书范围的奇怪性质。如果你想使用它们的话就可以用,但是别错误地认为它们是真正的关系域(即类型)。
相关实践学习
体验RDS通用云盘核心能力
本次实验任务是创建一个云数据库RDS MySQL(通用云盘),并通过云服务器ECS对RDS MySQL实例进行压测,体验IO加速和IO突发带来的性能提升;并通过DMS执行DDL,将数据归档到OSS,再结合云盘缩容,体验数据归档带来的成本优势。
相关文章
|
3月前
|
SQL Java 数据库连接
mybatis使用四:dao接口参数与mapper 接口中SQL的对应和对应方式的总结,MyBatis的parameterType传入参数类型
这篇文章是关于MyBatis中DAO接口参数与Mapper接口中SQL的对应关系,以及如何使用parameterType传入参数类型的详细总结。
65 10
|
3月前
|
SQL 存储 关系型数据库
SQL判断CHAR类型字段不为空的方法与技巧
在SQL查询中,判断一个CHAR类型字段是否不为空是一个常见的需求
|
3月前
|
SQL 关系型数据库 MySQL
创建SQL数据库的基本步骤与代码指南
在信息时代,数据管理显得尤为重要,其中数据库系统已成为信息技术架构的关键部分。而当我们谈论数据库系统时,SQL(结构化查询语言)无疑是其中最核心的工具之一。本文将详细介绍如何使用SQL创建数据库,包括编写相应的代码和必要的步骤。由于篇幅限制,本文可能无法达到您要求的2000字长度,但会尽量涵盖创建数
132 3
|
3月前
|
SQL 监控 关系型数据库
SQL错误代码1303解析与处理方法
在SQL编程和数据库管理中,遇到错误代码是常有的事,其中错误代码1303在不同数据库系统中可能代表不同的含义
|
3月前
|
SQL 安全 关系型数据库
SQL错误代码1303解析与解决方案:深入理解并应对权限问题
在数据库管理和开发过程中,遇到错误代码是常见的事情,每个错误代码都代表着一种特定的问题
|
4月前
|
SQL 分布式计算 大数据
大数据开发SQL代码编码原则和规范
这段SQL编码原则强调代码的功能完整性、清晰度、执行效率及可读性,通过统一关键词大小写、缩进量以及禁止使用模糊操作如select *等手段提升代码质量。此外,SQL编码规范还详细规定了代码头部信息、字段与子句排列、运算符前后间隔、CASE语句编写、查询嵌套、表别名定义以及SQL注释的具体要求,确保代码的一致性和维护性。
127 0
|
3天前
|
运维 关系型数据库 MySQL
体验领礼啦!体验自建数据库迁移到阿里云数据库RDS,领取桌面置物架!
「技术解决方案【Cloud Up 挑战赛】」上线!本方案介绍如何将自建数据库平滑迁移至云数据库RDS,解决业务增长带来的运维难题。通过使用RDS MySQL,您可获得稳定、可靠和安全的企业级数据库服务,专注于核心业务发展。完成任务即可领取桌面置物架,每个工作日限量50个,先到先得。
|
20天前
|
运维 关系型数据库 MySQL
自建数据库迁移到云数据库RDS
本次课程由阿里云数据库团队的凡珂分享,主题为自建数据库迁移至云数据库RDS MySQL版。课程分为四部分:1) 传统数据库部署方案及痛点;2) 选择云数据库RDS MySQL的原因;3) 数据库迁移方案和产品选型;4) 线上活动与权益。通过对比自建数据库的局限性,介绍了RDS MySQL在可靠性、安全性、性价比等方面的优势,并详细讲解了使用DTS(数据传输服务)进行平滑迁移的步骤。此外,还提供了多种优惠活动信息,帮助用户降低成本并享受云数据库带来的便利。
|
5月前
|
关系型数据库 MySQL 数据库
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
|
1月前
|
安全 关系型数据库 MySQL
体验自建数据库迁移到云数据库RDS,领取桌面置物架!
「技术解决方案【Cloud Up 挑战赛】」正式开启!本方案旨在帮助用户将自建数据库平滑迁移至阿里云RDS MySQL,享受稳定、高效、安全的数据库服务,助力业务快速发展。完成指定任务即可赢取桌面置物架等奖励,限量供应,先到先得。活动时间:2024年12月3日至12月31日16点。
下一篇
开通oss服务