Верхний регистр в HSQL - PullRequest
       18

Верхний регистр в HSQL

0 голосов
/ 12 июня 2018

Есть ли какой-нибудь способ, которым мы можем создать значение по умолчанию, значение в верхнем регистре для элемента в таблице создания для HSQL

CREATE TABLE IF NOT EXISTS  "job" (
   "id" INTEGER IDENTITY,
   "jobId" BIGINT ,
   "jobName" VARCHAR(100)  ,
   PRIMARY KEY ("jobName")
);

Теперь мне нужно каждый раз сохранять jobName в верхнем регистре.

Ответы [ 2 ]

0 голосов
/ 12 июня 2018

Для HSQLDB решение с сгенерированным столбцом (аналогично решению MySQL):

CREATE TABLE IF NOT EXISTS  "job" (
 "id" INTEGER IDENTITY,
 "jobId" BIGINT ,
 "jobName" VARCHAR(100)  ,
 "jobNameU" VARCHAR(100) GENERATED ALWAYS AS (UPPER("jobName")),   
 PRIMARY KEY ("jobNameU")
);

Существует лучшее решение с триггером BEFORE INSERT, которое работает без дополнительного сгенерированного столбца:

CREATE TABLE IF NOT EXISTS  "job" (
   "id" INTEGER IDENTITY,
   "jobId" BIGINT ,
   "jobName" VARCHAR(100)  ,
   PRIMARY KEY ("jobName")
);

CREATE TRIGGER makeUpper BEFORE INSERT ON "job" REFERENCING NEW ROW AS NEW
  FOR EACH ROW
  SET NEW."jobName" = UPPER(NEW."jobName")
0 голосов
/ 12 июня 2018

Вы можете использовать вычисляемый / сгенерированный столбец:

-- MySQL
CREATE TABLE job (
   id INT AUTO_INCREMENT,
   jobid INT ,
   jobName VARCHAR(100)  ,
   jobNameU VARCHAR(100) GENERATED ALWAYS AS (UPPER(jobName)) STORED,
   PRIMARY KEY (jobNameU),
   KEY(id)
);

INSERT INTO job(id, jobid, jobName)
VALUES (1,2,'aaa');

INSERT INTO job( jobid, jobName)
VALUES (2,'aaA')
--  Duplicate entry 'AAA' for key 'PRIMARY'

DBFiddle Demo

...