Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 689|回复: 0

查看mysql表结构和表创建语句的方法,建表42000错误解决办法

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-4-20 10:49:57 | 显示全部楼层 |阅读模式

    MYSQL ERROR 1071 (42000): Specified key was too long; max key length is 767 byte

    drop table if exists test;  
    create table test(test varchar(767) primary key)charset=latin5;  -- 成功 
    drop table if exists test; 
    
    create table test(test varchar(768) primary key)charset=latin5;  -- 错误
    -- ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes
    
     
    drop table if exists test; 
    create table test(test varchar(383) primary key)charset=GBK;  -- 成功 
    drop table if exists test; 
    
    create table test(test varchar(384) primary key)charset=GBK;  -- 错误
     -- ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes 
    
    
    drop table if exists test;  
    create table test(test varchar(255) primary key)charset=UTF8;  -- 成功 
    drop table if exists test;
    create table test(test varchar(256) primary key)charset=UTF8;  -- 错误  
    -- ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes 

     MySQL的varchar主键只支持不超过768个字节 或者 768/2=384个双字节 或者 768/3=256个三字节的字段 ,而 GBK是双字节的,UTF-8是三字节的。

    MySQL ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes 的原因分析

     

    查看mysql表结构的方法有三种:  

    1、mysql> desc tablename;  # 查看表的结构

    +------------------+---------------------+------+-----+---------------------+----------------+  
    | Field            | Type                | Null | Key | Default             | Extra          |  
    +------------------+---------------------+------+-----+---------------------+----------------+  
    | id               | int(11)             | NO   | PRI | NULL                | auto_increment |  
    | title            | text                | NO   |     | NULL                |                |  
    | content          | text                | NO   |     | NULL                |                |  
    | ordering         | int(11)             | NO   |     | 0                   |                |  
    | position         | varchar(50)         | YES |     | NULL                |                |  
    | checked_out      | int(11) unsigned    | NO   |     | 0                   |                |  
    | checked_out_time | datetime            | NO   |     | 0000-00-00 00:00:00 |                |  
    | published        | tinyint(1)          | NO   | MUL | 0                   |                |  
    | module           | varchar(50)         | YES | MUL | NULL                |                |  
    | numnews          | int(11)             | NO   |     | 0                   |                |  
    | access           | tinyint(3) unsigned | NO   |     | 0                   |                |  
    | showtitle        | tinyint(3) unsigned | NO   |     | 1                   |                |  
    | params           | text                | NO   |     | NULL                |                |  
    | iscore           | tinyint(4)          | NO   |     | 0                   |                |  
    | client_id        | tinyint(4)          | NO   |     | 0                   |                |  
    | control          | text                | NO   |     | NULL                |                |  
    +------------------+---------------------+------+-----+---------------------+----------------+  

    2、mysql> show create table tablename;  # 查看创建表的sql语句

    1. mysql> show create table jos_modules;  
    2. jos_modules | CREATE TABLE `jos_modules` (  
    3. `id` int(11) NOT NULL AUTO_INCREMENT,  
    4. `title` text NOT NULL,  
    5. `content` text NOT NULL,  
    6. `ordering` int(11) NOT NULL DEFAULT '0',  
    7. `position` varchar(50) DEFAULT NULL,  
    8. `checked_out` int(11) unsigned NOT NULL DEFAULT '0',  
    9. `checked_out_time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',  
    10. `published` tinyint(1) NOT NULL DEFAULT '0',  
    11. `module` varchar(50) DEFAULT NULL,  
    12. `numnews` int(11) NOT NULL DEFAULT '0',  
    13. `access` tinyint(3) unsigned NOT NULL DEFAULT '0',  
    14. `showtitle` tinyint(3) unsigned NOT NULL DEFAULT '1',  
    15. `params` text NOT NULL,  
    16. `iscore` tinyint(4) NOT NULL DEFAULT '0',  
    17. `client_id` tinyint(4) NOT NULL DEFAULT '0',  
    18. `control` text NOT NULL,  
    19. PRIMARY KEY (`id`),  
    20. KEY `published` (`published`,`access`),  
    21. KEY `newsfeeds` (`module`,`published`)  
    22. ) ENGINE=MyISAM AUTO_INCREMENT=145 DEFAULT CHARSET=utf8  

    3、mysql>select COLUMN_NAME from information_schema.COLUMNS where table_name = 'tablename' and TABLE_SCHEMA ='databasename';

         # 查看列名

    1. +----------------------------+
    2. | COLUMN_NAME                
    3. +----------------------------+
    4. | id                                           
    5. | distinct_name                     
    6. | offical_domain                     
    7. | offical_ip                             
    8. | offical_ip_loc                      
    9. | similar_domain_regex         
    10. | title_keywords                      
    11. | content_sensitive_keywords
    12. | out_link_offical_rate            
    13. | icp_code                            
    14. | reserved_one                     
    15. | reserved_two                    
    16. | reserved_three                  
    17. | update_time                       
    18. +----------------------------+

      

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-10 00:21 , Processed in 0.072259 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表