diff options
author | pixel <pixel> | 2007-04-12 18:20:01 +0000 |
---|---|---|
committer | pixel <pixel> | 2007-04-12 18:20:01 +0000 |
commit | 1fdd95292cdf7f58109cc3fc5ab5ead2288f1bfc (patch) | |
tree | f0b07a17373642e1324c032b70a67fcb88d9dae6 | |
parent | 753b838216316509ba5069ce44214630042bd33d (diff) |
'query' now returns an error code instead of throwing an exception.
-rw-r--r-- | include/SQL.h | 2 | ||||
-rw-r--r-- | lib/SQL.cc | 10 |
2 files changed, 8 insertions, 4 deletions
diff --git a/include/SQL.h b/include/SQL.h index fa1a163..4d794d5 100644 --- a/include/SQL.h +++ b/include/SQL.h @@ -11,7 +11,7 @@ class SQLConnection : public Base { public: SQLConnection(String host, String user, String passwd, String db, int port = 3306, String socket = "", unsigned long clags = 0) throw (GeneralException); ~SQLConnection(); - void query(String) throw (GeneralException); + int query(String); int numrows(); int numfields(); AssocArray fetchrow(); @@ -29,15 +29,17 @@ SQLConnection::~SQLConnection() { mysql_close(&con); } -void SQLConnection::query(String q) throw(GeneralException) { +int SQLConnection::query(String q) { + int r; + if (res) { mysql_free_result(res); } res = 0; - if (mysql_real_query(&con, ((ugly_string)q).p, q.strlen())) { - throw GeneralException(String("Couldn't run query ") + q); + if ((r = mysql_real_query(&con, ((ugly_string)q).p, q.strlen()))) { + return r; } res = mysql_store_result(&con); @@ -55,6 +57,8 @@ void SQLConnection::query(String q) throw(GeneralException) { na = 0; ii = -1; } + + return r; } int SQLConnection::numrows() { |