表更改后立即使用 gRPC 传输数据库数据
短信预约 -IT技能 免费直播动态提醒
问题内容
我正在使用 go、grpc 和 postgres 制作任务列表。
如何在调用 postitem
插入新数据时自动流式传输数据?我需要订阅 postgres 还是可以在不订阅或发布订阅的情况下完成此操作?
// protobuf 架构
syntax = "proto3";
package tasklist;
import "google/protobuf/empty.proto";
service todolist {
rpc gettasks(google.protobuf.empty) returns (stream gettasksresponse) {}
rpc postitem(postitemrequest) returns (posttaskrequest) {}
}
message task {
int64 id = 1;
string name = 2;
}
message gettasksresponse {
task task = 1;
}
message posttaskrequest {
task task = 1;
}
message postitemresponse {
bool result = 1;
}
// postgres 表架构
create table task (
id integer not null primary key,
name varchar(10) not null
);
// 继续
func (s *server) GetTasks(_ *empty.Empty, stream pb.TaskList_GetTasksServer) error {
// How can I steam data as soon as `PostTask` is called to update db? <- <-
for _, r := range s.requests {
// stream data
}
}
func (s *server) PostTask(ctx context.Context, r *pb.PostTaskRequest) (*pb.PostTaskResponse, error) {
// update Postgres here
return &pb.PostItemResponse{Result: true}, nil
}
正确答案
我猜 s.requests
类似于 chan task
。因此,在成功 // update postgres here
之后,您可以在 chan 中发送您的请求。
func (s *server) PostTask(ctx context.Context, r *pb.PostTaskRequest) (*pb.PostTaskResponse, error) {
postTask := toDomain(r)
err := s.service.UpdateTask(ctx, postTask)
if err != nil {
return nil, status.Error(codes.Internal, err.Error())
}
s.requests <- postTask
return &pb.PostItemResponse{Result: true}, nil
}
以上就是表更改后立即使用 gRPC 传输数据库数据的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
表更改后立即使用 gRPC 传输数据库数据
下载Word文档到电脑,方便收藏和打印~
下载Word文档
猜你喜欢
表更改后立即使用 gRPC 传输数据库数据
问题内容我正在使用 go、grpc 和 postgres 制作任务列表。如何在调用 postitem 插入新数据时自动流式传输数据?我需要订阅 postgres 还是可以在不订阅或发布订阅的情况下完成此操作?// protobuf 架构
2024-02-05
2024-04-02
2023-05-14
2024-04-02
Android 使用ContentObserver监听数据库内容是否更改
Android 使用ContentObserver监听数据库内容是否更改ContentObserver——内容观察者,目的是观察(捕捉)特定Uri引起的数据库的变化,继而做一些相应的处理,它类似于数据库技术中的触发器(Trigger),当C
2023-05-30
2024-04-02
2024-04-02
2024-04-02
2023-09-14
react中useState使用:如何实现在当前表格直接更改数据
这篇文章主要介绍了react中useState的使用:如何实现在当前表格直接更改数据,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13
sqlserver数据库加密后无法使用MDF,LDF,log文件名称被修改的数据恢复怎么办
这篇文章主要介绍了sqlserver数据库加密后无法使用MDF,LDF,log文件名称被修改的数据恢复怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。故障:2个SQL s
2023-06-29
如何使用阿里云主机将数据库中的文件传输到电脑上
本文将介绍如何使用阿里云主机将数据库中的文件传输到电脑上的方法。通过以下步骤,您可以在不破坏数据库结构的情况下,方便地将文件从数据库中提取出来,并保存到您的电脑上。1.登录阿里云主机首先,您需要登录到您的阿里云主机。在浏览器中输入您的主机IP地址和登录凭证,例如用户名和密码,然后点击登录按钮。2.连接到数据库一旦
2023-12-28
2024-04-02