H2 Schema initailization. Syntax error in SQL statement

前端 未结 4 829
渐次进展
渐次进展 2021-01-05 01:06

I have a spring boot application and I trying to initialize some data on application startup.

This is my application properties:

#Database connection         


        
相关标签:
4条回答
  • 2021-01-05 01:39

    This error results from the structure of the CREATE TABLE declaration.

    It will be the result when you have an extra comma in the end of your SQL declaration--no column declaration following the comma. For example:

    CREATE TABLE IF NOT EXISTS `Person` (
      `id`         INTEGER  PRIMARY KEY AUTO_INCREMENT,
      `first_name` VARCHAR(50) NOT NULL,
      `age`        INTEGER  NOT NULL,     --note this line has a comma in the end
    );
    

    That's because CREATE TABLE expects a list of the columns that will be created along with the table, and the first parameter of the column is the identifier. As you check here, the column declaration follows the structure:

    identifier datatype <constraints> <autoincrement> <functions>
    

    Thus, in your case, as @budthapa and @Vishwanath Mataphati have mentioned, you could simply remove the PRIMARY KEY(id) line from the CREATE TABLE declaration. Moreover, you have already stated that id is a primary key on the first line of the column definitions.

    In case you do not have a statement as the PRIMARY KEY declaration, be sure to check for the extra comma following your last column declaration.

    0 讨论(0)
  • 2021-01-05 01:49

    Try this, as you have used Table_name

    CREATE TABLE IF NOT EXISTS Person (
        id        INTEGER  PRIMARY KEY AUTO_INCREMENT,
         first_name VARCHAR(50) NOT NULL,
         age        INTEGER  NOT NULL
    );
    
    0 讨论(0)
  • 2021-01-05 01:49

    Use another com.h2database version. ex: 1.4.199

    0 讨论(0)
  • 2021-01-05 01:52

    Try this code. Remove PRIMARY KEY(id) and execute it.

    CREATE TABLE IF NOT EXISTS `Person` (
        `id`         INTEGER  PRIMARY KEY AUTO_INCREMENT,
         `first_name` VARCHAR(50) NOT NULL,
         `age`        INTEGER  NOT NULL
    );
    
    0 讨论(0)
提交回复
热议问题