allow converting from DateTime2 to Datetimen in 'tds73'#298
Open
Geo-W wants to merge 2 commits intoprisma:mainfrom
Open
allow converting from DateTime2 to Datetimen in 'tds73'#298Geo-W wants to merge 2 commits intoprisma:mainfrom
Geo-W wants to merge 2 commits intoprisma:mainfrom
Conversation
|
I'm seeing a similar issue, but with a regular As a workaround, I've copied/modified the legacy It's a little extra work, but it prevents a mandatory conversion to pub fn naive_dt_to_datetime1<'a>(dt: NaiveDateTime) -> ColumnData<'a> {
fn to_days(date: NaiveDate, start_year: i32) -> i64 {
(date - NaiveDate::from_ymd_opt(start_year, 1, 1).unwrap()).num_days()
}
fn to_sec_fragments(from: NaiveTime) -> i64 {
let nanos: i64 = (from - NaiveTime::from_hms_opt(0, 0, 0).unwrap())
.num_nanoseconds()
.unwrap();
nanos * 300 / (1e9 as i64)
}
let date = dt.date();
let time = dt.time();
let days = to_days(date, 1900) as i32;
let seconds_fragments = to_sec_fragments(time);
let dt = tiberius::time::DateTime::new(days, seconds_fragments as u32);
ColumnData::DateTime(Some(dt))
}For some example usage: /// Convert my domain object into a row usable by bulk insert
impl<'a> IntoRow<'a> for EventRow {
fn into_row(self) -> TokenRow<'a> {
let mut row = TokenRow::new();
row.push(naive_dt_to_datetime1(self.timestamp.naive_utc()));
row.push(self.event_id.into_sql());
row
}
}
/// Perform bulk insert
async fn do_inserts(db: &Client, events: &Vec<EventRow>) -> anyhow::Result<()>{
let mut bulk = db.bulk_insert("TABLE_NAME").await?;
for evt in events {
let row = evt.into_row();
bulk.send(row).await?;
}
_ = bulk.finalize().await?;
Ok(())
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This pr tries to address the following problem:
When inserting
NaiveDateTimeinto msdatetimecolumns withbulk_insertandtds73is turned on by default, it would raiseErr` value: BulkInput("invalid data type, expecting Some(VarLenSized(VarLenContext { type: Datetimen, len: 8, collation: None })) but found DateTime2(Some(DateTime2 { date: Date(693604), time: Time { increments: 330110000000, scale: 7 } }))cannot just disable
tds73feature asdate/timemight in the same table withdatetimesimultaneously andinto_sql/to_sqlis impl fordate/timein withouttds73only.normal inserting with
executedoes not get this issue as it callsDateTime2toNonewhen converting.tiberius/src/tds/codec/column_data.rs
Lines 615 to 619 in 98943b2
Don't know whether it is a good solution. Or maybe any other impl can solve this issue is appreciated.
Thank you so much~