技术标签: golang
db := database.GetDB(ctx)
func (a *RuleTarget) DelSystemRuleTargets(
ctx context.Context,
targets []*pbWeb.RuleTarget,
) (successCount int32, err error) {
for _, target := range targets {
// 注意如果是uid层面的删除,要级联删除cid和aid的数据
if fflag.IsSwitchOn(ctx, fflag.FlagSystemRuleAllRalated) {
log.ErrorContextf(ctx, "begin delete")
db = db.Where("rule_id = ?", 0).Where("account_id = ?", target.AccountId).
Where("status = ?", 0)
if target.CampaignId != 0 {
// 对cid进行删除
db = db.Where("campaign_id = ?", target.CampaignId)
}
err = db.Delete(RuleTarget{}).Error
} else {
err = db.Where(map[string]interface{}{
"rule_id": 0,
"account_id": target.AccountId,
"campaign_id": target.CampaignId,
"adgroup_id": target.AdgroupId,
}).Delete(RuleTarget{}).Error
}
if err != nil {
log.ErrorContextf(ctx, "RuleTarget.DelSystemRuleTargets() Error: %s", err.Error())
continue
} else {
successCount++
}
}
return successCount, nil
}
这里db = xx 语句执行了多次,因此这里gorm将查询条件放在了db中。结果就是在循环中下次执行的时候,db中的数据并没有清除掉。带上了上次的执行条件。例如:
第一次:
UPDATE `rule_targets` SET `deleted_at`='2021-05-24 15:57:32' WHERE `rule_targets`.`deleted_at` IS NULL AND ((rule_id = 0) AND (account_id = 172198) AND (status = 0))
第二次:
UPDATE `rule_targets` SET `deleted_at`='2021-05-24 15:57:32' WHERE `rule_targets`.`deleted_at` IS NULL AND ((rule_id = 0) AND (account_id = 172198) AND (status = 0) AND (rule_id = 0) AND (account_id = 20458) AND (status = 0))
但是这么写就可以:
// 开启保护中状态
// 因为存在批量操作,这里对非一键托管状态的aid忽略掉
func (a *RuleTarget) OpenSystemRuleProtected(ctx context.Context, targets []*pbWeb.RuleTarget) int {
// aid开启保护中,先删除,后增加这条记录(status = -1)
successCount := 0
systemRuleTargetsmap, err := a.getAidSystemRuleTarget(ctx, targets)
if err != nil {
log.ErrorContextf(ctx, "err in OpenSystemRuleProtected call getAidSystemRuleTarget:%v", err)
return successCount
}
db := database.GetDB(ctx)
for _, target := range targets {
// 不属于一键托管中
if systemRuleTargetsmap[target.AdgroupId] == 0 {
successCount++
continue
}
log.ErrorContextf(ctx, "begin delete")
err := db.Where(map[string]interface{}{
"rule_id": 0,
"account_id": target.AccountId,
"campaign_id": target.CampaignId,
"adgroup_id": target.AdgroupId,
}).Delete(RuleTarget{}).Error
if err != nil {
log.ErrorContextf(ctx, "del rule_target[%v]err:%v", target, err)
continue
}
// ruleTargetModel := &RuleTarget{
// RuleID: 0,
// AccountID: target.AccountId,
// CampaignID: target.CampaignId,
// AdGroupID: target.AdgroupId,
// Status: -1,
// }
// ruleTargetModel.setInstance(ruleTargetModel)
// err = ruleTargetModel.Save(ctx)
// if err != nil {
// log.ErrorContextf(ctx, "del rule_target[%v]err:%v", target, err)
// continue
// }
successCount++
}
return successCount
}
虽然也是在一个循环中执行同一个db变量,但是因为没有db = db.xxx语句,没有将ctx中放入查询条件,因此,每次循环执行是正常的额
实际修复方案:
for _, target := range targets {
db := database.GetDB(ctx)
// 注意如果是uid层面的删除,要级联删除cid和aid的数据
if fflag.IsSwitchOn(ctx, fflag.FlagSystemRuleAllRalated) {
db = db.Where("rule_id = ?", 0).Where("account_id = ?", target.AccountId).
Where("status = ?", 0)
if target.CampaignId != 0 {
// 对cid进行删除
db = db.Where("campaign_id = ?", target.CampaignId)
}
err = db.Delete(RuleTarget{}).Error
} else {
err = db.Where(map[string]interface{}{
"rule_id": 0,
"account_id": target.AccountId,
"campaign_id": target.CampaignId,
"adgroup_id": target.AdgroupId,
}).Delete(RuleTarget{}).Error
}
if err != nil {
log.ErrorContextf(ctx, "RuleTarget.DelSystemRuleTargets() Error: %s", err.Error())
continue
} else {
successCount++
}
}
就是吧 db := database.GetDB(ctx)放到循环内
文章浏览阅读231次。目前研究人员正在使用的深度学习框架不尽相同,有 TensorFlow 、PyTorch、Keras等。这些深度学习框架被应用于计算机视觉、语音识别、自然语言处理与生物信息学等领域,并获取了极好的效果。其中,PyTorch是当前难得的简洁优雅且高效快速的框架,当前开源的框架中,没有哪一个框架能够在灵活性、易用性、速度这三个方面有两个能同时超过PyTorch。基于此,磐小仙邀请到了作者 News(..._pytorch专栏开篇
文章浏览阅读1.2k次。其他版本 更新:2007 年 11 月/SAFESEH[:NO]在指定 /SAFESEH 后,只有在链接器还可以生成映像的安全异常处理程序表的情况下,该链接器才会生成一个映像。该表指定其异常处理程序适合于该映像的操作系统。只有在对 x86 目标进行链接时,/SAFESEH 才有效。已说明异常处理程序的平台不支持 _error lnk2026: 模块对于 safeseh 映像是不安全的。
文章浏览阅读732次。广告关闭腾讯云11.11云上盛惠 ,精选热门产品助力上云,云服务器首年88元起,买的越多返的越多,最高返5000元!在整个游戏运行期间,敌人列表的长度将不断变化。 我们将用这个游戏的设想贯穿始终,修改列表中元素、添加列表中元素、删除列表中元素的讲解中,首先,我们先看如何修改列表中的元素。 python中,修改列表元素的语法与访问列表元素的语法类似。 要修改列表元素,可指定列表名和要修改的元素的索引..._python修改列表元素
文章浏览阅读1k次。一、简介1.网页是组成一个网站的最基本的元素,一个网站做的好不好,就要看网页是如何编写的2.互联网上的信息,都是以网页的形式来给大家进行呈现的,所以网页实际上就是我们一个网站,或者网络信息传递的载体。网页文件使用一种特殊的标记语言所写的,这个标记语言的名称:HTML(超文本标记语言 Hyper Text Markup language)3.概念:Html是一种标记语言,不是编程语言,主要作用..._简述html的语法规范是什么
文章浏览阅读400次。本节课重点了解 EasyUI 中 NumberBox(数值输入框)组件的使用方法,这个组件依赖于 ValidateBox(验证框)组件。一. 加载方式//class 加载方式data-options="min:0,precision:2">//JS 加载调用$('#box').numberbox({min : 0,precision : 2,});二. 属性列表//属性设置$('#box')..._numberbox中data-options
文章浏览阅读660次。首先打印一次recv调用失败的errno值和各个宏的值.由上可知,EAGIN和EWOULDBLOCK的值都是11,其实EAGIN是在setsockopt设置SO_RCVTIMEO或SO_SNDTIMEO后,recv或者send系列函数超时等待返回-1,此时的errno值。EWOULDBLOCK则是大家熟悉的异步调用产生的errno。recv return -1,errn..._recv -1 errno 4 so_rcvtimeo
文章浏览阅读46次。2019独角兽企业重金招聘Python工程师标准>>> ..._data=l'a','b','c','d','e','f','g','h']for i in data[1:6:2]:print(i)
文章浏览阅读1k次。listview,girdview这些控件在我们android开发经常用的到,但是,数据显示不全的问题也是我们经常碰到的,下面只要在代码中加入几行代码即可以下方法仅供参考,转自网络listview控件显示数据private void listFitHeight(ListView listView){ RepairDetailInfosAdpter listAdapter=(RepairDet_gridview 数据少了
文章浏览阅读6.6k次。使用开源软件Prometheus监控企业内部资源1. 写在前面 在电厂行政管理大区内,因为业务体量小,业务变化相对少,之前公司采用的监控技术栈较为落后,只有简单的北塔网络监控,基本没有任何的监控平台。 接触Docker和kubernetes时间久了,开源的监控方案所接触。网上也有不少Zabbix、Nagios、Open-Falcon、Prometheus、Influxdb的对比这里就不一一列举了。最终平海电厂选择Prometheus+Grafana+explorer技术栈作为企_8919 hostname关联
文章浏览阅读477次。今天配置hbase的时候发现有几台机器的regionserver启不来。报错例如以下: at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(N..._启动hbase没有hquorumpeer和hregionserver
文章浏览阅读1.5k次。//// ViewController.m// 父控件与子控件#import "ViewController.h"@interface ViewController ()@end@implementation ViewController- (void)viewDidLoad { [super viewDidLoad]; /** *_ug删除父视图子视图也没了,怎么取消关联
文章浏览阅读1.4w次,点赞2次,收藏6次。抛异常:09-15 02:55:15.835 10255-10255/com.example.fanenqian.jndk E/AndroidRuntime: FATAL EXCEPTION: main Process: com.examp_ndk java.lang.unsatisfiedlinkerror: no implementation found for