《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的域根本不是类型。相反,它们只是一种不被考虑的“公共列定义”,具有大量超出本书范围的奇怪性质。如果你想使用它们的话就可以用,但是别错误地认为它们是真正的关系域(即类型)。
相关实践学习
MySQL数据库快速部署实践
本场景主要介绍如何在一台配置了CentOS 7.7版本的ECS实例(云服务器)上安装mysql,执行mysql的常用操作,学习基本的SQL语句。
相关文章
|
9月前
|
存储 关系型数据库 数据库
附部署代码|云数据库RDS 全托管 Supabase服务:小白轻松搞定开发AI应用
本文通过一个 Agentic RAG 应用的完整构建流程,展示了如何借助 RDS Supabase 快速搭建具备知识处理与智能决策能力的 AI 应用,展示从数据准备到应用部署的全流程,相较于传统开发模式效率大幅提升。
附部署代码|云数据库RDS 全托管 Supabase服务:小白轻松搞定开发AI应用
|
7月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1225 152
|
7月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
912 156
|
SQL 自然语言处理 数据库
【Azure Developer】分享两段Python代码处理表格(CSV格式)数据 : 根据每列的内容生成SQL语句
本文介绍了使用Python Pandas处理数据收集任务中格式不统一的问题。针对两种情况:服务名对应多人拥有状态(1/0表示),以及服务名与人名重复列的情况,分别采用双层for循环和字典数据结构实现数据转换,最终生成Name对应的Services列表(逗号分隔)。此方法高效解决大量数据的人工处理难题,减少错误并提升效率。文中附带代码示例及执行结果截图,便于理解和实践。
313 5
|
8月前
|
SQL 容灾 安全
云时代SQL Server的终极答案:阿里云 RDS SQL Server如何用异地容灾重构系统可靠性
在数字化转型的浪潮中,数据库的高可用性已成为系统稳定性的生命线。作为经历过多次生产事故的资深开发者,肯定深知传统自建SQL Server架构的脆弱性——直到遇见阿里云 RDS SQL Server,其革命性的异地容灾架构彻底改写了游戏规则。
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
4520 11
|
SQL Java 数据库连接
mybatis使用四:dao接口参数与mapper 接口中SQL的对应和对应方式的总结,MyBatis的parameterType传入参数类型
这篇文章是关于MyBatis中DAO接口参数与Mapper接口中SQL的对应关系,以及如何使用parameterType传入参数类型的详细总结。
525 10
|
SQL 存储 关系型数据库
SQL判断CHAR类型字段不为空的方法与技巧
在SQL查询中,判断一个CHAR类型字段是否不为空是一个常见的需求

热门文章

最新文章