`
wandejun1012
  • 浏览: 2737711 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

specified key was too long max key length is 1024 bytes

 
阅读更多

 

这是因为在设置联合主键时,如果采用UTF-8编码,那么只能存储1024/3=300多个单位长度。

 

所以长度不能超过300.

 

 

比如:

 

CREATE TABLE TIMMS10 ( CLUSTER_ID VARCHAR(32) DEFAULT ' ' NOT NULL, APP_ID VARCHAR(32) DEFAULT ' ' NOT NULL, IP_ADDRESS VARCHAR(30) DEFAULT ' ' NOT NULL, USER_NAME VARCHAR(10) DEFAULT ' ' NOT NULL, LOCALE VARCHAR(10) DEFAULT ' ' NOT NULL, MONITOR_SEQ DECIMAL(8,0) DEFAULT 0 NOT NULL, DIAGNOSE_ID DECIMAL(20,0) DEFAULT 0 NOT NULL, SESSION_ID VARCHAR(100) DEFAULT ' ' NOT NULL, THREAD_ID VARCHAR(100) DEFAULT ' ' NOT NULL, JOB_ID DECIMAL(5,0) DEFAULT 0 NOT NULL, JOB_PARENT_ID DECIMAL(5,0) DEFAULT 0 NOT NULL, JOB_CONTEXT VARCHAR(500) DEFAULT ' ' NOT NULL, JOB_TYPE VARCHAR(20) DEFAULT ' ' NOT NULL, JOB_START_TIME VARCHAR(18) DEFAULT ' ' NOT NULL, JOB_END_TIME VARCHAR(18) DEFAULT ' ' NOT NULL, JOB_COST DECIMAL(20,0) DEFAULT 0 NOT NULL, JOB_START_CLASS VARCHAR(100) DEFAULT ' ' NOT NULL, JOB_START_METHOD VARCHAR(50) DEFAULT ' ' NOT NULL, JOB_START_FILE VARCHAR(50) DEFAULT ' ' NOT NULL, JOB_START_LINE VARCHAR(5) DEFAULT ' ' NOT NULL, JOB_END_CLASS VARCHAR(100) DEFAULT ' ' NOT NULL, JOB_END_METHOD VARCHAR(50) DEFAULT ' ' NOT NULL, JOB_END_FILE VARCHAR(50) DEFAULT ' ' NOT NULL, JOB_END_LINE VARCHAR(5) DEFAULT ' ' NOT NULL, JOB_INFO VARCHAR(2000) DEFAULT ' ' NOT NULL, JOB_LEAF VARCHAR(1) DEFAULT ' ' NOT NULL, JOB_OK VARCHAR(1) DEFAULT ' ' NOT NULL, JOB_ERROR VARCHAR(500) DEFAULT ' ' NOT NULL, CONSTRAINT TIMMS10_PK PRIMARY KEY (CLUSTER_ID, APP_ID, MONITOR_SEQ, DIAGNOSE_ID, JOB_ID) );

 

 

注意观察最后的主键,是5个字段组合起来的联合主键,它们加起来的长度不能超过300,否则报错。

 

参考链接:http://hidba.org/?p=216

 

分享到:
评论

相关推荐

    MySQL错误“Specified key was too long; max key length is 1000 bytes”的解决办法

    max key length is 1000 bytes”。这个错误意味着你试图创建的索引键(key)超过了MySQL允许的最大长度。MySQL对每个表的每个索引都有一个最大长度限制,通常是1000字节。这个限制包括了所有被索引字段的长度。 在...

    mysql建库时提示Specified key was too long max key length is 1000 bytes的问题的解决方法

    ### MySQL建库时提示“Specified key was too long; max key length is 1000 bytes”的问题解析及解决方法 #### 问题背景 在使用MySQL进行数据库表结构设计时,可能会遇到“Specified key was too long; max key ...

    nacos-server-1.1.4.txt

    nacos-server-1.1.4 windows下的运行程序 springcloud alibaba

    用sql命令修改数据表中的一个字段为非空(not null)的语句

    ALTER TABLE table1 ALTER COLUMN ... 您可能感兴趣的文章:sql server建库、建表、建约束技巧mysql建库时提示Specified key was too long max key length is 1000 bytes的问题的解决方法Mysql 建库建表技巧分享SQL S

    解决Laravel5.x的php artisan migrate数据库迁移创建操作报错SQLSTATE[42000]

    Illuminate\Database\QueryException : SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes (SQL: alter table `users` add unique `users_email_...

    nacos-server-1.2.0.zip

    导致报 Specified key was too long; max key length is 767 bytes 解决方案1: 直接缩短到255长度 解决方案2: 修改数据库配置, set innodb_large_prefix=on 吐槽一下, 1.2.0版本比1.1.4版本多创建一...

    Bugfree3.0.4安装部署说明书

    - 如果在安装过程中遇到“Specified key was too long: max key length is 767 bytes”的错误,需要修改`\Apache2.2\htdocs\bugfree\install\schema.php`文件中的相关字段长度。 通过以上步骤,你应该能够成功地在...

    Joomla网站中数据导入导出问题

    - **错误原因**:在导入前,可能会遇到“Specified key was too long; max key length is 1000 bytes”的错误。这是由于MySQL的限制导致的。 - **解决方法**: 1. 打开导出的SQL文件,查找并定位到以下两行: ``` ...

    BobBuilder_app

    String Keys are UTF8 encoded and limited to 60 bytes if not specified otherwise (maximum is 255 chars). Support for long string Keys with the RaptorDBString class. Duplicate keys are stored as a WAH ...

    laravel执行php artisan migrate报错的解决方法

    SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes ``` 这个错误通常发生在创建或修改具有较大数据长度的索引时,尤其是在使用了InnoDB引擎的情况...

    解决在laravel中auth建立时候遇到的问题

    第一个错误是“索引太长”,具体表现为SQLSTATE[42000]:Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes。这个错误通常发生在为字段创建索引时,特别是当MySQL...

    在EF中使用MySQL的方法及常见问题

    由于MySQL对字符串类型的默认映射可能导致键长度超出限制,所以在定义`UserName`和`PassWord`时,需要使用`StringLength`和`MaxLength`数据注解来限制其长度,避免出现“Specified key was too long; max key length...

    php.ini-development

    On production servers, 4096 bytes is a good setting for performance ; reasons. ; Note: Output buffering can also be controlled via Output Buffering Control ; functions. ; Possible Values: ; On = ...

    Bochs - The cross platform IA-32 (x86) emulator

    - When x86-64 support is compiled in, you could enable/disable long mode 1G pages support without recompile using new CPUID option in .bochsrc. Configure options: --enable-mmx, --enable-sse, --...

Global site tag (gtag.js) - Google Analytics