后台报SQL Error: 1064, SQLState: 42000错误

警告: SQL Error: 1064, SQLState: 42000 
2010-5-29 22:04:38 org.hibernate.util.JDBCExceptionReporter logExceptions 
严重: 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 'desc) values ('org1', 'ads')' at line 1 

 
原来是我在表中用到的字段有:desc,是Mysql数据库中关键字

 



MySQL的保留字有以下这些,使用中需要注意。

 

ADD

ALL

ALTER

ANALYZE

AND

AS

ASC

ASENSITIVE

BEFORE

BETWEEN

BIGINT

BINARY

BLOB

BOTH

BY

CALL

CASCADE

CASE

CHANGE

CHAR

CHARACTER

CHECK

COLLATE

COLUMN

CONDITION

CONNECTION

CONSTRAINT

CONTINUE

CONVERT

CREATE

CROSS

CURRENT_DATE

CURRENT_TIME

CURRENT_TIMESTAMP

CURRENT_USER

CURSOR

DATABASE

DATABASES

DAY_HOUR

DAY_MICROSECOND

DAY_MINUTE

DAY_SECOND

DEC

DECIMAL

DECLARE

DEFAULT

DELAYED

DELETE

DESC

DESCRIBE

DETERMINISTIC

DISTINCT

DISTINCTROW

DIV

DOUBLE

DROP

DUAL

EACH

ELSE

ELSEIF

ENCLOSED

ESCAPED

EXISTS

EXIT

EXPLAIN

FALSE

FETCH

FLOAT

FLOAT4

FLOAT8

FOR

FORCE

FOREIGN

FROM

FULLTEXT

GOTO

GRANT

GROUP

HAVING

HIGH_PRIORITY

HOUR_MICROSECOND

HOUR_MINUTE

HOUR_SECOND

IF

IGNORE

IN

INDEX

INFILE

INNER

INOUT

INSENSITIVE

INSERT

INT

INT1

INT2

INT3

INT4

INT8

INTEGER

INTERVAL

INTO

IS

ITERATE

JOIN

KEY

KEYS

KILL

LABEL

LEADING

LEAVE

LEFT

LIKE

LIMIT

LINEAR

LINES

LOAD

LOCALTIME

LOCALTIMESTAMP

LOCK

LONG

LONGBLOB

LONGTEXT

LOOP

LOW_PRIORITY

MATCH

MEDIUMBLOB

MEDIUMINT

MEDIUMTEXT

MIDDLEINT

MINUTE_MICROSECOND

MINUTE_SECOND

MOD

MODIFIES

NATURAL

NOT

NO_WRITE_TO_BINLOG

NULL

NUMERIC

ON

OPTIMIZE

OPTION

OPTIONALLY

OR

ORDER

OUT

OUTER

OUTFILE

PRECISION

PRIMARY

PROCEDURE

PURGE

RAID0

RANGE

READ

READS

REAL

REFERENCES

REGEXP

RELEASE

RENAME

REPEAT

REPLACE

REQUIRE

RESTRICT

RETURN

REVOKE

RIGHT

RLIKE

SCHEMA

SCHEMAS

SECOND_MICROSECOND

SELECT

SENSITIVE

SEPARATOR

SET

SHOW

SMALLINT

SPATIAL

SPECIFIC

SQL

SQLEXCEPTION

SQLSTATE

SQLWARNING

SQL_BIG_RESULT

SQL_CALC_FOUND_ROWS

SQL_SMALL_RESULT

SSL

STARTING

STRAIGHT_JOIN

TABLE

TERMINATED

THEN

TINYBLOB

TINYINT

TINYTEXT

TO

TRAILING

TRIGGER

TRUE

UNDO

UNION

UNIQUE

UNLOCK

UNSIGNED

UPDATE

USAGE

USE

USING

UTC_DATE

UTC_TIME

UTC_TIMESTAMP

VALUES

VARBINARY

VARCHAR

VARCHARACTER

VARYING

WHEN

WHERE

WHILE

WITH

WRITE

X509

XOR

YEAR_MONTH

ZEROFILL

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Error: 1064, SQLState: 42000是一个常见的SQL错误。这个错误通常表示你在SQL语句中使用了MySQL的关键字或保留字。MySQL关键字和保留字是数据库中已经被预定义并有特殊含义的词汇。 在你提到的情况中,当你使用Spring Boot和Hibernate进行数据库操作时,如果你的表名或列名与MySQL的关键字或保留字重名,就会出现SQL Error: 1064, SQLState: 42000错误。 要解决这个错误,你可以尝试以下几个方法: 1. 重命名与MySQL关键字冲突的表名或列名:确保你的表名和列名不与MySQL的关键字或保留字重名,可以通过在命令中加上反引号来避免与关键字冲突,例如:`order`。 2. 使用转义字符:如果你无法修改表名或列名,你可以在SQL语句中使用反引号将其括起来,例如:SELECT `order` FROM table_name。 3. 避免使用MySQL的关键字作为表名或列名:为了避免与MySQL的关键字冲突,最好不要使用MySQL的关键字作为表名或列名。 需要注意的是,不同的数据库管理系统可能有不同的关键字和保留字,所以在编写SQL语句时,要留意使用的数据库系统的文档来避免冲突。 总结:SQL Error: 1064, SQLState: 42000表示你在SQL语句中使用了MySQL的关键字或保留字。为了解决这个错误,你可以重命名与关键字冲突的表名或列名,使用转义字符或避免使用关键字作为表名或列名。 : 引用内容:MySQL 关键字和保留字 : 引用内容:使用Spring boot Hibernate 测试数据库操作,发现customer表能增删改查,order表总是SQL Error: 1064, SQLState: 42000,看SQL语句又没问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值