Crates.io | gchdb |
lib.rs | gchdb |
version | 0.2.8 |
source | src |
created_at | 2020-05-21 14:20:15.585949 |
updated_at | 2022-05-28 08:43:07.882579 |
description | Provides a record abstraction for storing chat records extracted by different chat software, and provides full-text search feature |
homepage | |
repository | https://github.com/darkskygit/GCHDB |
max_upload_size | |
id | 244112 |
size | 69,735 |
This crate provides chat record abstraction, used to store chat records extracted from different chat software, and integrated Chinese full-text index.
fn main() -> ChatRecordResult<()> {
// create an records database
let mut recoder = SqliteChatRecorder::new("record.db")?;
// create record, you can extract some record from other im's database
let record = Record {
chat_type: "testaasdavxz".into(),
owner_id: "asdasdasdaaaa".into(),
group_id: "asdasdasd".into(),
sender: "人民日报".into(),
content:
"张华考上了北京大学;李萍进了中等技术学校;我在百货公司当售货员:我们都有光明的前途"
.into(),
timestamp: chrono::Local::now().naive_utc().timestamp_millis(),
..Default::default()
};
// insert to database
assert_eq!(recoder.insert_or_update_record(&record)?, true);
// index the contents of the record
recoder.refresh_index()?;
// query record by sql
println!(
"{:?}",
recoder.get_record(Query {
chat_type: Some("testaasdavxz".into()),
sender: Some("%日报".into()),
..Default::default()
})?
);
// query record by indexer
println!(
"{:?}",
recoder.get_record(Query {
keyword: Some("技术学校".into()),
..Default::default()
})?
);
// remove record in database
assert_eq!(recoder.remove_record(record)?, true);
Ok(())
}
Welcome pull request :)
AGPL3.0