gpt4 book ai didi

postgresql - 如何在go中模拟sql更新

转载 作者:IT王子 更新时间:2023-10-29 01:47:29 27 4
gpt4 key购买 nike

我正在尝试编写一个单元测试来更新 golang 中 postgresql 中的记录

数据库功能是

CREATE OR REPLACE FUNCTION test.update(param_id text, param_data jsonb, id2 text) RETURNS void AS
$$
BEGIN
UPDATE test.test_table
SET data = param_data,
WHERE id = (SELECT id FROM test.test_table2 WHERE name = id2)
END;
$$
LANGUAGE plpgsql;

单元测试是

rows := sqlmock.NewRows([]string{"result"}).AddRow("")

mock.ExpectBegin()
mock.ExpectQuery(fmt.Sprintf("SELECT %v.update(.+)", schema)).WithArgs(1, data).WillReturnRows(rows)
mock.ExpectCommit()

我还需要在里面模拟选择查询吗?如何模拟 void 函数?

最佳答案

我用过下面的包

import (sql "database/sql")

这使我能够检查以下内容,

....
var rows sql.Result
...
<execute query >
...
rows.RowsAffected()

rows.RowsAffected() 提供更新的行数。

关于postgresql - 如何在go中模拟sql更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44327560/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com