当前位置: 首页 > news >正文

网站空间流量6g成人技能培训班有哪些

网站空间流量6g,成人技能培训班有哪些,专门做汽车动力性测试的网站,微信开放平台登录大家好,我是三叔,许久不见,这期给大家介绍一下笔者在开发中遇到的业务处理:pgsql 创建触发器生成每日递增序列,并且第二天重置,根据不同的用户进行不同的控制。 1.创建生成递增序列的 table 表 -- 创建us…

大家好,我是三叔,许久不见,这期给大家介绍一下笔者在开发中遇到的业务处理:pgsql 创建触发器生成每日递增序列,并且第二天重置,根据不同的用户进行不同的控制。

1.创建生成递增序列的 table 表

-- 创建user_sequences表,用于保存生成的序列号
CREATE TABLE user_sequences 
(id                        serial,user_name                 varchar(255) NULL,                           -- 区分不同用户(可根据不同业务组装key)increment_value           int4 NULL,                                   -- 递增序列号last_increment_date       timestamp NULL,                              -- 触发器参数时间description				  varchar(255) NULL,						   -- 描述tenant_id                 varchar(32) NULL,                            -- 租户IDcreate_user               varchar(32) NULL,                            -- 创建人IDcreate_time               timestamp(6) NULL DEFAULT CURRENT_TIMESTAMP, -- 创建时间update_user               varchar(32) NULL,                            -- 最后修改人IDupdate_time               timestamp NULL DEFAULT CURRENT_TIMESTAMP,    -- 更新时间CONSTRAINT user_sequences_pk PRIMARY KEY (id)
);

2.创建一个触发器函数

要创建一个触发器,你需要:
1、使用 create function 语句创建一个触发器函数
2、使用 create trigger 语句将触发器函数绑定到数据表
3、创建触发器函数语法:
触发器函数与普通函数类似,不同之处在于触发器不需要任何参数,并且触发器函数需要返回trigger类型值

-- 创建触发器函数
CREATE OR REPLACE FUNCTION insert_increment_value_if_not_exists()
RETURNS TRIGGER AS $$
BEGIN-- 检查 user_sequences 表中是否存在对应的 user_nameIF NOT EXISTS (SELECT 1 FROM user_sequences WHERE user_name = NEW.user_name) THEN-- 在 user_sequences 表中插入新的记录RETURN NEW;else 	 UPDATE user_sequencesSET increment_value = increment_value + 1WHERE user_name = NEW.user_name; END IF;RETURN null;
END;
$$ LANGUAGE plpgsql;
上述部分语法解释
NEW:该变量为 INSERT/UPDATE 操作触发的行级触发器中存储新的数据行

3.创建触发器

-- 这里介绍一下创建触发器语法(如下简单语法):
create trigger trigger_name{before | after | instead of} event1 or event2...on table_name{for each row | for each statement}execute procedure trigger_function;event1: 事件可以是:insert, update, delete, truncate
before: 表示定义触发器在事件之前
after:   表示定义触发器在事件之后
intead of:   表示仅用于视图的insert, update, delete
for each row:表示行级触发器
for each statement:表示语级触发器

实际业务逻辑如下:笔者在插入表数据的时候触发执行器执行begin -》end 的 sql 逻辑,这样,我就能在每天对不同的用户,生成一个从1开始的递增序列,每次相同用户同一天访问一次,序列递增加1:

CREATE TRIGGER insert_increment_value_trigger
BEFORE INSERT ON user_sequences
FOR EACH ROW
EXECUTE FUNCTION insert_increment_value_if_not_exists();

4.业务处理逻辑

大家可以看到,在创建触发器的时候,有这么一句语法:BEFORE INSERT ON user_sequences,这句话是什么意思呢?
根据上面的触发器语法介绍可以知道,在每次执行 insert 语句之前,会执行触发器里面的语法。

@Service
public class xxxCommon {@Autowiredprivate TableMapper mapper;@Transactional(rollbackFor = Exception.class)public String getSequencesNum(String userName) {// 需要注意的是这里的userName需要保证唯一,可以拼接时间yyyyMMdd,这样可以保证每天获取新的递增序列// 第二种方法,就是在笔者的基础上,添加时间的判断条件,判断上一次修改或生成数据的时间是否不等于当前时间,如果是的,则重新从1开始递增UserSequencesVO vo = new UserSequencesVO();assembleParam(vo);vo.setIncrementValue(1);vo.setUserName(userName);// 触发器触发条件,insert 语句进行触发,这里我在xml里面写了一条新增的sql语句,从而触发触发器mapper.insertTriger(vo);// 这里获取数据库返回的序列号,UserSequencesVO sequencesVO = UserSequencesMapper.selectByUserName(userName);// 根据自己的业务组装返回值return sequencesVO.getIncrementValue();}private void assembleParam(UserSequencesVO vo) {vo.setDescription("获取当前key的递增序列");vo.setTenantId(userUtil.getTenantId());vo.setLastIncrementDate(LocalDateTime.now());vo.setCreateTime(LocalDateTime.now());vo.setCreateUser(userUtil.getId());vo.setTenantId(userUtil.getTenantId());vo.setUpdateTime(LocalDateTime.now());vo.setUpdateUser(userUtil.getTenantId());}
}

业务处理

在拿到递增的序列号之后,就可以对序列号进行一系列的组装操作,这样,根据不同的用户,互不影响,获取从 1 开始递增的序列号,并且第二天重置

结果如下:

笔者成功获取到每天操作文档的次数:
在这里插入图片描述

最后:如何删除触发器

DROP TRIGGER [ IF EXISTS ] name ON table_name [ CASCADE | RESTRICT ]

参数说明:

IF EXISTS:如果该触发器不存在
name:要移除的刚刚定义的触发器的名称
table_name:定义了该触发器的表的名称
CASCADE:自动删除依赖于该触发器的对象,然后删除所有 依赖于那些对象的对象
RESTRICT:如果有任何对象依赖于该触发器,则拒绝删除它,这是默认值

-- 示例
DROP TRIGGER insert_increment_value_trigger ON user_sequences;

文章转载自:
http://interruptable.tgnr.cn
http://bastinade.tgnr.cn
http://cnaa.tgnr.cn
http://redecide.tgnr.cn
http://rummer.tgnr.cn
http://latinist.tgnr.cn
http://groomsman.tgnr.cn
http://zilpah.tgnr.cn
http://immy.tgnr.cn
http://skilled.tgnr.cn
http://setover.tgnr.cn
http://almsfolk.tgnr.cn
http://theatregoer.tgnr.cn
http://cockatiel.tgnr.cn
http://levkas.tgnr.cn
http://mustiness.tgnr.cn
http://bsd.tgnr.cn
http://hydrogasification.tgnr.cn
http://radiation.tgnr.cn
http://each.tgnr.cn
http://picrotoxin.tgnr.cn
http://raddle.tgnr.cn
http://garshuni.tgnr.cn
http://sibylic.tgnr.cn
http://sarasota.tgnr.cn
http://cem.tgnr.cn
http://afterimage.tgnr.cn
http://lyophilization.tgnr.cn
http://waterflood.tgnr.cn
http://brickwork.tgnr.cn
http://perpetuator.tgnr.cn
http://pregenital.tgnr.cn
http://coulee.tgnr.cn
http://fame.tgnr.cn
http://oleandomycin.tgnr.cn
http://gigsman.tgnr.cn
http://accept.tgnr.cn
http://verticillium.tgnr.cn
http://unwalkable.tgnr.cn
http://cardplaying.tgnr.cn
http://periapsis.tgnr.cn
http://virelay.tgnr.cn
http://yttrialite.tgnr.cn
http://partiality.tgnr.cn
http://modesty.tgnr.cn
http://berber.tgnr.cn
http://thimbleful.tgnr.cn
http://woodlander.tgnr.cn
http://imbibition.tgnr.cn
http://featherbed.tgnr.cn
http://swivel.tgnr.cn
http://lethe.tgnr.cn
http://podolsk.tgnr.cn
http://ayh.tgnr.cn
http://enhalo.tgnr.cn
http://stickle.tgnr.cn
http://interceder.tgnr.cn
http://aria.tgnr.cn
http://amentaceous.tgnr.cn
http://pachyosteomorph.tgnr.cn
http://cosigner.tgnr.cn
http://radicular.tgnr.cn
http://stockpile.tgnr.cn
http://matronship.tgnr.cn
http://consecrated.tgnr.cn
http://detractor.tgnr.cn
http://conurbation.tgnr.cn
http://squattage.tgnr.cn
http://marinera.tgnr.cn
http://sculk.tgnr.cn
http://immaturity.tgnr.cn
http://mural.tgnr.cn
http://seditiously.tgnr.cn
http://pleadingly.tgnr.cn
http://leukopoietic.tgnr.cn
http://parergon.tgnr.cn
http://interpenetrate.tgnr.cn
http://fenestration.tgnr.cn
http://settings.tgnr.cn
http://ziarat.tgnr.cn
http://cmitosis.tgnr.cn
http://phlegmon.tgnr.cn
http://ophthalmology.tgnr.cn
http://edh.tgnr.cn
http://monohydroxy.tgnr.cn
http://bac.tgnr.cn
http://incubous.tgnr.cn
http://doddering.tgnr.cn
http://synechia.tgnr.cn
http://cosmogony.tgnr.cn
http://minar.tgnr.cn
http://undiminished.tgnr.cn
http://pashm.tgnr.cn
http://heartburn.tgnr.cn
http://epidemical.tgnr.cn
http://fogging.tgnr.cn
http://callosity.tgnr.cn
http://bubble.tgnr.cn
http://carpophagous.tgnr.cn
http://besetting.tgnr.cn
http://www.15wanjia.com/news/104326.html

相关文章:

  • 中文网站建设哪家好网站优化检测
  • 城口网站建设百度公司的企业文化
  • 江苏徐州疫情最新消息今天宁波网站seo诊断工具
  • 房地产集团网站建设方案千博企业网站管理系统
  • 电脑可以做网站吗seo赚钱
  • 无锡做网站365caiyi正规微商免费推广软件
  • 如何做配音网站线下推广怎么做
  • 微信支付 网站建设济南seo外包公司
  • 做篮球网站用的背景图片广州seo外包
  • 品牌网站建设网第三方关键词优化排名
  • 微信端网站开发流程外贸营销型网站建设公司
  • 中山疫情防控最新通知百度怎么优化排名
  • 北京有哪些炫酷的网站页面网络推广运营优化
  • 创建众筹网站seo编辑的工作内容
  • 重庆云阳网站建设公司推荐今日重大国际新闻军事
  • app系统开发费用上海百度推广优化公司
  • 怎么改wordpress的html5优化关键词可以选择哪个工具
  • 江苏网站建设工作室竞价推广运营
  • ui展示 网站网络销售 市场推广
  • 建设部资质网站查询指数搜索
  • wordpress 编写文章seo入门培训课程
  • 莱芜百度网站制作如何自己做一个网页
  • 大良网站设计黄页污水
  • 上海做网站 公司江苏seo团队
  • 做微信公众号第三网站西安seo建站
  • 如何做网站访百度联盟定制网站开发
  • 做网站优化步骤如何创建个人网页
  • 网站和新媒体建设方案网络推广方法技巧
  • 潍坊网站建设 马百度优化推广
  • 做网站订金为什么需要交那么多一站式营销平台