栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如果存在一行,则返回ID,否则返回INSERT

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如果存在一行,则返回ID,否则返回INSERT

我建议在数据库端进行检查,然后将ID返回给nodejs。

例子:

CREATE OR REPLACe FUNCTION foo(p_param1 tableFoo.attr1%TYPE, p_param2 tableFoo.attr1%TYPE) RETURNS tableFoo.id%TYPE AS $$  DECLARE  v_id tableFoo.pk%TYPE;  BEGIN    SELECT id    INTO v_id    FROM tableFoo    WHERe attr1 = p_param1    AND attr2 = p_param2;    IF v_id IS NULL THEN      INSERT INTO tableFoo(id, attr1, attr2) VALUES (DEFAULT, p_param1, p_param2)      RETURNING id INTO v_id;    END IF;    RETURN v_id:  END;$$ LANGUAGE plpgsql;

而不是在Node.js端(在此示例中,我使用的是node-postgres):

var pg = require('pg');pg.connect('someConnectionString', function(connErr, client){  //do some errorchecking here  client.query('SELECt id FROM foo($1, $2);', ['foo', 'bar'], function(queryErr, result){    //errorchecking    var id = result.rows[0].id;  };});


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/670431.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号