- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
使用 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
最佳答案
好的,我想我知道发生了什么。 (无论如何,它是一致的)。我忽略了通过这样的调用在数据库中创建表:
mysql --user=odb_test --database=odb_test < person.sql
这是必需的。在程序运行之前,数据库需要知道模式。所以,我剩下的问题是弄清楚如何在 msssql 而不是 mysql 中执行此操作。
更新:
好的,开始工作了。我通过 SQL Server 管理器执行此操作,加载 person.sql 文件并执行查询。它把它放在 odb_test 数据库中。然后例程可以运行。
关于c++ - 试图让简单的 ODB 'hello' 程序工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24333971/
我想了解 ODB 模型是如何工作的。 这是来自 the official site 的片段: #pragma db object class person { private:
我第一次使用 ODB:Code Synthesis 的 C++ 对象关系映射 (ORM)。这是一个类似于 C# 的 .NET EntityFramework 的工具,因为它允许您通过 C++ 在各种关
我一直在看ODB ORM现在已经有一段时间了,并进行了一些练习。我的问题是在重新编译代码的不同 DBMS 之间切换。从我的 Java 背景来看,我可以简单地更改配置文件并且 ORM 可以工作,例如 H
在我的 Visual Studio 解决方案中,我有两个不同的项目,其中一个构建为 static library,另一个构建为可执行文件。 ODB 相关代码,如创建数据库等都在库中。我将这个库链接到我
如何在 Mac OS X 中将 MacVim 配置为 ODB 编辑器?我有狮子(10.7),但我想雪豹也是一样。 MacVim 文档和简单的 Google 搜索似乎都缺少此过程,尽管 MacVim 的
我必须使用 ODB framework在我的项目中。我有 2 个文件:station.hxx 和 common.hxx,内容如下: common.hxx #ifndef COMMON_HXX #def
Microsoft SQL Server 上存储了一个过程。过程可以返回一个值。如何使用 ODB ORM 从 MS SQL Server 数据库执行存储过程并获取该过程返回的值? 最佳答案 您可以为此
是否可以将 odb(c++ orm 类框架)编译指示移到类头之外?例如,我只用 id 定义类 basic_object(抽象): class basic_object { int _id; p
我对这个库和一般的 ORM 还很陌生。我知道像 EntityFramework 这样的工具可以从数据库生成代码。 ODB for C++ 可以完成这项工作吗? 最佳答案 我不这么认为。看着 main
我最近完成了本教程, http://www.objectdb.com/tutorial/jpa/eclipse/spring/run 它说在Tomcat目录下创建了.odb文件,但是我找不到Tomca
使用 VS 2012 和 Microsoft SQL Server。我得到了所有要编译和构建的东西,但是当我尝试保留第一个对象时程序就死了: // file : hello/driver.c
我使用以下查询通过 JDBC 从 .mdb 文件检索数据,但是当我在 .odb 文件上尝试它时,它不会抛出任何异常,但根本没有结果。我想知道 .odb 是否区分大小写,而 .mdb 不区分大小写,还是
我关注了libgit2-backend为 libgit2 ODB 后端创建 mysql 后端的项目。 创建 blob 对象并将其放入 mysql 支持的 ODB 中相当容易,我正在使用 git_blo
我有一个名为 TimelineItem 的对象,它有一个名为 linked_items_ 的数据字段,其中包含一个 TimelineItem 类型的 vector 。这是为了表示链接到原始项目(重复项
我的代码有什么问题吗?继续显示此错误消息 Microsoft OLE DB Provider for ODBC Drivers error '80040e14' [MySQL][ODBC 5.2(w)
我正在尝试使用 ODB 建立一对多关系的模型。我基本上是在尝试重新创建 https://www.codesynthesis.com/products/odb/doc/manual.xhtml#6.2.
我正在考虑使用 ORM(对象关系映射器)来将我的 C++ 对象保存到 SQLite 数据库中。我目前正在考虑通过 CodeSynthesis 进行 ODB。 参见:http://www.codesyn
我正在尝试按照本教程学习如何使用 C++ 和 ODB: http://www.codesynthesis.com/products/odb/doc/manual.xhtml#2 我创建了一个 Pers
我想在我的游戏中使用 artemis ( https://github.com/junkdog/artemis-odb)。 最近我读到了 Glenn Fiedler 的游戏循环: http://gaf
我正在尝试使用 ODB Java API (this library)从我的汽车通过蓝牙从 ELM327 获取数据,但在每次请求时返回 ?,并且库引发 MisunderstoodException 这
我是一名优秀的程序员,十分优秀!