dongyi4420 2015-08-22 15:46
浏览 28

如何在通过触发器存储投票之前检查用户信誉的数量

I have two tables. Posts, Votes. I have a column in the Posts table named total_votes. Also I have a trigger for updating it when user gives a vote to the post.

Here is my trigger:

delimiter //
CREATE TRIGGER total_votes AFTER INSERT ON Votes
 FOR EACH ROW begin 
   update posts set total_votes = total_votes+new.value
   where  post.id = new.post_id; 
end //

So I need to check the number of user reputation, that If they are more than 50, then the vote stores, else, the vote not store. how can I do that ?

Actually I can write this: BEFORE INSERT

If ((select reputation from users where id = new.user_id) < 50) then
  SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'your rep are low';
end if;

Now I have two problem, One: how can I use of that error (your rep are low) in my website ? (via php), and two: How can I deactivate total_votes trigger (AFTER INSERT) if the above condition was true ?

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
    • ¥15 ETLCloud 处理json多层级问题
    • ¥15 matlab中使用gurobi时报错
    • ¥15 这个主板怎么能扩出一两个sata口
    • ¥15 不是,这到底错哪儿了😭
    • ¥15 2020长安杯与连接网探
    • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
    • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
    • ¥15 可见光定位matlab仿真
    • ¥15 arduino 四自由度机械臂