#c #odb
#c #odb
Вопрос:
Работа с VS 2012 и Microsoft SQL Server. У меня есть все для компиляции и сборки, но программа умирает, когда я пытаюсь сохранить первый объект:
// file : hello/driver.cxx
// copyright : not copyrighted - public domain
#include <memory> // std::auto_ptr
#include <iostream>
#include <odb/database.hxx>
#include <odb/transaction.hxx>
#include "database.hxx" // create_database
#include "person.hxx"
#include "person-odb.hxx"
using namespace std;
using namespace odb::core;
int
main (int argc, char* argv[])
{
try
{
auto_ptr<database> db (create_database (argc, argv));
unsigned long john_id, joe_id;
// Create a few persistent person objects.
//
{
person john ("John", "Doe", 33);
person jane ("Jane", "Doe", 32);
person joe ("Joe", "Dirt", 30);
transaction t (db->begin ());
// Make objects persistent and save their ids for later use.
//
john_id = db->persist (john); // Note: dies here
db->persist(jane);
joe_id = db->persist(joe);
t.commit ();
}
}
catch (const odb::exceptionamp; e)
{
cerr << e.what () << endl;
return 1;
}
}
Итак, я предполагаю, что хорошо, что я прошел часть create_database. Это означает, что я подключаюсь к серверу (я думаю). Я получаю сообщение об ошибке:
208 (42S02) [Microsoft][SQL Server Native Client 11.0][SQL Server]Invalid object name 'person'.
8180 (42000) [Microsoft][SQL Server Native Client 11.0][SQL Server]Statement(s) could not be prepared.
Вероятно, это что-то простое, но я не могу в этом разобраться. Возможно, я на САМОМ деле не получаю доступ к нужной мне базе данных.
Вот person.hxx:
// file : hello/person.hxx
// copyright : not copyrighted - public domain
#ifndef PERSON_HXX
#define PERSON_HXX
#include <string>
#include <cstddef> // std::size_t
#include <odb/core.hxx>
#pragma db object
class person
{
public:
person (const std::stringamp; first,
const std::stringamp; last,
unsigned short age)
: first_ (first), last_ (last), age_ (age)
{
}
const std::stringamp;
first () const
{
return first_;
}
const std::stringamp;
last () const
{
return last_;
}
unsigned short
age () const
{
return age_;
}
void
age (unsigned short age)
{
age_ = age;
}
private:
friend class odb::access;
person () {}
#pragma db id auto
unsigned long id_;
std::string first_;
std::string last_;
unsigned short age_;
};
#pragma db view object(person)
struct person_stat
{
#pragma db column("count(" person::id_ ")")
std::size_t count;
#pragma db column("min(" person::age_ ")")
unsigned short min_age;
#pragma db column("max(" person::age_ ")")
unsigned short max_age;
};
#endif // PERSON_HXX
Комментарии:
1. Если возможно, используйте
std::unique_ptr
вместоstd::auto_ptr
.2. @CaptainObvlious, возможно, это причина проблемы или это общий комментарий к стилю / программированию?
3. Просто общее наблюдение.
auto_ptr
сломан и устарел, а VS2012 поддерживает некоторые функции C 11 и дополнения к библиотеке, в том числеstd::unique_ptr
.4. @Jim, здесь недостаточно информации, чтобы кто-то мог помочь. Можете ли вы опубликовать наименьшую версию
"person.hxx"
, которая вызывает проблему, плюс наименьший набор команд, которые вы используете для вызова компилятора ODB и реального компилятора?5. @0xbe5077ed , это стандартные файлы из каталога примеров ODB, поэтому я не думаю, что это имеет какое-либо отношение к person.hxx. Я почти уверен, что что-то настроено неправильно.
Ответ №1:
Хорошо, я думаю, я понял, что происходит. (В любом случае это согласовано). Я забыл создать таблицу в базе данных с помощью такого вызова:
mysql --user=odb_test --database=odb_test < person.sql
Это необходимо. База данных должна знать о схеме, прежде чем программа может быть запущена. Итак, моя оставшаяся проблема — выяснить, как это сделать в msssql вместо mysql.
Обновить:
Хорошо, заставил ее работать. Я сделал это с помощью диспетчера SQL Server, загрузив файл person.sql и выполнив запрос. Он поместил ее в базу данных odb_test. Затем может быть запущена процедура.
Комментарии:
1. Нужно ли создавать базу данных odb_test вручную? Или есть какой-то другой способ сделать это из программы? например, SQLITE_OPEN_CREATE ..