fix: 修复重构引入的若干 bug (#126)

This commit is contained in:
ᴀᴍᴛᴏᴀᴇʀ
2024-07-04 01:00:41 +08:00
committed by GitHub
parent 940abd4f3b
commit ff1150e863
4 changed files with 10 additions and 24 deletions

View File

@@ -12,8 +12,9 @@ impl VideoInfo {
Some(base_model) => base_model.into_active_model(),
None => {
let mut tmp_model = bili_sync_entity::video::Model::default().into_active_model();
// 注意此处要把 id 设置 NotSet否则 id 会是 Unchanged(0)
// 注意此处要把 id 和 created_at 设置 NotSet方便在 sql 中忽略这些字段,交由数据库自动生成
tmp_model.id = NotSet;
tmp_model.created_at = NotSet;
tmp_model
}
};

View File

@@ -4,7 +4,7 @@ use bili_sync_migration::OnConflict;
use sea_orm::entity::prelude::*;
use sea_orm::ActiveValue::Set;
use crate::adapter::{unique_video_columns, VideoListModel};
use crate::adapter::VideoListModel;
use crate::bilibili::{PageInfo, VideoInfo};
/// 尝试创建 Video Model如果发生冲突则忽略
@@ -18,7 +18,8 @@ pub async fn create_videos(
.map(|v| video_list_model.video_model_by_info(v, None))
.collect::<Vec<_>>();
video::Entity::insert_many(video_models)
.on_conflict(OnConflict::columns(unique_video_columns()).do_nothing().to_owned())
// 这里想表达的是 on 索引名,但 sea-orm 的 api 似乎只支持列名而不支持索引名,好在留空可以达到相同的目的
.on_conflict(OnConflict::new().do_nothing().to_owned())
.do_nothing()
.exec(connection)
.await?;