次のデータベース構造があります。
CREATE TABLE songs (_id SERIAL PRIMARY KEY, _artist TEXT, _name TEXT);
CREATE TABLE cafes (_id SERIAL, _ip TEXT PRIMARY KEY);
CREATE TABLE users (_id SERIAL UNIQUE, _imei TEXT PRIMARY KEY);
CREATE TABLE votes (_id SERIAL PRIMARY KEY, _cafe TEXT, _user INTEGER, _song INTEGER, _vote INTEGER);
特定の行が存在するかどうかをチェックし、存在しない場合はそれらを作成するストアド プロシージャがあります。
ストアド プロシージャ:
CREATE OR REPLACE FUNCTION testfunc(user_imei text, cafe_ip text, song_artist text, song_name text) RETURNS void AS $$
DECLARE
id_cafe INTEGER;
id_user INTEGER;
id_song INTEGER;
temp_row RECORD;
BEGIN
IF NOT EXISTS (SELECT _id FROM users WHERE _imei = user_imei) THEN
insert into users (_imei) values (user_imei);
END IF;
IF NOT EXISTS (SELECT _id FROM cafes WHERE _ip = cafe_ip) THEN
insert into cafes (_ip) values (cafe_ip);
END IF;
IF NOT EXISTS (SELECT _artist FROM songs WHERE _artist = song_artist AND _name = song_name) THEN
insert into songs (_artist, _name) values (song_artist, song_name);
END IF;
END;
$$ LANGUAGE plpgsql;
結局、新しい行を table に挿入したいのですがvote
、ここで:
_cafe = cafes._id
_song = 曲._id
_user = users._id
誰でも私を助けることができますか?