我在自己搭建的 MySQL 服务中, 在使用 create table 创建表时报了 1064 错误, 尝试网上找了各种解决方法, 最后还是被自己试着解决了. 解决的有的稀里糊涂的, 毕竟我自己对数据库知识还没个很清晰的认知. 废话不多说了, 下面看我的解决历程吧.
自己创建表的初衷: 想要从无到有的尝试
- set names utf8
- set foreign_key_checks=0
- drop table if exists `own_reimbursement`;
- create table `own_reimbursement` (
- `id` int(10) not null AUTO_INCREMENT,
- `start_time` date not null default,
- `end_time` date not null default,
- `travel_time` int(3) not null default,
- `place_name` char(30) default comment '地名',
- `project_name` char(30) default comment '项目名称',
- `venue_name` char(30) default comment '场馆名称',
- `personnel_name` char(30) default comment '人员',
- `hotel_expense` float(7) default comment '住宿费',
- `taxi_fare` float(7) not null default comment '打的费',
- `travel_allowance` float(7) not null default comment '出差补助',
- `road_fee` float(7) not null default comment '路费',
- `subsidy` float(7) not null default comment '报销合计',
- primary key (`id`)
- ) ENGINE=InnoDB AUTO_INCREMENT=100 DEFAULT CHARSET=utf8;
- BEGIN;
- INSERT INTO `own_reimbursement` VALUES ('1', '2018-08-22', '2018-08-31', '10', '江西景德镇','xx 项目','xxxx 运动中心','王思聪','1830','195.8','750','738','3513.8');
- COMMIT;
- SET FOREIGN_KEY_CHECKS = 1;
在执行时一直报 1064 错误, 让我百思不得其解, 还傻傻的以为真是 version 问题, 还特意找了相关的 version 说明看 (下了英文版的一脸懵逼的), 无赖直接简单粗暴的在网上搜 MySQL 创建表示报 1064 错误, 还真看到不少解决方法, 但没一条适用的.
- [SQL]set names utf8
- set foreign_key_checks=0
- drop table if exists `own_reimbursement`;
- [Err] 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'set foreign_key_checks=0
- drop table if exists `own_reimbursement`' at line 2
网上解决版本:
1. 查看 create table 语句里面的表, 列, 索引都要反斜杠符号也可以不使用, 但不能写成 '单引号. 不然执行就会报 1064 错误了
2. 不要使用 MySQL 的保留字
我的错误是因为 没搞清楚 default. 去掉 default 后就成功了.
- set names utf8;
- set foreign_key_checks = 0;
- drop table if exists `own_reimbursement`;
- create table `own_reimbursement` (
- `id` int(10) not null AUTO_INCREMENT,
- `start_time` date not null ,
- `end_time` date not null ,
- `travel_time` int(3) not null ,
- `place_name` char(30) NOT NULL comment '地名',
- `project_name` char(30) NOT NULL comment '项目名称',
- `venue_name` char(30) NOT NULL comment '场馆名称',
- `personnel_name` char(30) NOT NULL comment '人员',
- `hotel_expense` float(7) comment '住宿费',
- `taxi_fare` float(7) not null comment '打的费',
- `travel_allowance` float(7) not null comment '出差补助',
- `road_fee` float(7) not null comment '路费',
- `subsidy` float(7) not null comment '报销合计',
- primary key (`id`)
- ) ENGINE=InnoDB AUTO_INCREMENT=100 DEFAULT CHARSET=utf8;
- SET FOREIGN_KEY_CHECKS = 1;
原因:
default 修饰符
可以使用 DEFAULT 修饰符为字段设定一个默认值.
如果一个字段中没有指定 DEFAULT 修饰符, MySQL 会依据这个字段是 NULL 还是 NOT NULL 自动设置默认值.
如果指定字段可以为 NULL, 则 MySQL 为其设置默认值为 NULL.
如果是 NOT NULL 字段, MySQL 对于数值类型插入 0, 字符串类型插入空字符串,
时间戳类型插入当前日期和时间, ENUM 类型插入枚举组的第一条.
如果创建表时要使用 default 修饰符, 那不要忘记在 default 后面加个默认值.
例如:
- CREATE TABLE `websites` (
- `id` int(11) NOT NULL AUTO_INCREMENT,
- `name` char(20) NOT NULL DEFAULT ''COMMENT'站点名称',
- `url` varchar(255) NOT NULL DEFAULT '',
- `alexa` int(11) NOT NULL DEFAULT '0' COMMENT 'Alexa 排名',
- `country` char(10) NOT NULL DEFAULT ''COMMENT'国家',
- PRIMARY KEY (`id`)
- ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
来源: http://www.bubuko.com/infodetail-2801265.html