Merge pull request #9689 from Budibase/fix/9654

Fix for SQL many-to-many configuration via relationship modal
This commit is contained in:
Michael Drury 2023-02-14 15:02:12 +00:00 committed by GitHub
commit ebc52123b1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 41 additions and 28 deletions

View File

@ -42,25 +42,16 @@ services:
couchdb-service: couchdb-service:
# platform: linux/amd64 # platform: linux/amd64
container_name: budi-couchdb-dev container_name: budi-couchdb3-dev
restart: on-failure restart: on-failure
image: ibmcom/couchdb3 image: budibase/couchdb
environment: environment:
- COUCHDB_PASSWORD=${COUCH_DB_PASSWORD} - COUCHDB_PASSWORD=${COUCH_DB_PASSWORD}
- COUCHDB_USER=${COUCH_DB_USER} - COUCHDB_USER=${COUCH_DB_USER}
ports: ports:
- "${COUCH_DB_PORT}:5984" - "${COUCH_DB_PORT}:5984"
volumes: volumes:
- couchdb3_data:/opt/couchdb/data - couchdb_data:/data
couch-init:
container_name: budi-couchdb-init-dev
image: curlimages/curl
environment:
PUT_CALL: "curl -u ${COUCH_DB_USER}:${COUCH_DB_PASSWORD} -X PUT couchdb-service:5984"
depends_on:
- couchdb-service
command: ["sh","-c","sleep 10 && $${PUT_CALL}/_users && $${PUT_CALL}/_replicator; fg;"]
redis-service: redis-service:
container_name: budi-redis-dev container_name: budi-redis-dev
@ -73,9 +64,9 @@ services:
- redis_data:/data - redis_data:/data
volumes: volumes:
couchdb3_data: couchdb_data:
driver: local driver: local
minio_data: minio_data:
driver: local driver: local
redis_data: redis_data:
driver: local driver: local

View File

@ -152,7 +152,7 @@
fromTable, fromTable,
throughTable, throughTable,
fromTable.primary[0], fromTable.primary[0],
throughFromKey throughToKey
), ),
throughToKey: throughToKey:
errorChecker.manyForeignKeySet(throughToKey) || errorChecker.manyForeignKeySet(throughToKey) ||
@ -160,7 +160,7 @@
toTable, toTable,
throughTable, throughTable,
toTable.primary[0], toTable.primary[0],
throughToKey throughFromKey
), ),
fromForeign: fromForeign:
errorChecker.foreignKeySet(fromForeign) || errorChecker.foreignKeySet(fromForeign) ||
@ -391,24 +391,14 @@
options={Object.keys(getTable(throughId)?.schema)} options={Object.keys(getTable(throughId)?.schema)}
bind:value={throughToKey} bind:value={throughToKey}
bind:error={errors.throughToKey} bind:error={errors.throughToKey}
on:change={e => on:change={changed}
changed(() => {
if (throughFromKey === e.detail) {
throughFromKey = null
}
})}
/> />
<Select <Select
label={`Foreign Key (${getTable(toId)?.name})`} label={`Foreign Key (${getTable(toId)?.name})`}
options={Object.keys(getTable(throughId)?.schema)} options={Object.keys(getTable(throughId)?.schema)}
bind:value={throughFromKey} bind:value={throughFromKey}
bind:error={errors.throughFromKey} bind:error={errors.throughFromKey}
on:change={e => on:change={changed}
changed(() => {
if (throughToKey === e.detail) {
throughToKey = null
}
})}
/> />
{/if} {/if}
{:else if isManyToOne && toId} {:else if isManyToOne && toId}

View File

@ -0,0 +1,32 @@
SELECT 'CREATE DATABASE main'
WHERE NOT EXISTS (SELECT FROM pg_database WHERE datname = 'main')\gexec
CREATE SCHEMA test;
CREATE TABLE territories (
territory_id character varying(20) PRIMARY KEY,
territory_description character varying(60) NOT NULL
);
CREATE TABLE employees (
employee_id smallint PRIMARY KEY,
last_name character varying(20) NOT NULL,
first_name character varying(10) NOT NULL,
title character varying(30),
title_of_courtesy character varying(25),
birth_date date,
hire_date date,
address character varying(60),
city character varying(15),
region character varying(15),
postal_code character varying(10),
country character varying(15),
home_phone character varying(24),
extension character varying(4),
photo bytea,
notes text,
reports_to smallint REFERENCES employees(employee_id),
photo_path character varying(255)
);
CREATE TABLE employee_territories (
employee_id smallint REFERENCES employees(employee_id),
territory_id character varying(20) REFERENCES territories(territory_id),
CONSTRAINT pk_employee_territories PRIMARY KEY (employee_id, territory_id)
);