💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、豆包、星火、月之暗面及文生图、文生视频 广告
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 % 业务场景。