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

#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 ..