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

索引字段长度太长,
1.修改字段长度
2.修改mysql默认的存储引擎
在/etc/mysql/my.cnf 的[mysqld] 下面加入default-storage-engine=INNODB
但是在建库时已经明确表明了需要使用INNODB引擎
Sql代码

复制代码 代码如下:

CREATE TABLE `acs` (
...
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

检查当前的引擎

复制代码 代码如下:

mysql> show engines;

果然没有InnoDB
查看是否支持动态加载, 重要的是have_dynamic_loading这行,如果是YES,那么继续

复制代码 代码如下:

mysql>show variables like "have_%";

安装插件

复制代码 代码如下:

mysql> INSTALL PLUGIN INNODB SONAME 'ha_innodb.so';
mysql> show engines;

Mysql建库第一次接触Mysql,和Oracle还是有差别的哦,下面简单介绍Linux Mysql建库过程。
#mysql

>CREATE USER 'bob'@'%' IDENTIFIED BY '123456'; //创建用户bob.
>GRANT ALL PRIVILEGES ON *.* TO 'bob'@'localhost' IDENTIFIED BY '123456';
//设置bob可以本地登录并赋所有权限给bob,因为bob是管理员哦!
>GRANT ALL PRIVILEGES ON *.* TO 'bob'@'%' IDENTIFIED BY '123456';
//用户地址可以是localhost,也可以是ip地址、机器名字、域名。也可以用'%'表示从任何地址连接.
>FLUSH PRIVILEGES; //刷新授权
>CREATE DATABASE travel CHARACTER SET utf8 COLLATE utf8_general_ci; //创建数据库travel并设置成utf8格式.
>quit

#mysql -uroot -p travel < travel20120410.sql //为了方便,我直接导入了一份数据,root密码默认为空,所以后面直接跟数据库名称.

#mysql -ubob -p123456 回车

>SHOW DATABASES; //查看数据库
>select user,host,password from mysql.user; //bob登录,查看已经存在的所有用户
>\S 或者 SELECT CURRENT_USER(); //查看当前用户
>use travel;
>show tables;
>show grants; //查看自己的权限
>show grants for dba@localhost; //查看dba的权限
>revoke all on *.* from dba@localhost; //移除dba的权限
>update user set password=password("密码") where user='root' //修改root密码
#mysqladmin -uroot -p旧密码 password 新密码 //修改root密码
#mysql -ubob -pbob -h192.168.19.182 travel //远程登录到182这台Mysql数据库

时间: 2024-08-30 12:02:13

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

mysql-操作MYSQL建表时不能保存,id也不能选择自动递增

问题描述 操作MYSQL建表时不能保存,id也不能选择自动递增 急,在线等o(╯□╰)o,截图没有设置长度,其实设置了也是一样的问题,所以这个排除了 解决方案 你用的是mysql图形界面客户端软件是什么呢?我用的是SQLYog客户端,是有自增选项的. 解决方案二: 数据表定义有问题吧,不是提示说length没设置吗

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的字段设置的太长了,于是我把这两个字段的长度改了一下就好了.  建立索引时,数据库计算key的长度是累加所有Index用到的字段的char长度后再按下面比例乘起来不能超过限定的key长度1000:  latin1 = 1 byte = 1 character  uft8 = 3 byte = 1 character 

MySQL 的模块不能安装的解决方法_Mysql

我们最常用的 DBD::mysql 模块,我发现是难住很多人的地方.因为安装老是失败,下面我介绍一下解决方法,比如我使用 cpanm 安装,有时就出 /home/nue2501j/work/DBD-mysql-4.010/blib/arch/auto/DBD/mysql/mysql.so: undefined symbol: DBIc_TRACE_LEVEL at /usr/lib/perl5/5.8.5/i386-linux-thread-multi/DynaLoader.pm line 23

mysql安装时出现各种常见问题的解决方法_Mysql

小编为大家整理许多mysql安装时出现各种常见问题的解决方法,供大家参考,具体内容如下 问题一: 当各位在安装.重装时出现could not start the service mysql error:0原因: 卸载mysql时并没有完全删除相关文件和服务,需要手动清除. 安装到最后一步execute时不能启动服务的解决方法: 首先,在管理工具->服务里面将MySQL的服务给停止(有的是没有安装成功,有这个服务,但是已经停止了的),win+R->cmd,打开命令提示符窗口,输入命令:sc de

mysql启动提示mysql.host 不存在,启动失败的解决方法_Mysql

error 日志当中的记录: [ERROR] Fatal error: Can't open and lock privilege tables: Table 'mysql.host' doesn't exist 从发了帖子,只有人看,没有人回复,看到这种情况只能自己解决问题了,自己动手丰衣足食吗, 嗯... 你还别说,还真让我解决了问题,人啊,都是逼出来的,....没有办法,这个问题对于高手可能是很简单的问题 ,但是对我第一次摸mysql,确实怎么也弄不懂的问题. 好了闲话不多说 说一下我解决

CentOS下安装mysql时忘记设置root密码致无法登录的解决方法_Mysql

前言 昨天一天都是启动mysql时提示:The server quit without updating PID file,今天重装了mysql之后还是同样报错,然后恢复了一下/usr/my.cnf突然就可以启动了.(明明昨天/usr/my.cnf就是默认的,有个解决方法说改这个文件才改的) 然后现在就到没有设置root密码的问题了,搜了几个方法都不行,直到看到下面这个方法一才行. 解决方法一: # /etc/init.d/mysql stop # mysqld_safe --user=mysq

mysql登录报错提示:ERROR 1045 (28000)的解决方法_Mysql

本文分析了mysql登录报错提示:ERROR 1045 (28000)的解决方法.分享给大家供大家参考,具体如下: 一.问题: 公司linux系统的mysql数据库root用户设置过密码,但常常用命令'mysql -u root -p'登录报错,有时又能登录.登录报错信息为: [root@localhost ~]# mysql -u root -p Enter password: ERROR 1045 (28000): Access denied for user 'root'@'localho

MYSQL安装时解决要输入current root password的解决方法_Mysql

终归结出以下解决方法: 1.清除MYSQL的安装目录,默认是C:\Program Files 2.清除MYSQL数据存放目录,一般在C:\Documents and Settings\All Users.windows\Application Data目录下 (需要注意的时Application Data这个文件夹默认是隐藏的,要通过 工具->文件夹选项->查看->显示所有 文件与文件夹 来设置隐藏文件可见). 删除MySQL文件夹 3.这步很重要,之前不管我怎么卸载MYSQL清空残余文

php运行提示Can&#039;t connect to MySQL server on &#039;localhost&#039;的解决方法_Mysql

错误编号:2003 问题分析: 无法连接到 MySQL 服务器,可能的情况为: 1.MySQL 服务没有启动,一般是在异常的情况下 MySQL 无法启动导致的,比如无可用的磁盘空间,my.ini 里 MySQL 的 basedir 路径设置错误等: 2.MySQL 服务器资源紧张,导致无法连接. 解决方法: 1.如果你是虚拟主机用户(购买的空间),则联系空间商检查 MySQL 是否正常启动,并确认 MySQL 的配置信息(是否为 localhost): 2.如果你是独立主机用户(拥有管理主机权限