risingwave_meta_model/
streaming_job.rs1use sea_orm::entity::prelude::*;
16use serde::{Deserialize, Serialize};
17
18use crate::{CreateType, JobStatus, StreamingParallelism};
19
20#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Serialize, Deserialize)]
21#[sea_orm(table_name = "streaming_job")]
22pub struct Model {
23 #[sea_orm(primary_key, auto_increment = false)]
24 pub job_id: i32,
25 pub job_status: JobStatus,
26 pub create_type: CreateType,
27 pub timezone: Option<String>,
28 pub parallelism: StreamingParallelism,
29 pub max_parallelism: i32,
30 pub specific_resource_group: Option<String>,
31}
32
33#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
34pub enum Relation {
35 #[sea_orm(
36 belongs_to = "super::object::Entity",
37 from = "Column::JobId",
38 to = "super::object::Column::Oid",
39 on_update = "NoAction",
40 on_delete = "Cascade"
41 )]
42 Object,
43}
44
45impl Related<super::object::Entity> for Entity {
46 fn to() -> RelationDef {
47 Relation::Object.def()
48 }
49}
50
51impl ActiveModelBehavior for ActiveModel {}