本文目录一览:
mysql 无法启动的几种常见问题
1、情况一:MySQL的错误日志文件(安装目录\MYOA\data5\机器名.err
)会记录如下内容:
InnoDB: Reading tablespace information from the .ibd files...
InnoDB: Error: trying to add tablespace 460 of name '.\td_oa\flow_data_35.ibd'
InnoDB: to the tablespace memory cache, but tablespace
InnoDB: 460 of name '.\td_oa\exam_data.ibd' already exists in the tablespace
解决方法:
- 剪切出安装目录
\MYOA\data5\TD_OA
的flow_data_35.ibd
和flow_data_35.frm
两个文件; - 启动
MySQL5_OA
服务,使用备份的flow_data_35.sql
导入到TD_OA
库中。如果提示flow_data_35
表已经存在不能导入,则继续按后续步骤执行; - 在
data5
下手动建立tmp
目录; - 使用MySQL管理工具或MySQL命令行程序在
tmp
下建立名称为flow_data_35
的表(包含一个字段即可); - 将
tmp
下的flow_data_35.frm
和flow_data_35.ibd
拷贝到安装目录\MYOA\data5\TD_OA
目录下; - 在MySQL管理工具或MySQL命令行程序中,进入
TD_OA
库,使用“drop table flow_data_35;
”命令清除公共表空间中残留的flow_data_35
表的相关信息; - 进入
tmp
库,删掉flow_data_35
表; - 使用备份的
flow_data_35.sql
导入到TD_OA
库中; - 如果还有其他表存在该问题,可重复执行4至8步骤。
2、情况二:MySQL的错误日志文件(安装目录
\MYOA\data5\机器名.err
)会记录如下内容:
130409 15:54:31 [Note] Plugin 'FEDERATED' is disabled.
130409 15:54:31 InnoDB: The InnoDB memory heap is disabled
130409 15:54:31 InnoDB: Mutexes and rw_locks use Windows interlocked functions
130409 15:54:31 InnoDB: Compressed tables use zlib 1.2.3
130409 15:54:32 InnoDB: Initializing buffer pool, size = 1023.0M
InnoDB: VirtualAlloc(1086849024 bytes) failed; Windows error 8
130409 15:54:32 InnoDB: Completed initialization of buffer pool
130409 15:54:32 InnoDB: Fatal error: cannot allocate memory for the buffer pool
130409 15:54:32 [ERROR] Plugin 'InnoDB' init function returned error.
130409 15:54:32 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
130409 15:54:32 [ERROR] Unknown/unsupported storage engine: Innodb
130409 15:54:32 [ERROR] Aborting
解决方法:
此情况出现的原因是myoa\mysql5\my.ini
中innodb_buffer_pool_size
的值太大,OA服务器操作系统不支持所致。改小后再启动mysql5_OA
服务即可,一般保持和数据库大小一致。数据库大小即是myoa/data5
的大小。
3、情况三:mysql服务启动不了,事件查看器中显示:
The syntax '--log-slow-queries' is deprecated and will be removed in a future release. Please use '--slow-query-log'/'--slow-query-log-file' instead.
解决方法:
安装目录\MYOA\data5
下的ibdata1
、ib_logfile0
、ib_logfile1
文件属性被设置为只读导致,取消只读控制,重启mysql5_OA
服务即可。
4、情况四:MySQL的错误日志文件(data5\机器名.err
)会记录如下内容:
InnoDB: No valid checkpoint found.
解决方法:
此问题找不到检查点,数据库是无效的,此种情况,只能用热备份数据恢复。
5、以上四种情况,是2013版OA系统目前比较常见的mysql服务启动不了的现象和解决办法,大家可作参考,其他情况的话,再具体分析处理。
6、分析思路总结:遇到mysql5_OA
服务启动不了的情况,首先查看myoa\data5
下的错误日志文件,根据日志中的具体内容进行具体分析。
7、2013版MYSQL服务启动不了(可以尝试强制启动mysql服务)方法如下:
- 打开
\MYOA\mysql5\my.ini
,去掉innodb_force_recovery=1
前边的注释。 - 启动
MySQL5_OA
服务,此时MySQL处于只读状态,可以导出,不可写入。如果仍不能启动,可以尝试将innodb_force_recovery
修改为2、3、4、5、6等,直到可以启动为止。 - 使用MySQL管理工具,将
TD_OA
等相关的数据库导出为SQL文件。 - 停止
MySQL5_OA
服务,删除TD_OA
下的所有文件、ibdata1
、ib_logfile0
、ib_logfile1
等文件。 - 打开
\MYOA\mysql5\my.ini
,在innodb_force_recovery=1
前边加上#
号,将该项注释掉。 - 启动
MySQL5_OA
服务,然后导入此前备份的SQL文件。 - 检查数据库,将无法通过该方法恢复的数据表,通过之前自动备份的SQL文件进行恢复。
MYSQL数据库问题
创建数据库
create database 数据库名
on primary --主文件
(
name=逻辑名,
filename='存储路径及文件名', --是字符串需要用''
size=大小 --需要加单位,如MB
)
log on --日志文件
(
name=逻辑名,
filename='存储路径及文件名',
size=大小
)
创建表
- 判断表是否存在:
if exists(select * from sysobjects where id = object_id(N'表名'))
注:
exists(select语句)
,若select语句无数据行则返回false,否则返回truesysobjects
是系统表的一个,存储了所有的数据库对象的表object_id(表名)
,返回表在数据库中的id号
- 创建表:
create table 表名
(
字段名 字段类型 是否允许为空 约束键,
...
)
注:
- 最后一个字段不需要
,
号 - 若允许为空写
null
,不允许写not null
- 约束键在第八章
- 删除表:
drop table 表名
注:若有主键被外表的外键引用,需要先将外键表删除
Mysql数据库的基本问题
亲,你看看你这句:
COUNT(id) as num, SUM(num) as zongshu
你确定,num
是你数据库里的字段?如果是字段你为什么要 as
别名成num
?
如果num
是别名,你SUM(num) as zongshu
就会提示错误,因为num
根本就不是字段,而只是个你临时命名的别名,所以报错是理所当然的。
能理解吗?不懂继续追问。