SQL 里“字段类型”因数据库而异,下面按 **MySQL 8.x** 给出最全清单,并附一句话提示,复制即可用,其他库(SQL Server/Oracle/PostgreSQL)在括号里给出常见对应或差异。
| 大类 | 具体类型 | 一句话提示 |
|---|---|---|
| 数值·整型 | `TINYINT[(M)] [UNSIGNED] [ZEROFILL]` | 1 字节,-128~127 或 0~255;布尔可简写 `BOOL`/`BOOLEAN`,实际还是 TINYINT(1)。 |
| | `SMALLINT[(M)] [UNSIGNED]` | 2 字节,±32 K 或 0~65 K。 |
| | `MEDIUMINT[(M)] [UNSIGNED]` | 3 字节,±8 M 或 0~16 M。 |
| | `INT[(M)] [UNSIGNED]` | 4 字节,±21 亿或 0~42 亿;经常简写 `INTEGER`。 |
| | `BIGINT[(M)] [UNSIGNED]` | 8 字节,±9 E 或 0~18 E;雪花 ID 专用。 |
| 数值·浮点 | `FLOAT[(p)] [UNSIGNED]` | 4 字节单精度,p∈0-24;精度要求不高时用。 |
| | `DOUBLE[(M,D)] [UNSIGNED]` | 8 字节双精度;MySQL 里也可写 `REAL`。 |
| 数值·定点 | `DECIMAL[(M[,D])] [UNSIGNED]` | 精确小数,M 总位数,D 小数位;等价 `NUMERIC`、`DEC`。 |
| 字符串·定长 | `CHAR(M) [BINARY]` | 固定 M 字符(非字节),M≤255;尾部空格会被补全或截断。 |
| 字符串·变长 | `VARCHAR(M)` | 最大 M 字符,M≤65535;实际存长度+数据,省空间。 |
| | `TINYTEXT` | 最大 255 字节文本,无默认值。 |
| | `TEXT[(M)]` | 最大 64 KB,常用来存文章、JSON。 |
| | `MEDIUMTEXT` | 16 MB。 |
| | `LONGTEXT` | 4 GB。 |
| 二进制·定长 | `BINARY(M)` | 类似 CHAR,存字节而非字符,比较区分大小写。 |
| 二进制·变长 | `VARBINARY(M)` | 类似 VARCHAR,存字节。 |
| | `TINYBLOB` | 255 字节二进制。 |
| | `BLOB` | 64 KB 二进制,可存图片、文件切片。 |
| | `MEDIUMBLOB` | 16 MB。 |
| | `LONGBLOB` | 4 GB。 |
| 日期时间 | `DATE` | 年月日,3 字节,范围 1000-01-01 ~ 9999-12-31。 |
| | `TIME[(fsp)]` | 时分秒,可选小数秒 0-6 位;3-6 字节。 |
| | `DATETIME[(fsp)]` | 日期+时间,8 字节,无时区;推荐替代 TIMESTAMP。 |
| | `TIMESTAMP[(fsp)]` | 4 字节,范围 1970-2038,自动时区转换,可自动更新 ON UPDATE。 |
| | `YEAR[(4)]` | 1 字节,只存年份 1901-2155。 |
| JSON | `JSON` | 二进制存储,支持路径查询、索引(8.0 生成列)。 |
| 布尔简写 | `BOOLEAN` / `BOOL` | 只是 TINYINT(1) 的同义词,0 为假,非 0 为真。 |
| 枚举 | `ENUM('v1','v2'...)` | 内部整数 1-2 字节,最多 65535 个成员;插入非法值变空串或报错。 |
| 集合 | `SET('a','b','c')` | 多选位字段,最多 64 个成员,占 1-8 字节。 |
| 几何/地理 | `GEOMETRY`, `POINT`, `LINESTRING`, `POLYGON`, `MULTIPOINT`, `MULTILINESTRING`, `MULTIPOLYGON`, `GEOMETRYCOLLECTION` | 需 SRID,8.0 支持空间索引;PostgreSQL 对应 `PostGIS` 类型更丰富。 |
| 自动增量 | `SERIAL` | 简写 `BIGINT UNSIGNED NOT NULL AUTO_INCREMENT UNIQUE`,8.0 推荐显式写出。 |
常见差异速览
- **SQL Server** 无 `TINYINT/MEDIUMINT`,用 `SMALLINT/INT/BIGINT`;字符串用 `NVARCHAR/NCHAR`(UTF-16)。
- **Oracle** 常用 `NUMBER(p,s)` 包揽整型与定点;字符串 `VARCHAR2`;大文本 `CLOB`,大二进制 `BLOB`。
- **PostgreSQL` 有 `INTEGER`、`SERIAL`、`TEXT`、`BYTEA`、`JSON/JSONB`、`UUID`、`ARRAY`、`RANGE` 等专属类型。 |
记住:选类型先定“范围+精度+是否可变长”,再考虑“存储字节+索引长度+可读性”,就能覆盖 99 % 业务场景。
- 环境配置
- window怎么配置java环境变量?
- SQL学习
- 字段类型
- 1、 所有可声明的字段类型
- 2、常用的可声明的字段类型
- 创建表和表内字段
- 1、整个创建表语句
- 2、设置id主键
- 3、设置业务主键,唯一索引
- 4、设置业务字段
- 5、普通索引
- 6、唯一索引与普通索引的区别
- 7、表的引擎、字符集、排序规则和注释的设置
- Java基础语法
- 数据类型
- Java中的数据类型
- LocalDate
- 常用的数据类型
- Java 常用数据类型方法
- Java中数组、list、Map、HashMap
- 如何用Map来优化那些复杂的“双重 for 循环”查询?
- Java 8 中steam()操作流
- Java中HashMap和JSON
- Java中的JSONObject
- 工具类
- Java 常用工具类
- Arrays工具类
- Java 时间工具类
- 泛型
- Java中泛型概念
- Java中的泛型容器
- 泛型参数与函数参数的区别
- 推断出泛型实参
- Lambda表达式
- 数据分层
- 异常处理
- Java8 异常处理类总结表
- MyBatis-Plus 常用异常类总结表
- Java高级特性
- Maven
- jib-maven-plugin
- 什么是Spring Boot 的 parent pom?
- maven中各个生命周期的含义
- Spring Boot
- maven与spring boot 的关系
- Java中的连接池
- Spring JDBC
- Spring JDBC的概念
- JdbcTemplate常用的方法
- Spring中Bean的概念
- Spring中的抽象,通俗解释一下
- Spring中的事物
- Spring中的事物,通俗解释一下
- Spring中的事物抽象,常见的有哪些,列举一下
- Spring中常用的事物场景有哪些,列举一下
- Spring事务管理有哪些注解?
- Spring中使用事物处理订单的案例,列举说明一下
- Spring中声明式事务、分布式事务以及编程式事务的区别,列举一下
- 配置文件
- application-properties配置文件
- Spring Boot 的启动
- spring boot项目如何启动?
- 列举一下Spring Boot的启动过程
- SpringApplication.run方法
- Spring Boot 启动时有哪些接口?
- CommandLineRunner
- Spring Boot 的常用注解
- 系统注解
- 表格:系统注解
- @Override
- @Deprecated
- @SuppressWarnnings
- 使用在类名上的注解
- 表格:使用在类名上的注解
- @RestController
- @Controller
- @Service
- @Repository
- @Component
- @Configuration
- @Resource
- @Autowired
- @RequestMapping
- @GetMapping
- @PostMapping
- @Transactional
- @Qualifier
- 使用在方法上的注解
- 表格:使用在方法上的注解
- @RequestBody
- @PathVariable
- @Bean
- @ResponseBody
- @PreAuthorize
- 其他常用注解
- 表格:其他常用注解
- @EnableAutoConfiguration
- @SpringBootApplication
- @EnableScheduling
- @EnableAsync
- @ComponentScan
- @Aspec
- @ControllerAdvice
- @ExceptionHandler
- @Value
- @ConfigurationProperties
- @EnableConfigurationProperties
- @MapperScan
- @ApiOperation
- @Produces
- Validator验证的常用注解
- spring IoC容器
- Spring IoC容器依赖注入实现方式
- 常用依赖
- RESTEasy
- resteasy简介
- RESTEasy框架(依赖)的功能和常用注解
- MyBatis
- 简介
- paginationInterceptor
- @TableName
- @TableId
- @Param
- MyBatis-Plus
- MyBatis-Plus简介
- MyBatis-Plus的工具类
- Mybatis-Plus扩展的工具类和方法
- MyBatis-Plus中最常用的工具类方法
- MyBatis-Plus 中最常用的 4 大核心工具类
- Wrapper条件构造器
- Wrapper条件构造器详解
- Wrapper条件构造器eq等方法的参数说明
- LambdaQueryWrapper与QueryWrapper
- 日期格式是否必须转换
- Lombok
- Lombok作用详解
- @Data
- @Slf4j
- @Builder
- @EqualsAndHashCode
- @Accessors
- Jackson
- Jackson简介
- @JsonFormat
- Jackson高效地在 HashMap 和 JSON 字符串之间进行相互转换
- Hutool
- Hutool简介
- hutool依赖常用的方法
- fastjson2
- fastjson2简介
- UrlBasedCorsConfigurationSource
- 生态相关
- JBoss 社区
- 支付系统
- 1. 初始化mysql数据库流程
- 2. 初始化redis数据库的流程
- 3. 初始化rabbitmq服务
- 环球置业
- 1.模块目录结构分析
- 2. DTO(数据传输层)的核心作用
- 3. VO(视图对象层)
- 4. VO(视图对象层)和 DTO 数据传输层 的区别
