[glom] Find: Use backend-specific LIKE or ILIKE operator instead of =.
- From: Murray Cumming <murrayc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glom] Find: Use backend-specific LIKE or ILIKE operator instead of =.
- Date: Thu, 23 Jun 2011 19:17:45 +0000 (UTC)
commit 14b52a7116a689c1982dfa21a10420ba19cfafe0
Author: Murray Cumming <murrayc murrayc com>
Date: Thu Jun 23 21:17:33 2011 +0200
Find: Use backend-specific LIKE or ILIKE operator instead of =.
* glom/libglom/connectionpool.[h|cc]:
* glom/libglom/connectionpool_backends/backend.h:
* glom/libglom/connectionpool_backends/postgres.h:
* glom/libglom/connectionpool_backends/sqlite.h:
get_string_find_operator(): Return the Gnome::Gda operator enum
instead of the operator as a string.
* glom/libglom/data_structure/field.[h|cc]: sql_find_operator():
Likewise, return the Gnome::Gda operator enum.
* glom/libglom/utils.cc: get_find_where_clause_quick():
* glom/mode_data/box_data.cc: get_find_where_clause():
Use Field::sql_find_operator() and Field::sql_find(), as per
the TODO comments.
This was code that I forgot to change properly when porting to
use Gnome::Gda::SqlBuilder, so this has been broken since
Glom 1.16.
Find still does not work.
ChangeLog | 22 ++++++++++++++++
glom/frame_glom.cc | 2 +-
glom/libglom/connectionpool.cc | 2 +-
glom/libglom/connectionpool.h | 2 +-
glom/libglom/connectionpool_backends/backend.h | 2 +-
glom/libglom/connectionpool_backends/postgres.h | 2 +-
glom/libglom/connectionpool_backends/sqlite.h | 2 +-
glom/libglom/data_structure/field.cc | 6 ++--
glom/libglom/data_structure/field.h | 2 +-
glom/libglom/utils.cc | 31 ++++++++++++++---------
glom/mode_data/box_data.cc | 6 ++--
11 files changed, 54 insertions(+), 25 deletions(-)
---
diff --git a/ChangeLog b/ChangeLog
index c416edb..04e7882 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,27 @@
2011-06-23 Murray Cumming <murrayc murrayc com>
+ Find: Use backend-specific LIKE or ILIKE operator instead of =.
+
+ * glom/libglom/connectionpool.[h|cc]:
+ * glom/libglom/connectionpool_backends/backend.h:
+ * glom/libglom/connectionpool_backends/postgres.h:
+ * glom/libglom/connectionpool_backends/sqlite.h:
+ get_string_find_operator(): Return the Gnome::Gda operator enum
+ instead of the operator as a string.
+ * glom/libglom/data_structure/field.[h|cc]: sql_find_operator():
+ Likewise, return the Gnome::Gda operator enum.
+ * glom/libglom/utils.cc: get_find_where_clause_quick():
+ * glom/mode_data/box_data.cc: get_find_where_clause():
+ Use Field::sql_find_operator() and Field::sql_find(), as per
+ the TODO comments.
+
+ This was code that I forgot to change properly when porting to
+ use Gnome::Gda::SqlBuilder, so this has been broken since
+ Glom 1.16.
+ Find still does not work.
+
+2011-06-23 Murray Cumming <murrayc murrayc com>
+
Frame: Rename a signal handler.
* glom/frame_glom.[h|cc]: Rename on_menu_Mode_Toggle() to
diff --git a/glom/frame_glom.cc b/glom/frame_glom.cc
index e292188..ce70839 100644
--- a/glom/frame_glom.cc
+++ b/glom/frame_glom.cc
@@ -1387,7 +1387,7 @@ void Frame_Glom::on_button_quickfind()
else
{
const Gnome::Gda::SqlExpr where_clause = Utils::get_find_where_clause_quick(get_document(), m_table_name, Gnome::Gda::Value(criteria));
- //std::cout << "debug: " << G_STRFUNC << ": where_clause=" << where_clause << std::endl;
+ //std::cout << "debug: " << G_STRFUNC << ": where_clause=" << where_clause.serialize() << std::endl;
on_notebook_find_criteria(where_clause);
}
}
diff --git a/glom/libglom/connectionpool.cc b/glom/libglom/connectionpool.cc
index c836ff4..b6cdf2a 100644
--- a/glom/libglom/connectionpool.cc
+++ b/glom/libglom/connectionpool.cc
@@ -467,7 +467,7 @@ const FieldTypes* ConnectionPool::get_field_types() const
return m_pFieldTypes;
}
-Glib::ustring ConnectionPool::get_string_find_operator() const
+Gnome::Gda::SqlOperatorType ConnectionPool::get_string_find_operator() const
{
g_assert(m_backend.get());
return m_backend->get_string_find_operator();
diff --git a/glom/libglom/connectionpool.h b/glom/libglom/connectionpool.h
index 6f64de0..5a6f8cc 100644
--- a/glom/libglom/connectionpool.h
+++ b/glom/libglom/connectionpool.h
@@ -179,7 +179,7 @@ public:
Field::sql_format get_sql_format() const;
const FieldTypes* get_field_types() const;
- Glib::ustring get_string_find_operator() const;
+ Gnome::Gda::SqlOperatorType get_string_find_operator() const;
typedef Backend::InitErrors InitErrors;
diff --git a/glom/libglom/connectionpool_backends/backend.h b/glom/libglom/connectionpool_backends/backend.h
index 8297a5b..5ef1421 100644
--- a/glom/libglom/connectionpool_backends/backend.h
+++ b/glom/libglom/connectionpool_backends/backend.h
@@ -105,7 +105,7 @@ protected:
* TODO: Maybe we can use libgda to construct the expression, so we don't
* need this function.
*/
- virtual Glib::ustring get_string_find_operator() const = 0;
+ virtual Gnome::Gda::SqlOperatorType get_string_find_operator() const = 0;
/** This specifies the database schema which contains the non-internal
* tables. This is used to speedup the libgda meta store update by only
diff --git a/glom/libglom/connectionpool_backends/postgres.h b/glom/libglom/connectionpool_backends/postgres.h
index cf80638..a947770 100644
--- a/glom/libglom/connectionpool_backends/postgres.h
+++ b/glom/libglom/connectionpool_backends/postgres.h
@@ -58,7 +58,7 @@ public:
private:
virtual Field::sql_format get_sql_format() const { return Field::SQL_FORMAT_POSTGRES; }
virtual bool supports_remote_access() const { return true; }
- virtual Glib::ustring get_string_find_operator() const { return "ILIKE"; } // ILIKE is a postgres extension for locale-dependent case-insensitive matches.
+ virtual Gnome::Gda::SqlOperatorType get_string_find_operator() const { return Gnome::Gda::SQL_OPERATOR_TYPE_LIKE; } //TODO: Use ILIKE ILIKE is a postgres extension for locale-dependent case-insensitive matches.
virtual const char* get_public_schema_name() const { return "public"; }
virtual bool change_columns(const Glib::RefPtr<Gnome::Gda::Connection>& connection, const Glib::ustring& table_name, const type_vec_const_fields& old_fields, const type_vec_const_fields& new_fields) throw();
diff --git a/glom/libglom/connectionpool_backends/sqlite.h b/glom/libglom/connectionpool_backends/sqlite.h
index 03b34a2..b963c23 100644
--- a/glom/libglom/connectionpool_backends/sqlite.h
+++ b/glom/libglom/connectionpool_backends/sqlite.h
@@ -40,7 +40,7 @@ public:
private:
virtual Field::sql_format get_sql_format() const { return Field::SQL_FORMAT_SQLITE; }
virtual bool supports_remote_access() const { return false; }
- virtual Glib::ustring get_string_find_operator() const { return "LIKE"; }
+ virtual Gnome::Gda::SqlOperatorType get_string_find_operator() const { return Gnome::Gda::SQL_OPERATOR_TYPE_LIKE; }
virtual const char* get_public_schema_name() const { return "main"; }
bool add_column_to_server_operation(const Glib::RefPtr<Gnome::Gda::ServerOperation>& operation, GdaMetaTableColumn* column, unsigned int i);
diff --git a/glom/libglom/data_structure/field.cc b/glom/libglom/data_structure/field.cc
index 122be6b..cdb0525 100644
--- a/glom/libglom/data_structure/field.cc
+++ b/glom/libglom/data_structure/field.cc
@@ -391,7 +391,7 @@ Glib::ustring Field::sql_find(const Gnome::Gda::Value& value) const
}
}
-Glib::ustring Field::sql_find_operator() const
+Gnome::Gda::SqlOperatorType Field::sql_find_operator() const
{
switch(get_glom_type())
{
@@ -401,7 +401,7 @@ Glib::ustring Field::sql_find_operator() const
if(connection_pool && connection_pool->get_backend())
return connection_pool->get_string_find_operator();
else
- return "LIKE"; // Default
+ return Gnome::Gda::SQL_OPERATOR_TYPE_LIKE; // Default
break;
}
case(TYPE_DATE):
@@ -410,7 +410,7 @@ Glib::ustring Field::sql_find_operator() const
case(TYPE_BOOLEAN):
default:
{
- return "=";
+ return Gnome::Gda::SQL_OPERATOR_TYPE_EQ;
break;
}
}
diff --git a/glom/libglom/data_structure/field.h b/glom/libglom/data_structure/field.h
index bcda5c8..4878464 100644
--- a/glom/libglom/data_structure/field.h
+++ b/glom/libglom/data_structure/field.h
@@ -198,7 +198,7 @@ public:
/** Get a suitable operator to use when finding records.
* For instance, == for numbers, or LIKE for text.
*/
- Glib::ustring sql_find_operator() const;
+ Gnome::Gda::SqlOperatorType sql_find_operator() const;
Glib::ustring get_calculation() const;
void set_calculation(const Glib::ustring& calculation);
diff --git a/glom/libglom/utils.cc b/glom/libglom/utils.cc
index 03a5ac8..52a37c1 100644
--- a/glom/libglom/utils.cc
+++ b/glom/libglom/utils.cc
@@ -1044,6 +1044,10 @@ Gnome::Gda::SqlExpr Utils::get_find_where_clause_quick(const Document* document,
Gnome::Gda::SqlBuilder::create(Gnome::Gda::SQL_STATEMENT_SELECT);
builder->select_add_target(table_name);
+ //We need to add some fields to select,
+ //because otherwise the SqlBuilder would not contain a valid query.
+ builder->select_add_field("*", table_name);
+
if(!document)
{
std::cerr << G_STRFUNC << ": document was null." << std::endl;
@@ -1053,7 +1057,7 @@ Gnome::Gda::SqlExpr Utils::get_find_where_clause_quick(const Document* document,
//TODO: Cache the list of all fields, as well as caching (m_Fields) the list of all visible fields:
const Document::type_vec_fields fields = document->get_table_fields(table_name);
- guint previous_and_id = 0;
+ guint previous_id = 0;
typedef std::vector< sharedptr<LayoutItem_Field> > type_vecLayoutFields;
type_vecLayoutFields fieldsToGet;
for(Document::type_vec_fields::const_iterator iter = fields.begin(); iter != fields.end(); ++iter)
@@ -1070,28 +1074,31 @@ Gnome::Gda::SqlExpr Utils::get_find_where_clause_quick(const Document* document,
if(use_this_field)
{
- const guint eq_id = builder->add_cond(Gnome::Gda::SQL_OPERATOR_TYPE_EQ, //TODO: Ue field->sql_find_operator().
+ //std::cout << "Using field: " << field->get_name() << std::endl;
+ const guint eq_id = builder->add_cond(field->sql_find_operator(),
builder->add_field_id(field->get_name(), table_name),
- builder->add_expr(quick_search)); //Use field->sql_find(quick_search);
+ builder->add_expr( field->sql_find(quick_search) )); //sql_find() modifies the value for the operator.
- guint and_id = 0;
- if(previous_and_id)
+ if(previous_id)
{
- and_id = builder->add_cond(Gnome::Gda::SQL_OPERATOR_TYPE_AND,
- previous_and_id, eq_id);
+ const guint or_id = builder->add_cond(Gnome::Gda::SQL_OPERATOR_TYPE_OR,
+ previous_id, eq_id);
+ previous_id = or_id;
}
-
- previous_and_id = and_id;
+ else
+ previous_id = eq_id;
}
}
- if(previous_and_id)
+ if(previous_id)
{
- builder->set_where(previous_and_id); //This might be unnecessary.
- return builder->export_expression(previous_and_id);
+ builder->set_where(previous_id); //This might be unnecessary.
+ //std::cout << G_STRFUNC << ": builder: " << sqlbuilder_get_full_query(builder) << std::endl;
+ return builder->export_expression(previous_id);
}
else
{
+ std::cerr << G_STRFUNC << ": Returning null SqlExpr" << std::endl;
return Gnome::Gda::SqlExpr();
}
}
diff --git a/glom/mode_data/box_data.cc b/glom/mode_data/box_data.cc
index 6e39aaa..6800ffd 100644
--- a/glom/mode_data/box_data.cc
+++ b/glom/mode_data/box_data.cc
@@ -112,14 +112,14 @@ Gnome::Gda::SqlExpr Box_Data::get_find_where_clause() const
if(use_this_field)
{
- const guint cond_id = builder->add_cond(Gnome::Gda::SQL_OPERATOR_TYPE_EQ, //TODO: Use field->sql_find_operator()
+ const guint cond_id = builder->add_cond(field->sql_find_operator(),
builder->add_field_id(field->get_name(), m_table_name),
- builder->add_expr(data));
+ builder->add_expr( field->sql_find(data) ));
//And with previous condition, if any:
if(where_cond_id)
{
- where_cond_id = builder->add_cond(Gnome::Gda::SQL_OPERATOR_TYPE_AND, //TODO: Use field->sql_find_operator()
+ where_cond_id = builder->add_cond(Gnome::Gda::SQL_OPERATOR_TYPE_AND,
where_cond_id,
cond_id);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]