1

我的域类有问题。每次我尝试插入条目时,都会出现此错误:

The column name "Sequence_No" was not found in this ResultSet.

这是我的域类:

class Record {

String firstName
String middleName
String lastName
String motherMaidenLastName
String motherMaidenMiddleName
Date birthDate
String examTypeCode
Date examinationDate

static constraints = {
    firstName nullable:false, blank:false, maxSize: 50
    middleName nullable:true, blank:true, maxSize: 50
    lastName nullable:false, blank:false, maxSize: 50
    motherMaidenLastName nullable:true, blank:true, maxSize: 50
    motherMaidenMiddleName nullable:true, blank:true, maxSize: 50
    birthDate  nullable: false
    examTypeCode  nullable: false, maxSize: 4
    examinationDate  nullable: false
}

static mapping  = {
    datasource 'oevs'
    table '`elig`'
    id column: '`Sequence_No`'
    firstName column: '`FirstName`'
    middleName column: '`MiddleName`'
    lastName column: '`LastName`'
    motherMaidenLastName column: '`MotherMaidenLastName`'
    motherMaidenMiddleName column: '`MotherMaidenMiddleName`'
    birthDate column: '`Date_Birth`'
    examTypeCode column: '`ExamType`'
    examinationDate column: '`Date_Exam`'
    }
}

但是我试图保存的条目被插入到数据库中,它只是抛出了那个错误。我正在使用 PostgreSQL。我被要求以这种方式命名列名。这就是为什么我需要在命名我的列时放置一个反引号字符,因为如果不这样做,PostgreSQL 会自动将其全部转换为小写字母。每次我删除 id 列中的反引号字符时,错误都不会出现,但显然列名已转换为小写。

4

1 回答 1

1

错误在于以下语句:

这就是为什么我需要在命名我的列时放置一个反引号字符,因为如果不这样做,PostgreSQL 会自动将其全部转换为小写字母。

反引号 (``)仅在MySQL中使用(毫无意义地违反 SQL 标准 - 您可以使用它SET sql_mode = 'ANSI';来解决此问题)。反引号对 PostgreSQL 或标准 SQL 没有特殊意义。在 PostgreSQL中使用双引号("" ) (真的在任何地方)来实现您的目标。此相关答案中的更多详细信息。

你几乎是对的:在 PostgreSQL 中,没有双引号的标识符被转换为小写。有关详细信息,请阅读手册中的标识符和关键字一章。

我通常建议不要在 PostgreSQL 中使用 CamelCase 标识符。有很多方法可以克服它。困惑的用户的绝望问题不断出现在这里。如果可以的话,不要使用 CamelCase 和双引号标识符。创建非标准标识符后,您必须始终将其双引号...

于 2012-11-25T23:29:40.373 回答