4 / 4 / 0
Регистрация: 13.10.2013
Сообщений: 171
1

Странности с неразрешёнными файлами include (Kubuntu, NetBeans)

22.11.2014, 18:05. Показов 2315. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет.

Буквально несколько дней назад я начал осваивать C++.
Мне захотелось попробовать из готовых примеров создать демон, который я ранее написал на PHP.

Назначение демона - соединение раз в секунду с базой данных, проверка значений в определённых таблицах и в зависимости от них выполнение неких заложенных в логику правил.

Обычно пользоваться готовыми примерами мне удавалось легко, но этот случай похоже особый

Итак.

Первое что я сделал - разобрался с проблемами связанными с компиляцией и заставил выполняться следующий пример:

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/* Standard C++ includes */
#include <stdlib.h>
#include <iostream>
 
/*
  Include directly the different
  headers from cppconn/ and mysql_driver.h + mysql_util.h
  (and mysql_connection.h). This will reduce your build time!
*/
#include <mysql/mysql_connection.h>
 
#include <mysql/cppconn/driver.h>
#include <mysql/cppconn/exception.h>
#include <mysql/cppconn/resultset.h>
#include <mysql/cppconn/statement.h>
 
using namespace std;
 
int main(void)
{
cout << endl;
cout << "Running 'SELECT 'Hello World!' » AS _message'..." << endl;
 
try {
  sql::Driver *driver;
  sql::Connection *con;
  sql::Statement *stmt;
  sql::ResultSet *res;
 
  /* Создание соединения */
  driver = get_driver_instance();
  con = driver->connect("tcp://ip_адрес:3306", "некий_пользователь", "какойто_там_пароль");
  /* Подключение к базе данных mysql */
  con->setSchema("scada");
 
  stmt = con->createStatement();
  res = stmt->executeQuery("SELECT * FROM dict_rule");
  while (res->next()) 
  {
    cout << "\t... id_rule: " << res->getInt("id_rule") << endl;
  }
  delete res;
  delete stmt;
  delete con;
 
} catch (sql::SQLException &e) {
  cout << "# ERR: SQLException in " << __FILE__;
  //cout << "(" << __FUNCTION__ << ") on line " »  << __LINE__ << endl;
  cout << "# ERR: " << e.what();
  cout << " (MySQL error code: " << e.getErrorCode();
  cout << ", SQLState: " << e.getSQLState() << " )" << endl;
}
 
cout << endl;
 
return EXIT_SUCCESS;
}
Я успешно получил список id, после чего осмелел и решил перенести общение с базой данных в класс query_class

Был создан заголовоный файл

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/* 
 * File:   query_class.h
 * Author: fedoseev
 *
 * Created on 22 Ноябрь 2014 г., 18:11
 */
 
#ifndef QUERY_CLASS_H
#define QUERY_CLASS_H
 
#include <stdlib.h>
#include <iostream>
#include <stdio.h>
 
/*
  Include directly the different
  headers from cppconn/ and mysql_driver.h + mysql_util.h
  (and mysql_connection.h). This will reduce your build time!
*/
#include <mysql/mysql_connection.h>
 
#include <mysql/cppconn/driver.h>
#include <mysql/cppconn/exception.h>
#include <mysql/cppconn/resultset.h>
#include <mysql/cppconn/statement.h>
 
class query_class {
public:
    query_class();
 
private:
 
};
 
#endif  /* QUERY_CLASS_H */
И файл собственно с кодом

C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
/* 
 * File:   query_class.cpp
 * Author: fedoseev
 * 
 * Created on 22 Ноябрь 2014 г., 18:11
 */
 
#include "query_class.h"
 
using namespace std;
 
query_class::query_class() 
{
 
 
try {
  sql::Driver *driver;
  sql::Connection *con;
  sql::Statement *stmt;
  sql::ResultSet *res;
 
  /* Создание соединения */
  driver = get_driver_instance();
  con = driver->connect("tcp://ip_адрес:3306", "какойто_там_пользователь", "какойто_там_пароль");
  /* Подключение к базе данных mysql */
  con->setSchema("scada");
 
  stmt = con->createStatement();
  res = stmt->executeQuery("SELECT * FROM dict_rule");
  while (res->next()) 
  {
    cout << "\t... id_rule: " << res->getInt("id_rule") << endl;
  }
  delete res;
  delete stmt;
  delete con;
 
} catch (sql::SQLException &e) {
  cout << "# ERR: SQLException in " << __FILE__;
  //cout << "(" << __FUNCTION__ << ") on line " »  << __LINE__ << endl;
  cout << "# ERR: " << e.what();
  cout << " (MySQL error code: " << e.getErrorCode();
  cout << ", SQLState: " << e.getSQLState() << " )" << endl;
}
 
cout << endl;
 
return EXIT_SUCCESS;
}
Возможно я гдето не прав, так как изучаю всё это методом (научного!) тыка, но вот что мне совершенно не ясно.
Я и в первом варианте и во втором варианте использовал одни и теже инклюды. Но почемуто во втором варианте у этих инклюдов резко появились не разрешённые зависимости. Причём я не поленился посмотреть всю цепочку не коррекных инклюдов и нашёл файл include, которого по мнению компилятора нет. Но странно то, что он есть и NetBeans прекрасно его находит при вводе по первым буквам!

Объясните чайнику в чём здесь фокус?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.11.2014, 18:05
Ответы с готовыми решениями:

#include <exception> (kubuntu, NetBeans, g++)
Всем привет. При подключении инклюдов #include &lt;mysql/mysql_connection.h&gt; #include...

Работа с файлами в C# с исп. библиотек #include <stdio.h> #include <stdlib.h> #include <math.h> #include <io.h>
В типизированном файле записаны названия городов и их численность. Увеличить численность каждого...

Возвращение массива в качестве результата выполнения метода класса (Kubuntu, netBeans, g++)
Всем привет. Пытаюсь написать свой первый демон на C++ по образу и подобию сделанного на PHP. ...

Странности в работе IDE NetBeans 8.1
Здравствуйте! Начал сталкиваться после обновления IDE NetBeans с 8.02 на 8.1 с уймой непонятных...

4
3255 / 2057 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
22.11.2014, 18:08 2
Kapitan79, во-первых, с чего вдруг конструктор стал возвращать какое-то значение?
Во-вторых, слов много, давайте ближе к телу: какие ошибки компилятора?
В-третьих, в последнем варианте есть функция main()?
0
4 / 4 / 0
Регистрация: 13.10.2013
Сообщений: 171
22.11.2014, 18:17  [ТС] 3
Да в последнем варианте main есть.
По поводу конструктора - это да...
По поводу конструктора - в точку. Именно наэто и ругается похоже.

Я с непривычки начал искать ошибки в графическом интерфейсе.
Там то как раз и пишется ошибка типа "В <mysql/mysql_connection.h> находятся не разрешённые файлы include"
Видимо не стоит обращать на них внимания...
0
3255 / 2057 / 351
Регистрация: 24.11.2012
Сообщений: 4,909
22.11.2014, 18:22 4
Цитата Сообщение от Kapitan79 Посмотреть сообщение
Видимо не стоит обращать на них внимания...
Судя по симптомам, в среде не настроены пути к заголовочным файлам. Нужно посмотреть какие конкретно заголовочные файлы не видит, где они лежат на файлухе и прописать директории где-нибудь в настройки проекта. Если компиляции не мешает, то теоретически можно и забить.
1
4 / 4 / 0
Регистрация: 13.10.2013
Сообщений: 171
22.11.2014, 18:26  [ТС] 5
Действительно, исправил код и всё заработало.
Спасибо!
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.11.2014, 18:26
Помогаю со студенческими работами здесь

Странности при работе с файлами на некоторых ПК
Здравствуйте. id visual studio. есть такая странность: дан код: #include &lt;stdio.h&gt; // подключаем...

Папки с include файлами
Подскажите, пожалуйста пути где лежат файлы инклудов, а конкретно arpa/inet.h netdb.h...

#include<iostream>// подключение библиотек #include <conio.h> #include <climits>
помогите для этой программы сделать блок-схему. Пожалуйста #include&lt;iostream&gt;// подключение...

Ошибки с неразрешенными внешними символами
1&gt;new_menu.obj : error LNK2019: ссылка на неразрешенный внешний символ &quot;void __cdecl...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru