首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >phpMyadmin错误sql语法

phpMyadmin错误sql语法
EN

Stack Overflow用户
提问于 2013-03-23 12:44:10
回答 2查看 1.5K关注 0票数 1

SQL查询:

代码语言:javascript
复制
CREATE TABLE  summertraining.student(

studentID VARCHAR( 9 ) NOT NULL ,
Name VARCHAR( 20 ) NOT NULL ,
KSUEmail VARCHAR( 20 ) NOT NULL ,
PhoneNo VARCHAR( 14 ) NOT NULL ,
coordinatorName VARCHAR( 20 ) NULL ,
supervisorName VARCHAR( 20 ) NULL ,
GPA DOUBLE( 4 ) NOT NULL ,
password VARCHAR( 10 ) NOT NULL ,
registerFlag VARCHAR( 7 ) NOT NULL ,
PRIMARY KEY (  studentID )
) ENGINE = INNODB;

MySQL说:

1064 -您的SQL语法有错误;请检查与您的MySQL服务器版本对应的手册,以获得正确的语法,以便在第1行使用text ') NOT NULL、password VARCHAR(10) NOT NULL、registerFlag VARCHAR(7) NOT NULL‘。

EN

回答 2

Stack Overflow用户

发布于 2013-03-23 12:57:47

这个错误是一致的:

代码语言:javascript
复制
GPA DOUBLE( 4 ) NOT NULL ,

需要使用:

代码语言:javascript
复制
GPA DOUBLE NOT NULL ,
票数 0
EN

Stack Overflow用户

发布于 2013-03-23 13:17:59

正如@Serg所指出的,问题确实是DOUBLE(4)部分。如果要为双值指定精度,则至少需要有两个数字来指定精度,而不仅仅是一个。来自MySQL手册:

MySQL允许非标准语法:浮点(M,D)或实(M,D)或双精度(M,D)。在这里,“(M,D)”的意思是可以用总计最多M位的值来存储,其中D位数可能在小数点之后。例如,定义为FLOAT(7,4)的列在显示时将类似于-999.9999。MySQL在存储值时执行四舍五入,因此如果将999.00009插入浮点数(7,4)列中,则近似结果为999.0001。

但是,您可能只想坚持使用DOUBLE,因为这个语法是特定于MySQL的:

为了最大限度地实现可移植性,需要存储近似数字数据值的代码应该使用浮点数或双精度,而不指定精度或数字数。

以下是手册中相关页面的链接:http://dev.mysql.com/doc/refman/5.6/en/floating-point-types.html

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15586921

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档