我有以下数据库结构:
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 = song._id
_user = users._id
任何人都可以帮助我吗?