SQLite触发器更新摘要计数

jrh*_*cks 3 sqlite

考虑以下两个(假设的)表

温度

* day
* time
* lake_name
* station
* temperature_f
Run Code Online (Sandbox Code Playgroud)

Temperature_summary

* day
* lake_name
* station
* count_readings_over_75f
* count_readings_below_75f
Run Code Online (Sandbox Code Playgroud)

如何编写SQLite Trigger来更新insert上的temperature_summary表.我想增加点数.

谢谢,杰夫

Dou*_*rie 6

假设您在当天插入温度之前已经创建了day/lake_name/station的记录.当然,你可以添加另一个触发器来做到这一点.

create trigger Temperature_count_insert_trigger_hi after insert on Temperature
  when new.temperature_f >= 75
  begin
    update Temperature_summary set count_readings_over_75f = count_readings_over_75f + 1
    where new.day = day and new.lake_name = lake_name and new.station = station;
  end;

create trigger Temperature_count_insert_trigger_lo after insert on Temperature
  when new.temperature_f < 75
  begin
    update Temperature_summary set count_readings_below_75f = count_readings_below_75f + 1
    where new.day = day and new.lake_name = lake_name and new.station = station;
  end;
Run Code Online (Sandbox Code Playgroud)

您可以将这些组合成一个稍微复杂的触发器

create trigger Temperature_count_insert_trigger after insert on Temperature
  begin
    update Temperature_summary
    set count_readings_below_75f = count_readings_below_75f + (new.temperature_f < 75),
      count_readings_over_75f = count_readings_over_75f + (new.temperature_f >= 75)
    where new.day = day and new.lake_name = lake_name and new.station = station;
  end;
Run Code Online (Sandbox Code Playgroud)

要确保Temperature_summary中有一行要更新(a)在Temperature_summary上创建一个唯一索引(day, lake_name, station),或者将这些列作为主键,并且(b)在触发器中执行插入或忽略,如下所示:

create trigger Temperature_count_insert_trigger after insert on Temperature
  begin
    insert or ignore into Temperature_summary
      values (new.day, new.lake_name, new.station, 0, 0);
    update Temperature_summary
    set count_readings_below_75f = count_readings_below_75f + (new.temperature_f < 75),
      count_readings_over_75f = count_readings_over_75f + (new.temperature_f >= 75)
    where new.day = day and new.lake_name = lake_name and new.station = station;
  end;
Run Code Online (Sandbox Code Playgroud)