oracle触发器:为什么update可以触发,但是insert就不行啊!大神们快围观啊!!!!!! 10C

CREATE OR REPLACE TRIGGER b2b_person_tri
AFTER INSERT OR UPDATE ON SYS_PERSON
FOR EACH ROW

DECLARE
v_entryid NUMBER(10);
v_personinfoid number(10);
PRAGMA AUTONOMOUS_TRANSACTION;

BEGIN
CASE
WHEN INSERTING THEN
select count(*) into v_entryid from sys_person p,b2b_entryconf t
where p.entryid = t.entryid
and p.personid = :new.personid;

if v_entryid > 0 then
select sys_nextid_fun('EDIS_UNTINTF_SEQ') into v_personinfoid from dual;
insert into edis_untintf(
edis_untintf_seq,
edis_untintf_sourceid,
edis_untintf_comefrom,
edis_untintf_intfname,
edis_untintf_credate,
edis_untintf_modol
)
values(
v_personinfoid,
:new.personid,
'SYS_PERSON',
'B2B',
sysdate,
'insert'
);
end if;
WHEN updating THEN
select count(*) into v_entryid from sys_person p, b2b_entryconf t
where p.entryid = t.entryid
and p.personid = :old.personid;

         if v_entryid > 0 then
            select sys_nextid_fun('EDIS_UNTINTF_SEQ') into v_personinfoid from dual;
            insert into edis_untintf(
                   edis_untintf_seq,
                   edis_untintf_sourceid,
                   edis_untintf_comefrom,
                   edis_untintf_intfname,
                   edis_untintf_credate,
                   edis_untintf_modol
            )
            values(
                   v_personinfoid,
                   :old.personid,
                   'SYS_PERSON',
                   'B2B',
                   sysdate,
                   'update'
            );
            commit;
       end if;

END CASE;

END;

3个回答

不大懂你写的啥,不过好像如果模式都一样的话你在insert下面好像没有提交

楼主你确定你的case的两个then都执行了吗,insert执行了吗,会不会是根本不满足条件没有执行insert所以没有触发

如果你插入了数据,那就一定会触发的。
只是你的判断条件 if v_entryid > 0 then 不一定成立罢了

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Oracle触发器:A表数据插入B表

具体问题描述: A表和B表字段完全相同,A表中插入数据且A表中status=1时该数据插入到B表中,数据在B表中当字段status=0时就执行删除该条数据 ===================================================== 下面是我写的代码,现在实现了A表中的数据全部插入到B表中了,其实应该有一个status=1在插入B表中,这我没实现,还有一个是当B表status=0时,该数据就删除了,这个我也没实现,有会的大神们帮帮忙 create or replace trigger AB_DML_TGR after insert on CARUSER_FINANCE for each row declare V_NUM number; begin V_NUM := 0; select count(*) into V_NUM from ARREARAGE_MANAGER M where M.CARUSER_ID= :new.caruser_id; if V_NUM = 0 then if inserting then insert into ARREARAGE_MANAGER values (:new.ID, :new.CARUSER_ID, :new.finance_status, :new.balance, :new.data_status, :new.create_time, :new.update_time, :new.end_time, :new.mes_owner, :new.u_owner ); end if; elsif :new.finance_status=0 then delete ARREARAGE_MANAGER t where t.finance_status=0; end if; end;

数据库insert,update触发器怎么同时写在一个触发器里

数据库里有A表和B表,A表新增数据的时候,也往B表里新增数据,A表在修改数据的时候,B表会记录这条数据,同样是新增数据,但是当这条数据再次被修改时,B表里的记录永远是修改后的数据,求告知触发器insert 与update 写在一起时,是怎么写的

Oracle触发器不能读取表的问题

12、假设有这样一张用户表表结构如下:UserInfo(id ,username,userPass),希望向表中增加数据时,表中id列的数字自动生成。(选做) 1)第一步创建序列,要求开始的数字为1,每次递增1,按顺序产生序列值; 2)第二步创建一个触发器,向用户表中插入数据的时候触发触发器,在触发器内部调用序列并生成一个序列值赋值给表的id列。 触发器: ``` create or replace trigger pro_id after insert on userinfo for each row begin update userinfo set id=seq_id.nextval where username=:new.username; end; ``` 执行该语句时出错: ``` insert into userinfo(username, userpass) values('李四',123456); ``` 在行 1 上开始执行命令时出错: insert into userinfo(username, userpass) values('李四',123456) 错误报告: SQL 错误: ORA-04091: 表 SCOTT.USERINFO 发生了变化, 触发器/函数不能读它 ORA-06512: 在 "SCOTT.PRO_ID", line 2 ORA-04088: 触发器 'SCOTT.PRO_ID' 执行过程中出错 04091. 00000 - "table %s.%s is mutating, trigger/function may not see it" *Cause: A trigger (or a user defined plsql function that is referenced in this statement) attempted to look at (or modify) a table that was in the middle of being modified by the statement which fired it. *Action: Rewrite the trigger (or function) so it does not read that table. 请问哪里出错了?

在ORACLE上定义触发器,但是似乎无效,求大神解答

在oracle sql developer中定义了一个触发器,记录下每个用户对数据库的表进行数据操纵的次数 首先创建了一个audit_table表(user_name,table_name,del,ins,upd) 在表中插入一个元组:"user1","student",0,0,0; 然后定义了触发器: create or replace trigger audit_student after delete or insert or update on student for each row begin if deleting then update audit_table set del=del+1 where user_name=user and table_name='student'; elsif inserting then update audit_table set ins=ins+1 where user_name=user and table_name='student'; else update audit_table set upd=upd+1 where user_name=user and table_name='student'; end if; end; 接下来我用用户user1对student表进行增删改操作后(已经给user1赋予了对表student的所有权限),查看audit_table表内并无变化 ![图片说明](https://img-ask.csdn.net/upload/201704/19/1492596334_342864.png) ![图片说明](https://img-ask.csdn.net/upload/201704/19/1492596365_194956.png) 想问下,各位大神,这是为什么

触发器阻止INSERT

<div class="post-text" itemprop="text"> <p>I have a html form that send some data in a database. I just created a trigger that on every people that complete the <em>city</em> field with <em>LA</em> will add the word "HI FROM LA" in a column named <em>tag</em>.</p> <p>The problem is that after I created this trigger I get an error when I try to submit a form:</p> <pre><code>#1442 - Can't update table 'users' in stored function/trigger because it is already used by statement which invoked this stored function/trigger. </code></pre> <p>The trigger is:</p> <pre><code>DELIMITER | CREATE TRIGGER update_tag BEFORE INSERT ON users FOR EACH ROW BEGIN IF (NEW.city= 'LA') THEN INSERT INTO users SET NEW.tag = 'HI FROM LA'; END IF; END; | DELIMITER ; </code></pre> <p>The insert is done with:</p> <pre><code>INSERT INTO users(id, name, city) VALUES(23, "John", "LA") </code></pre> <p>What alternatives do I have to avoid this conflict?</p> <p>EDITED TRIGGER:</p> <p>I also created a new table called 'trigger':</p> <pre><code>DELIMITER | CREATE TRIGGER update_tag BEFORE INSERT ON users FOR EACH ROW BEGIN IF (NEW.city= 'LA') THEN INSERT INTO trigger SET NEW.tag = 'HI FROM LA'; END IF; END; | DELIMITER ; </code></pre> <p>With this trigger, I get an error on line 5</p> </div>

在oracle数据库中的触发器怎么可以回滚主事务的操作

我执行下面这段代码之后没有出错,然后更新cusinfo表,想要回滚主事务的操作,但是这里提示说不能再触发器使用rollback(使用子事务也没什么用) create or replace trigger forbid_insert_update_cusinfo --触发器,通过cusinfo表的FILINGMAN或CHARGEMAN列值是否存在于userinfo表中,若存在插入,若不存在就rollback before update or insert of filingman,chargeman on cusinfo for each row declare v_countf number; v_countc number; begin select count(*) into v_countf from userinfo where username=:new.filingman; select count(*) into v_countc from userinfo where username=:new.chargeman; if v_countf=0 then--要注意,这里的判断不能写== rollback; elsif v_countc=0 then rollback; end if; end;

oracle触发器语句找错(变量定义,赋值,条件判断)

[code="sql"] CREATE OR REPLACE TRIGGER "d" AFTER UPDATE ON "USER" REFERENCING OLD AS "USER_BEFORE_UPDATED" NEW AS "USER_AFTER_UPDATED" FOR EACH ROW DECLARE OLD_SERVICE VARCHAR2(20); TIME_D NUMBER; SERVICE_NAME VARCHAR2(20); SERVICE_NAME := 'TERMINATE'; BEGIN --user表的CURRENT_MODE字段被更新为TERMINATE IF :USER_BEFORE_UPDATED.CURRENT_MODE <> :SERVICE_NAME and :USER_AFTER_UPDATED.CURRENT_MODE = :SERVICE_NAME THEN --查询user的service名字 :OLD_SERVICE := select SERVICENAME from SERVICE WHERE USER_ID = :USER_AFTER_UPDATED.USER_ID; --计算当前时间的long型值 :TIME_D := select (sysdate - 8 / 24 - to_date('1970-01-01', 'yyyy-mm-dd')) * 86400000 from dual; --根据以上数据插入info表一条记录 INSERT INTO INFO VALUES ( :TIME_D,:OLD_SERVICE,'N',:USER_AFTER_UPDATED.USER_NAME); END IF; END; [/code] [size=medium]本意是:当更新user表的时候,触发事件:当user表的CURRENT_MODE字段被更新为TERMINATE时,执行code,首先查询user的service,计算当前时间的long型值,根据以上数据插入info表一条记录。 这里有一些错误,大家就当是看伪代码,请大家纠错! :D 这里涉及到的问题有: 1 触发器中如何定义一个变量,然后给他赋一个varchar2的值? 2 如何将sql的查询结果赋值给变量 3 如何在代码块中使用变量 另外希望大家讨论讨论oracle调试命令的好工具[/size]

oracle 修改触发:NEW值怎么是0??

触发器代码: create or replace trigger TR_T_SPILL_LOSS_LIST BEFORE update on t_spill_loss_list for each row declare M_SPILL_TYPE VARCHAR2(30); M_SHOP_ID NUMBER(18); begin M_SPILL_TYPE := ''; M_SHOP_ID := 0; SELECT MAX(SPILL_TYPE), MAX(SHOP_ID) INTO M_SPILL_TYPE, M_SHOP_ID FROM T_SPILL_LOSS WHERE ISDEL = 0 AND SPILL_ID = :NEW.SPILL_ID AND ROWNUM = 1; IF (NVL(:NEW.ISAUDITING, 0) = 1) AND (NVL(:OLD.ISAUDITING, 0) = 0) AND (M_SPILL_TYPE='TYPE_1') THEN INSERT INTO T_STOCK_DETAIL(STOCK_DETAIL_ID, STOCK_DATETIME, STOCK_USER_ID, STAT_ID, SELLER_ID, SKU_ID, STOCK_ID, CHARGE_QTY, CHARGE_QTY2, LIST_ID, STOCK_DETAIL_MODE, ISDEF) VALUES(SQ_STOCK_DETAIL_ID.NEXTVAL, SYSDATE, :NEW.CREATE_USER_ID, M_SHOP_ID, :NEW.SELLER_ID, :NEW.SKU_ID, :NEW.STOCK_ID, :NEW.SPILL_LOSS_QTY, NULL, :NEW.SPILL_LOSS_LIST_ID, 'MODE_BY', 0); ELSIF (NVL(:NEW.ISAUDITING, 0) = 0) AND (NVL(:OLD.ISAUDITING, 0) = 1) AND (M_SPILL_TYPE='TYPE_1') THEN INSERT INTO T_STOCK_DETAIL(STOCK_DETAIL_ID, STOCK_DATETIME, STOCK_USER_ID, STAT_ID, SELLER_ID, SKU_ID, STOCK_ID, CHARGE_QTY, CHARGE_QTY2, LIST_ID, STOCK_DETAIL_MODE, ISDEF) VALUES(SQ_STOCK_DETAIL_ID.NEXTVAL, SYSDATE, :NEW.CREATE_USER_ID, M_SHOP_ID, :NEW.SELLER_ID, :NEW.SKU_ID, :NEW.STOCK_ID, NULL, :NEW.SPILL_LOSS_QTY, :NEW.SPILL_LOSS_LIST_ID, 'MODE_BY', 0); ELSIF (NVL(:NEW.ISAUDITING, 0) = 1) AND (NVL(:OLD.ISAUDITING, 0) = 0) AND (M_SPILL_TYPE='TYPE_2') THEN INSERT INTO T_STOCK_DETAIL(STOCK_DETAIL_ID, STOCK_DATETIME, STOCK_USER_ID, STAT_ID, SELLER_ID, SKU_ID, STOCK_ID, CHARGE_QTY, CHARGE_QTY2, LIST_ID, STOCK_DETAIL_MODE, ISDEF) VALUES(SQ_STOCK_DETAIL_ID.NEXTVAL, SYSDATE, :NEW.CREATE_USER_ID, M_SHOP_ID, :NEW.SELLER_ID, :NEW.SKU_ID, :NEW.STOCK_ID, NULL, :NEW.SPILL_LOSS_QTY, :NEW.SPILL_LOSS_LIST_ID, 'MODE_BS', 0); ELSIF (NVL(:NEW.ISAUDITING, 0) = 0) AND (NVL(:OLD.ISAUDITING, 0) = 1) AND (M_SPILL_TYPE='TYPE_2') THEN INSERT INTO T_STOCK_DETAIL(STOCK_DETAIL_ID, STOCK_DATETIME, STOCK_USER_ID, STAT_ID, SELLER_ID, SKU_ID, STOCK_ID, CHARGE_QTY, CHARGE_QTY2, LIST_ID, STOCK_DETAIL_MODE, ISDEF) VALUES(SQ_STOCK_DETAIL_ID.NEXTVAL, SYSDATE, :NEW.CREATE_USER_ID, M_SHOP_ID, :NEW.SELLER_ID, :NEW.SKU_ID, :NEW.STOCK_ID, :NEW.SPILL_LOSS_QTY, NULL, :NEW.SPILL_LOSS_LIST_ID, 'MODE_BS', 0); END IF; end TR_T_SPILL_LOSS_LIST; 执行触发器代码: UPDATE T_SPILL_LOSS_LIST SET STOCK_ID =6722 , ISAUDITING = 0 WHERE SPILL_LOSS_LIST_ID =13643; 我明明把STOCK_ID修改成6722了,可是:NEW.STOCK_ID还是等于0?

为什么我给表添加了一个insert监听触发器后,在新插入一跳数据的时候,提示未找到任何数据

CREATE OR REPLACE TRIGGER trig_toms_demo AFTER INSERT OR UPDATE OR DELETE ON gxjhxm FOR EACH ROW DECLARE PRAGMA AUTONOMOUS_TRANSACTION; ht_htbh ht.htbh%type; BEGIN IF INSERTING THEN SELECT count(*) INTO ht_htbh FROM gxjyk.ht; END IF; END; 求大神解惑 ``` ```

oracle 10g 触发器

各位大虾,请问oracle 10g的触发器 使用insert 或update事件触发 (insert或update后触发),能否在触发器的代码中取出所insert或update的具体记录,然后使用该记录对其他表进行操作,如果可以,有参考代码希望能给参考一下。谢谢。

oracle 触发器 无效且未通过重新验证

![图片说明](https://img-ask.csdn.net/upload/201612/02/1480667945_232262.png) 求帮看看是什么问题!

hibernate+Oracle 执行save操作的时候没有sequence 不执行insert语句

entity中的主键如下, ![图片说明](https://img-ask.csdn.net/upload/201709/19/1505793821_882566.png) 数据库中目前有触发器(且数据库不能改动) ![图片说明](https://img-ask.csdn.net/upload/201709/19/1505793878_641845.png) 当执行save操作时,ID每次+2 hibernate执行了一次 select queue_seq.nextval from dual 触发器又执行了一次,所以每次+2。 但是如果把entity中的sequence去掉,hibernate执行save操作时,连insert语句都没有,请问这个问题怎么解决。。。

触发器insert同时往另外一个表插数据

create or replace trigger tab_order_app_status before update of status on TAB_ORDER_APP for each row declare -- local variables here begin if nvl(:new.status, 0) = 1 and nvl(:old.status, 0) = 0 and nvl(:new.FENDAN_TYPE, 0) = 0 then insert into TAB_ORDER_FENDAN_TMP (guid, Order_Id, Send_Man_Province, Send_Man_City, SEND_MAN_AREA, SEND_MAN_ADDRESS_DETAIL, ACCEPT_COMPANY) values (sys_guid(), :new.order_id, :new.send_man_province, :new.send_man_city, :new.send_man_area, :new.send_man_address_detail, :new.accept_company); end if; end tab_order_app_status; 怎么在这个触发器里面加一个当tab_order_appb表插入数据的同时往Tmp表插入一条数据呢

如何创建一个触发器,当A表中数据发生变化,更新B 表中数据?

###需求:我现在需要创建一个触发器,进行数据更新,具体要求如下: 现有数据表TEST1、TEST2两个数据表,表中字段若干, 两表关联字段为TEST1.A=TEST2.A。 表TEST1中 B 字段原先有数据, C字段是没有数据的。 我现在想写一个触发器,当字段 TEST1.C 中INSERT 数据后,将表TEST2中的TEST.B字段 UPDATE为‘DX13’。 ###针对上面的问题我应当怎么写触发器,本人接触数据库时间不长,对这些问题还有些不明白。

sql使用触发器当一张表插入数据就往另一张表插入数据

日期格式是这样的![图片说明](https://img-ask.csdn.net/upload/201601/04/1451903124_358717.png)但是使用触发器当上图插入了一条数据就往下图插入相同的数据,如下图![图片说明](https://img-ask.csdn.net/upload/201601/04/1451903138_769728.png)为什么日期格式不一样呢?

触发器 批量插入后,更新表中的一个字段,值是根据表中某些字段的值拼接的一个字符串

--创建触发器 Alter trigger tbytzc_insert on t_ysk_ytzcmb after insert --插入之后触发 as --定义变量 declare @ytxh varchar(15),@px varchar(20),@cx varchar(250),@fdj varchar(80),@qd varchar(80),@pf varchar(80),@xsbsc varchar(80), @jxsdm varchar(1000),@tbytsql varchar(3000),@jznd varchar(4),@cx_count int,@cx_join varchar(300),@fdj_join varchar(300),@qd_join varchar(300),@pd_join varchar(300),@xsbsc_join varchar(300),@jxsdm_join varchar(600); --在inserted表中查询已经插入记录信息 select @px = 品系,@cx = 车型,@fdj = 发动机,@qd = 驱动,@pf = 排放,@xsbsc = 销售办事处, @jxsdm = 经销商代码,@jznd=jznd,@ytxh=预提序号 from inserted; set @tbytsql = 'a.品系部='''+@px+''''; if(isnull(@cx,'')<>'' )--车型 begin set @tbytsql = @tbytsql +' and '; set @cx_join = REPLACE (@cx,'、','%'' or a.车型 like ''%') set @cx_join = '(a.车型 like ''%'+@cx_join+'%'')'; set @tbytsql = @tbytsql +@cx_join; if(isnull(@fdj,'')<>'' )--发动机 begin set @tbytsql = @tbytsql +' and '; set @fdj_join = REPLACE (@fdj,'、','%'' or a.发动机 like ''%') set @fdj_join = '(a.发动机 like ''%'+@fdj_join+'%'')'; set @tbytsql = @tbytsql +@fdj_join; if(isnull(@qd,'')<>'' )--驱动 begin set @tbytsql = @tbytsql +' and '; set @qd_join = REPLACE (@qd,'、','%'' or a.驱动 like ''%') set @qd_join = '(a.驱动 like ''%'+@qd_join+'%'')'; set @tbytsql = @tbytsql +@qd_join; if(isnull(@pf,'')<>'' )--排放 begin set @tbytsql = @tbytsql +' and '; set @pd_join = REPLACE (@pf,'、','%'' or a.排放 like ''%') set @pd_join = '(a.排放 like ''%'+@pd_join+'%'')'; set @tbytsql = @tbytsql +@pd_join; if(isnull(@xsbsc,'')<>'' )--销售办事处 begin set @tbytsql = @tbytsql +' and '; set @xsbsc_join = REPLACE (@xsbsc,'、','%'' or upper(a.销售办事处) like ''%') set @xsbsc_join = '(upper(a.销售办事处) like ''%'+@xsbsc_join+'%'')'; set @tbytsql = @tbytsql +@xsbsc_join; if(isnull(@jxsdm,'')<>'' )--付款方 begin set @tbytsql = @tbytsql +' and '; set @jxsdm_join = REPLACE (@jxsdm,'、','%'' or upper(a.付款方) like ''%') set @jxsdm_join = '(upper(a.付款方) like ''%'+@jxsdm_join+'%'')'; set @tbytsql = @tbytsql +@jxsdm_join; end end end end end end --更新数据: update t_ysk_ytzcmb set tbytsql=@tbytsql where jznd=@jznd and 预提序号=@ytxh; go

SpringMVC里如何实现不同用户的请求关键

各位大神,我在做一个网上商城的项目,目前遇到的瓶颈是:买家修改订单之后,如何主动通知卖家有订单变化? 实现过程中一开始希望在买家的控制器调用DAO的时候直接通过request或者session去获取卖家的响应连接,就能轻松通知卖家,但是request和session是单用户的,似乎是没办法去获取其他用户的请求的或者响应连接。 另一种想法是在oracle数据库里对订单表创建相关的触发器例如这样的触发器: CREATE OR REPLACE TRIGGER traigger_order AFTER INSERT OR UPDATE OF order_state ON torder BEGIN NULL; END; 这里针对torder表创建了一个监听order_state列的插入和更新的触发器trigger_order,但是问题是数据库在监听到触发器被触发后怎么样去告知java,java又怎么样去定向到卖家的response? 以上两个方法感觉都很难实现,是不是我的想法有问题还是没有捉住重点?这样的需求应该如何去实现?新手轻拍。。。

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

搜狗输入法也在挑战国人的智商!

故事总是一个接着一个到来...上周写完《鲁大师已经彻底沦为一款垃圾流氓软件!》这篇文章之后,鲁大师的市场工作人员就找到了我,希望把这篇文章删除掉。经过一番沟通我先把这篇文章从公号中删除了...

总结了 150 余个神奇网站,你不来瞅瞅吗?

原博客再更新,可能就没了,之后将持续更新本篇博客。

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发(16k)

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

《Oracle Java SE编程自学与面试指南》最佳学习路线图2020年最新版(进大厂必备)

正确选择比瞎努力更重要!

《Oracle Java SE编程自学与面试指南》最佳学习路线图(2020最新版)

正确选择比瞎努力更重要!

都前后端分离了,咱就别做页面跳转了!统统 JSON 交互

文章目录1. 无状态登录1.1 什么是有状态1.2 什么是无状态1.3 如何实现无状态1.4 各自优缺点2. 登录交互2.1 前后端分离的数据交互2.2 登录成功2.3 登录失败3. 未认证处理方案4. 注销登录 这是本系列的第四篇,有小伙伴找不到之前文章,松哥给大家列一个索引出来: 挖一个大坑,Spring Security 开搞! 松哥手把手带你入门 Spring Security,别再问密...

字节跳动面试官竟然问了我JDBC?

轻松等回家通知

面试官:你连SSO都不懂,就别来面试了

大厂竟然要考我SSO,卧槽。

阿里面试官让我用Zk(Zookeeper)实现分布式锁

他可能没想到,我当场手写出来了

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

2020春招面试了10多家大厂,我把问烂了的数据库事务知识点总结了一下

2020年截止目前,我面试了阿里巴巴、腾讯、美团、拼多多、京东、快手等互联网大厂。我发现数据库事务在面试中出现的次数非常多。

爬虫(101)爬点重口味的

小弟最近在学校无聊的很哪,浏览网页突然看到一张图片,都快流鼻血。。。然后小弟冥思苦想,得干一点有趣的事情python 爬虫库安装https://s.taobao.com/api?_ks...

立即提问
相关内容推荐