作者热门文章
- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在尝试编写一个单元测试来更新 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/
我是一名优秀的程序员,十分优秀!