Попытка заставить работать простую ODB-программу ‘hello’

Работа с 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::exception& 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::string& first,
const std::string& last,
unsigned short age)
: first_ (first), last_ (last), age_ (age)
{
}

const std::string&
first () const
{
return first_;
}

const std::string&
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

3

Решение

ОК, думаю, я понял, что происходит. (Это в любом случае последовательно). Я забыл создать таблицу в базе данных с помощью такого вызова:

mysql --user=odb_test --database=odb_test < person.sql

Это необходимо База данных должна знать о схеме, прежде чем программа сможет быть запущена. Итак, моя оставшаяся проблема состоит в том, чтобы выяснить, как сделать это в msssql вместо mysql.

ОБНОВИТЬ:

ОК, получил его на работу. Я сделал это с помощью диспетчера SQL Server, загрузив файл person.sql и выполнив запрос. Это поместило это в базу данных odb_test. Тогда рутина может бежать.

1

Другие решения


По вопросам рекламы [email protected]