我在系统日志里看到 : Default storage engine (InnoDB) is not available导致mysql无法启动的解决办法 MySQL在重装后无法再启动,查看事件显示如下错误: Default storage engine (InnoDB) is not available ,解决方案如下: 1. 打开my.ini或my.cnf文件,找到default-storage-engine这一行,把它改成default-storage- engine=MyISAM。 2.删除在MySQL安装目录下的Data目录中的 ib_logfile0 ib_logfile1 找到在配置MySQL服务器时指定的InfoDB目录删除掉 ibdata1 重新启动MySQL的Service select host,user,password from user; host字段表示登录的主机,其值可以用IP,也可用主机名, 将host字段的值改为%就表示在任何客户端机器上能以某用户登录到mysql服务器。 Step 2: 创建一个新用户test: 格式:grant 权限 on 数据库名.表名 用户@登录主机 identified by "用户密码"; grant select,update,insert,delete on *.* to test@192.168.0.99 identified by "test"; GRANT ALL PRIVILEGES ON db.* TO user@localhost identified by "test"; Step 3:重新加载 记住:对授权表的任何修改都需要重新reload ./mysqladmin -uroot -ppwd reload 或者:FLUSH PRIVILEGES; ok... '' 正在处理中,请稍后...... UPDATE mysql.user SET password=OLD_PASSWORD('yninfo') WHERE User='hongyun' ; FLUSH PRIVILEGES; Mysql 学习笔记 1、安装环境: Windows XP Mysql 4.0.17 从 http://www.mysql.com下载 EMS Mysql Query 1.6.0.1 本机IP:172.5.1.183 2、安装Mysql,采用默认安装即可 目录选择在c:\mysql,不要修改默认目录 3、启动Mysql 安装为服务:c:\mysql\bin\mysqld --install 启动Mysql: net start mysql 停止Mysql: net stop mysql 4、系统创建的数据库有mysql,test mysql保存系统数据 test数据库用来测试 5、默认登陆方式 在本机 c:\mysql\bin\mysql -uroot c:\mysql\bin\mysql 远程 mysql -h 172.5.1.183 -uroot 这些是在mysql.user表中,系统默认存在4条数据 use mysql select host,user,password from user; +-----------+------+----------+ | host | user | password | +-----------+------+----------+ | localhost | root | | | % | root | | | localhost | | | | % | | | +-----------+------+----------+ 这些数据代表的意义: 用户名为root,密码为空的用户可以从本机和任何远程主机登陆 任何用户名,密码为空的用户可以从本机登陆 用户名为空,密码为空的用户不可以从远程登陆 (user中后面的字段为N,所以无法登陆) 在4.0.17版本后就不允许在远程登陆了,所以%显示的可能是类似于build或 localhost.localdomain,如果你想达到远程登陆的目的,可以这样 c:\mysql\bin\mysql -uroot mysql update user set host='%',password=PASSWORD('root') where user='root' and host in ('build','localhost.localdomain'); 这样就可以是root/root在远程可以登陆了,如果修改本地root密码,可以 update user set password=PASSWORD("root") where user='root' and host='localhost' 下次就需要用mysql -uroot -proot才可以登陆 在远程或本机可以使用 mysql -h 172.5.1.183 -uroot 登陆,这个根据第二行的策略确定 权限修改生效: 1)net stop mysql net start mysql 2)c:\mysql\bin\mysqladmin flush-privileges 3)登陆mysql后,用flush privileges语句 其他 增加用户授权的方式 1)在user表中增加记录 user表中除了host,user,password列之外,还有很多权限字段,但字段数量在不同的 版本中不同,你需要注意列的数量,所以如果要增加用户,需要 c:\mysql\bin\mysql -uroot mysql insert into user values('172.5.1.201','root',PASSWORD("test"), 'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y', 'Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y','Y') 因为权限字段默认为'N',所以得全部写上,因此这样的方式不如使用grant 2)使用grant语句,如增加一个完全权限的用户 grant all privileges on *.* to shiyq@"172.5.1.201" identified by 'stone' with grant option; 收回授权 1)操作user表 #收回root@localhost的Shutdown_priv update user set Shutdown_priv='N' where user='shiyq' and host='172.5.1.201'; 删除shiyq@"172.5.1.201" delete from user where user='root' and host='172.5.1.201' 2)使用revoke命令 #删除用户shiyq@"172.5.1.201" mysql>revoke all privileges on *.* from shiyq@'172.5.1.201'; #删除用户shiyq@"172.5.1.201"的Shutdown权限 mysql>revoke Shutdown on *.* from shiyq@"172.5.1.201"; grant和revoke的操作也是影响到user表的,所以他们是一样的,看你喜欢什么了 其他:在user表保存的是针对本机的所有数据库,如果你要得到更精确的权限控制, 那么你需要操作host、db、table_priv表,mysql的权限是3个表权限的并集, 这些表也可以用grant,revoke操作,有兴趣可以进一步研究 下面有个简单的例字 c:\mysql\bin\mysql -uroot -proot mysql> create database shiyq; use shiyq; create table test ( id int not null auto_increment primary key, name varchar(20) not null default 'test' ); grant drop,alter,create on shiyq.* to test@localhost identified by "test"; grant insert,update,delete on test to test@localhost; #这时候你可以查看一下user,host,db,tables_priv的记录,可以看到你操作的结果, #因为这些表的列数较多,所以最好用 EMS Mysql Query 1.6.0.1 这个工具来看, #现在用刚刚创建的用户登陆试试看 c:\mysql\bin\mysql -utest -ptest mysql> show databases; #看看有什么不同 use shiyq; show tables; create table test1(id int not null primary key); select * from test1; #系统提示你没有权限, select * from test; #但可以执行下列命令 insert into test(name) values('hello'); udpate test set name='hello test'; delete from test; 赋予test@localhost 的shiyq.test select 权限 grant select on test to test@localhost; 这样用shiyq/stone登陆就可以执行 select * from test; 6、创建数据库staffer create database staffer; 7、下面的语句在mysql环境在执行 显示用户拥有权限的数据库 show databases; 切换到staffer数据库 use staffer; 显示当前数据库中有权限的表 show tables; 显示表staffer的结构 desc staffer; 8、创建测试环境 1)创建数据库staffer,创建用户 mysql> create database staffer mysql> grant all privileges on staffer.* to shiyq@localhost identified by "stone"; mysql> exit; c:\mysql\bin\mysql -ushiyq -pstone staffer 2)创建表staffer,department,position,depart_pos create table s_position ( id int not null auto_increment, name varchar(20) not null default '经理', #设定默认值 description varchar(100), primary key PK_positon (id) #设定主键 ); create table department ( id int not null auto_increment, name varchar(20) not null default '系统部', #设定默认值 description varchar(100), primary key PK_department (id) #设定主键 ); create table depart_pos ( department_id int not null, position_id int not null, primary key PK_depart_pos (department_id,position_id) #设定复和主键 ); create table staffer ( id int not null auto_increment primary key, #设定主键 name varchar(20) not null default '无名氏', #设定默认值 department_id int not null, position_id int not null, unique (department_id,position_id) #设定唯一值 ); 3)删除 mysql> drop table depart_pos; drop table department; drop table s_position; drop table staffer; drop database staffer; 9、修改结构 mysql> #表s_position增加列test alter table s_position add(test char(10)); #表s_position修改列test alter table s_position modify test char(20) not null; #表s_position修改列test默认值 alter table s_position alter test set default 'system'; #表s_position去掉test默认值 alter table s_position alter test drop default; #表s_position去掉列test alter table s_position drop column test; #表depart_pos删除主键 alter table depart_pos drop primary key; #表depart_pos增加主键 alter table depart_pos add primary key PK_depart_pos (department_id,position_id); 10、操作数据 #插入表department insert into department(name,description) values('系统部','系统部'); insert into department(name,description) values('公关部','公关部'); insert into department(name,description) values('客服部','客服部'); insert into department(name,description) values('财务部','财务部'); insert into department(name,description) values('测试部','测试部'); #插入表s_position insert into s_position(name,description) values('总监','总监'); insert into s_position(name,description) values('经理','经理'); insert into s_position(name,description) values('普通员工','普通员工'); #插入表depart_pos insert into depart_pos(department_id,position_id) select a.id department_id,b.id postion_id from department a,s_position b; #插入表staffer insert into staffer(name,department_id,position_id) values('陈达治',1,1); insert into staffer(name,department_id,position_id) values('李文宾',1,2); insert into staffer(name,department_id,position_id) values('马佳',1,3); insert into staffer(name,department_id,position_id) values('亢志强',5,1); insert into staffer(name,department_id,position_id) values('杨玉茹',4,1); 11、查询及删除操作 #显示系统部的人员和职位 select a.name,b.name department_name,c.name position_name from staffer a,department b,s_position c where a.department_id=b.id and a.position_id=c.id and b.name='系统部'; #显示系统部的人数 select count(*) from staffer a,department b where a.department_id=b.id and b.name='系统部' #显示各部门的人数 select count(*) cou,b.name from staffer a,department b where a.department_id=b.id group by b.name; #删除客服部 delete from department where name='客服部'; #将财务部修改为财务一部 update department set name='财务一部' where name='财务部'; 12、备份和恢复 备份数据库staffer c:\mysql\bin\mysqldump -uroot -proot staffer>e:\staffer.sql 得到的staffer.sql是一个sql脚本,不包括建库的语句,所以你需要手工 创建数据库才可以导入 恢复数据库staffer,需要创建一个空库staffer c:\mysql\bin\mysql -uroot -proot staffer<staffer.sql 如果不希望后来手工创建staffer,可以 c:\mysql\bin\mysqldump -uroot -proot --databases staffer>e:\staffer.sql mysql -uroot -proot >e:\staffer.sql 但这样的话系统种就不能存在staffer库,且无法导入其他名字的数据库, 当然你可以手工修改staffer.sql文件 常用参数示例,命令都在c:\mysql\bin\下执行 1)导出整个数据库 mysqldump -uroot -proot --all-databases>e:\all.sql 2)导出staffer数据库 mysqldump -ushiyq -pstone --database staffer>e:\staffer.sql 3)导出staffer库中的staffer表 mysqldump -ushiyq -pstone --database staffer --tables staffer>e:\staffer.staffer.sql 如果不希望有关于数据库的语句,去掉--database即可, 如果需要从远程机器导出,可以采用 -h 参数,这个和登陆一致 13、从文本向数据库导入数据 1)使用工具c:\mysql\bin\mysqlimport 这个工具的作用是将文件导入到和去掉文件扩展名名字相同的表里,如 staffer.txt,staffer都是导入到staffer表中 常用选项及功能如下 -d or --delete 新数据导入数据表中之前删除数据数据表中的所有信息 -f or --force 不管是否遇到错误,mysqlimport将强制继续插入数据 -i or --ignore mysqlimport跳过或者忽略那些有相同唯一 关键字的行, 导入文件中的数据将被忽略。 -l or -lock-tables 数据被插入之前锁住表,这样就防止了, 你在更新数据库时,用户的查询和更新受到影响。 -r or -replace 这个选项与-i选项的作用相反;此选项将替代 表中有相同唯一关键字的记录。 --fields-enclosed- by= char 指定文本文件中数据的记录时以什么括起的, 很多情况下 数据以双引号括起。 默认的情况下数据是没有被字符括起的。 --fields-terminated- by=char 指定各个数据的值之间的分隔符,在句号分隔的文件中, 分隔符是句号。您可以用此选项指定数据之间的分隔符。 默认的分隔符是跳格符(Tab) --lines-terminated- by=str 此选项指定文本文件中行与行之间数据的分隔字符串 或者字符。 默认的情况下mysqlimport以newline为行分隔符。 您可以选择用一个字符串来替代一个单个的字符: 一个新行或者一个回车。 mysqlimport命令常用的选项还有-v 显示版本(version), -p 提示输入密码(password)等。 这个工具有个问题,无法忽略某些列,这样对我们的数据导入有很大的麻烦,虽然 可以手工设置这个字段,但会出现莫名其妙的结果,我们做一个简单的示例 我们定义如下的depart_no.txt,保存在e盘,间隔为制表符\t 10 10 11 11 12 24 执行如下命令 c:\mysql\bin\mysqlimport -uroot -proot staffer e:\depart_pos.txt 在这里没有使用列的包围符号,分割采用默认的\t,因为采用别的符号会有问题, 不知道是不是windows的原因 2)Load Data INFILE file_name into table_name(column1_name,column2_name) 这个命令在mysql>提示符下使用,优点是可以指定列导入,示例如下 c:\mysql\bin\mysql -uroot -proot staffer mysql>load data infile "e:/depart_no.txt" into depart_no(department_id,position_id); 这两个工具在Windows下使用都有问题,不知道是Windows的原因还是中文的问题, 而且不指定的列它产生了空值,这显然不是我们想要的,所以谨慎使用这些工具 14、Mysql管理工具 Mysql是一个相对简单的系统,大多数使用Mysql自带的客户端工具就可以满足我们的要求, 但是在特定条件下你可以采用一些工具让你的管理、开发和调试工作更容易,下面介绍我 整理过的软件 1)PHPMyAdmin 这是一个基于B/S结构,采用PHP语言开发的一个管理工具,目前版本是2.6.0-pl2, 可以从http://sourceforge.net/projects/phpmyadmin/ 下找到最新的版本以及 下载的链接,因为这是一个Web的工具,所以配置过程稍微有点麻烦,现在我简单 说明一下,我采用的结构是 Windows XP + Apache 2.0.52 + PHP 4.3.9 + mysql 4.0.22 (mysql 4.0 的版本是大同小异,如果其他版本遇到问题,我们可以一起讨论) 1)安装Aapache 从http://httpd.apache.org/download.cgi可以下载最新的Apache版本 点击setup.exe安装到d:\Apache Group\Apache2下,安装程序会将安装一个 名字Apache2的服务,如果出现异常情况,我们可以手动来安装, d:\Apache Group\Apache2\bin\Apache -k install net start Apache2 net stop Apache2 2)安装PHP 从http://www.php.net可以下载最新的php版本,最好用版本4.xx 它有安装和zip两种版本,由于安装版本不能完全支持Apache,而且没有很多扩展组 件,我采用了Zip包, a)将Zip包打开,将根目录下文件拷贝到c:\PHP下 b)配置过程可以根据目录下的install.txt来完成,我简单的说明一下将php安装 为Apache的一个模块的过程 拷贝php.ini-dist到c:\windows下,修改名字为php.ini 拷贝php4ts.dll到c:\windows\System32下 在D:\Apache Group\Apache2\conf\httpd.conf中加上 LoadModule php4_module c:/php/sapi/php4apache2.dll AddType application/x-httpd-php .php c)在D:\Apache Group\Apache\htdocs下增加一个文件info.php,内容为 <?php infophp(); ?> 在浏览器输入http://localhost/info.php 如果看到输出,则php配置成功 3)配置PHPMyAdmin 将PHPMyAdmin解压到e:\Hompage下,则PHPMyAdmin的工作目录为 e:\HomePage\phpMyAdmin-2.6.0-pl2 在D:\Apache Group\Apache2\conf\http.conf设置虚拟目录和权限,增加如下 Alias /phpadmin "e:/HomePage/phpMyAdmin-2.6.0-pl2" <Directory "e:/HomePage/phpMyAdmin-2.6.0-pl2"> Order allow,deny Allow from all </Directory> 重新启动Apache 在浏览器中输入:http://localhost/phpadmin/main.php,如果可以看到页面, 证明配置成功了。 4)在默认情况下PHPMyAdmin用root@localhost与空密码访问Mysql数据库, 如果你的数据库的root@localhost密码不为空,假设为root,可以修改根目录 下的config.inc.php,搜索下列行 $cfg['Servers'][$i]['host'] = 'localhost' 找到下面的 $cfg['Servers'][$i]['password'] = ''; 修改为 $cfg['Servers'][$i]['password'] = 'root'; 就可以登陆了 登陆之后你可以设置你喜欢的语言界面,这个程序的功能很强大,功能有 a)创建删除数据库 b)权限管理 c)表管理 d)数据管理 e)运行SQL查询 你可以自己操作一下,就不多说了,其实这个程序也是一个很好的Php学习程序, 通过这个程序你可以很好的学习PHP、Mysql管理以及Php,Mysql的组合编程 5)PHPMyAdmin默认支持一个Mysql实例(就是一台主机的意思) 但可以通过修改config.inc.php来达到支持多个实例的目的, 具体方法是找到 $cfg['ServerDefault'] = 1; // Default server (0 = no default server) 修改这个数值为0,会得到一个Mysql实例列表, 也可以修改为别的数值将默认的实例改为你所要的实例,但这样的话,你默认的实例 的信息必须完全,否则会出错的。 2)EMS Electronic Microsystems(http://www.ems-hitech.com/)提供了一些比较好的Mysql管理 工具,这些工具可以在http://www.1xia.com/网站上下载,你可以输入EMS,就可以查询到你 需要的工具,下面简单介绍一下他们的功能 EMS Mysql Query:是一个查询工具,提供SQL加亮显示、表格化显示数据、所见所得编辑 数据的功能 EMS Mysql Manager:提供管理表的全部功能,如 1)表结构的修改,包括主键索引等 2)表的备份和恢复 3)用户及权限管理 4)数据库SQL监控 5)运行SQL脚本 6)可视化数据库设计 7)数据库传输功能:在两个数据库之间传递数据,类似SQL Server的DTS 8)数据库创建删除功能 这个工具的功能已经相当全了,而且在友好性性上要超过PHPMyAdmin 3)Navicat公司(http://www.navicat.com/) Navicat2004这个产品和EMS Mysql Manager类似,但增加了定时运行的功能,这样你就可以 定时备份,定时恢复,可以减轻系统管理员的工作量,这个工具也可以在http://www.1xia.com/ 上下载
|