From f8fec23264acd576860509d6cf68d49b23330fc3 Mon Sep 17 00:00:00 2001 From: Teddy Wing Date: Thu, 10 Mar 2022 00:02:40 +0100 Subject: Start encoding SQLite affinity rules Need to figure out what to do for NUMERIC affinity since Rusqlite doesn't expose a variant for that pseudo-type. --- src/lib.rs | 2 +- src/main.rs | 11 +++++++---- src/sqlite.rs | 25 +++++++++++++++++++++++++ 3 files changed, 33 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/lib.rs b/src/lib.rs index 8e0367d..6b1c108 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1 +1 @@ -mod sqlite; +pub mod sqlite; diff --git a/src/main.rs b/src/main.rs index d289b01..e064baa 100644 --- a/src/main.rs +++ b/src/main.rs @@ -31,7 +31,7 @@ fn main() { fn yaml_extract( doc: &yaml::Yaml, tx: &rusqlite::Transaction, - table_columns: &HashMap, + table_columns: &HashMap, ) { match doc { yaml::Yaml::Array(ref array) => { @@ -71,7 +71,7 @@ struct Zero {} use std::collections::HashMap; -fn get_column_names(dbconn: &rusqlite::Connection) -> HashMap { +fn get_column_names(dbconn: &rusqlite::Connection) -> HashMap { let mut column_names = HashMap::new(); let mut stmt = dbconn.prepare(r#" @@ -103,8 +103,11 @@ fn get_column_names(dbconn: &rusqlite::Connection) -> HashMap { let row = row_result.unwrap(); - // TODO: Translate to rusqlite::types::Type. - column_names.insert(row.0, row.1); + let type_name: String = row.1; + + let type_affinity = yaqlite::sqlite::affinity(&type_name); + + column_names.insert(row.0, type_affinity); } column_names diff --git a/src/sqlite.rs b/src/sqlite.rs index 10dbb61..8094398 100644 --- a/src/sqlite.rs +++ b/src/sqlite.rs @@ -6,4 +6,29 @@ use rusqlite; /// Use the SQLite rules for type affinity described in: /// https://sqlite.org/datatype3.html#determination_of_column_affinity pub fn affinity(type_name: &str) -> rusqlite::types::Type { + use rusqlite::types::Type; + + let type_name = type_name.to_uppercase(); + + if type_name.contains("INT") { + return Type::Integer; + } else if type_name.contains("CHAR") + || type_name.contains("CLOB") + || type_name.contains("TEXT") + { + return Type::Text; + } else if type_name.contains("BLOB") + || type_name.is_empty() + { + return Type::Blob; + } else if type_name.contains("REAL") + || type_name.contains("FLOA") + || type_name.contains("DOUB") + { + return Type::Real; + } + + // TODO: Numeric affinity + + Type::Text } -- cgit v1.2.3