```
contract_id varchar(50) NOT NULL COMMENT '合同ID(业务主键)',
UNIQUE KEY `uk_contract_id` (`contract_id`),
```
声明一个最长 50 字符的字符串列 `contract_id`,强制非空,并将其业务含义标注为“合同ID(业务主键)”。
| 子句/属性 | 含义与注意事项 |
|-----------|----------------|
| `contract_id` | 列名,建议与业务术语保持一致,方便 ORM 映射。 |
| `varchar(50)` | 可变长字符串,上限 50 字符;MySQL 层按实际长度 + 1 字节存储(≤255 时)。若存 UTF8MB4,最多耗 200 字节。 |
| `NOT NULL` | 禁止插入 NULL,保证业务主键一定有值;省去 IS NULL 判断,使索引更高效。 |
| `COMMENT '合同ID(业务主键)'` | 元数据注释,写入表定义;`SHOW FULL COLUMNS` 或 `information_schema` 可查,方便 DBA/开发快速理解用途。 |
| 业务主键 vs 代理主键 | 本列承担“业务上唯一”职责,可与数据库自增 ID 并存;需额外加 `UNIQUE KEY(contract_id)` 或干脆 `PRIMARY KEY(contract_id)` 来保证唯一。 |
| 性能提示 | varchar 做主键时,InnoDB 聚簇索引叶子节点存整条记录,字符串越长二级索引越胖;若合同号规则固定且较短,可用 `char` 或转 `bigint` 枚举值。 |
>[info]UNIQUE KEY `uk_contract_id` (`contract_id`),
一句话总结
给列 `contract_id` 加上唯一索引 `uk_contract_id`,保证全表该列值不重复,可快速等值查询且允许 NULL(若列定义允许)。
详细解释
| 维度 | 说明 |
|---|---|
| 关键字 | `UNIQUE KEY` 等价于 `UNIQUE INDEX`,在 MySQL 里既是约束也是 B+Tree 索引。 |
| 名称 | `uk_contract_id` 为用户自定义索引名,后续 `SHOW INDEX`、Hint、`ALTER TABLE DROP INDEX` 都用它引用。 |
| 作用 | 1. 唯一性:插入/更新重复值时报 1062 Duplicate entry。<br>2. 加速查询:等值 (`=`) 或范围 (`<, >, BETWEEN`) 搜索可快速定位。<br>3. 可为 NULL:与 PRIMARY KEY 不同,允许多行 NULL(视为互不相同)。 |
| 与主键区别 | 一张表只能有一个主键,但可有多个 UNIQUE KEY;主键默认聚簇,UNIQUE 为二级索引,叶子存主键值。 |
| 复合唯一 | 可写 `UNIQUE KEY uk_multi (col1, col2)`,组合整体唯一,单列可重复。 |
| 性能注意 | 字符串越长,索引节点扇出减少,IO 增多;若合同号已定长且较短,可省空间;写入时需维护索引,高并发批量插入建议先删后加。 |
- 环境配置
- 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 数据传输层 的区别
