- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Windows 应用程序,正在将其移植到 UNIX/Linux。此应用程序使用 ODBC 连接到 SQL Server。在本例中,SQL Server 运行在 Windows 服务器上,但我认为这并不重要。
问题是我需要与服务器建立多个连接。因此应用程序多次调用 SQLDriverConnect()(使用不同的连接句柄)。在 Windows 上这工作得很好。但在 Linux 上,第二次调用崩溃了。
当然,我的实际应用程序测试了 SQL 函数的返回值。但缩减后的样本没有出现任何错误,因此我删除了这些测试。
我已将完整的应用程序缩减为 10 行程序,但结果相同。
SQLHANDLE henv, hdbc1, hdbc2;
char connstr[] = "DRIVER={ODBC Driver 11 for SQL Server};<other necessary params>";
SQLAllocHandle(SQL_HANDLE_ENV, SQL_NULL_HANDLE, &henv);
SQLSetEnvAttr(henv, SQL_ATTR_ODBC_VERSION, (SQLPOINTER) SQL_OV_ODBC3, 0);
SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc1);
SQLAllocHandle(SQL_HANDLE_DBC, henv, &hdbc2);
SQLDriverConnect(hdbc1, NULL, connstr, strlen(connstr),
NULL, 0, &need, SQL_DRIVER_NOPROMPT);
SQLDriverConnect(hdbc2, NULL, connstr, strlen(connstr),
NULL, 0, &need, SQL_DRIVER_NOPROMPT);
我希望第二次调用成功(或者至少返回一个错误)。相反,应用程序会因“内存故障”而严重崩溃。如果我使用 gdb 调试程序,我会得到更多信息:
程序收到信号 SIGSEGV,段错误。0x0000000000000000 在?? ()
您可能想知道为什么我需要与服务器的多个连接。事实上,我可能不会,但这是他们目前编写应用程序的方式。如果我可以使用 ODBC 调用设置一些标志以从单个连接获取多个结果集,那么我就会这样做。但我没有运气使用该功能。
非常感谢
最佳答案
这似乎是由于我正在使用的 ODBC 驱动程序管理器造成的。我正在使用的机器上安装了多个。如果我设置不同的 ODBC 驱动程序管理器,一切都会按预期工作。
失败的 ODBC 驱动程序管理器是 unixODBC 的自制版本。成功的 ODBC 驱动程序管理器是 native Red Hat Linux 版本(无论是什么)。我不知道这是 unixODBC 的错误,还是我们特定构建的错误,还是其他原因。但我确实知道,当使用 Red Hat 版本的 ODBC 驱动程序管理器时,我的示例程序可以正常工作,而且我的完整应用程序也可以正常工作。
关于c - SQLDriverConnect 在 Linux 上崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57101807/
我有一段代码看起来像这样: void update_clock(uint8_t *time_array) { time_t time = *((time_t *) &time_array[0]
应用程序崩溃了 :( 请帮助我.. 在这方面失败了。我找不到错误?该应用程序可以连接到 iTunesConnect 但它会出错。 谁能根据下面的崩溃报告判断问题出在哪里? share_with_app
小二是新来的实习生,作为技术 leader,我给他安排了一个非常简单的练手任务,把前端 markdown 编辑器里上传的图片保存到服务器端,结果他真的就把图片直接保存到了服务器上,这下可把我气坏了,就
我正在创建一个函数,它将目录路径作为参数传递,或者如果它留空,则提示用户输入。 我已经设置了我的 PATH_MAX=100 和 if 语句来检查 if ((strlen(folder path) +
我已将“arial.ttf”文件(从我的/Windows/Fonts 文件夹中获取)加载到内存中,但是将其传递到 FT_New_Memory_Face 时会崩溃(在 FT_Open_Face 中的某处
我正在尝试在我的计算机上的两个控制台之间进行 rtsp 流。 在控制台 1 上,我有: ffmpeg -rtbufsize 100M -re -f dshow -s 320x240 -i video=
我正在尝试使用 scio_beast在一个项目中。我知道它还没有完成,但这并不重要。我已经设法让它工作得很好。 我现在正在尝试连接到 CloudFlare 后面的服务器,我知道我需要 SNI 才能工作
我有一个带有关联宏的下拉列表,如下所示: Sub Drop() If Range("Hidden1!A1") = "1" Then Sheets("Sheet1").Se
我对 bash 很陌生。我要做的就是运行这个nvvp -vm /usr/lib64/jvm/jre-1.8.0/bin/java无需记住最后的路径。我认为 instafix 就是这样做...... n
我在 Windows 上使用 XAMPP 已经两年左右了,它运行完美,没有崩溃没有问题。 (直到四个月前。) 大约四个月前,我们将服务器/系统升级到了更快的规范。 这是旧规范的内容 - Windows
我面临着一个非常烦人的 android 崩溃,它发生在大约 1% 的 PRODUCTION session 中,应用程序始终在后台运行。 Fatal Exception: android.app.Re
尝试使用下面的函数: public void createObjectType() { try { mCloudDB.createObjectType(ObjectTypeIn
由于我正在进行的一个项目,我在 CF11 管理员中弄乱了类路径,我设法使服务器崩溃,以至于我唯一得到的是一个漂亮的蓝屏和 500 错误.我已经检查了日志,我会把我能做的贴在帖子的底部,但我希望有人会启
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 10 个月前关闭。 Improve
我最近从 xcode 3.x 更新到 4.2,当我在 4.2 中运行应用程序时,我遇到了核心数据问题。我还更新到了 iOS 5,所以问题可能就在那里,我不太确定。 这些应用程序在 3.x 中运行良好,
我是一个相对较新的 iPhone 应用程序开发人员,所以我的知识有点粗略,所以如果这是一个微不足道的问题,请原谅我。 我有一个导航应用程序,它通过在navigationController对象上调用p
if ([MFMailComposeViewController canSendMail]) { MFMailComposeViewController *mailViewController
你能帮我吗? 我正在设置 UILocalNotification,当我尝试设置其 userInfo 字典时,它崩溃了。 fetchedObjects 包含 88 个对象。 这是代码: NSDi
为什么我的代码中突然出现 NSFastEnumeration Mutation Handler 崩溃。我很茫然为什么会突然出现这个崩溃以及如何解决它。 最佳答案 崩溃错误: **** 由于未捕获的异常
当我从表中删除行时,我的应用程序崩溃了。这是我检测到错误和堆栈跟踪的来源。谢谢! //delete row from database - (void)tableView:(UITableView *
我是一名优秀的程序员,十分优秀!