什么是c++ mysql中的分段错误?
What is segmentation fault in C++ mysql?
我使用c++向服务器发送MySQL命令。为什么说"分割错误",这是什么意思?当我运行程序时,它的输出是:
connection Succeeded
Segmentation fault
编辑代码以删除i+1行,但仍然有相同的问题
代码:
#include <stdlib.h>
#include <iostream>
#include <mysql.h>
#include <stdio.h>
#define SERVER "localhost"
#define USER "root"
#define PASSWORD "coursework"
int main()
{
MYSQL *connect;
connect=mysql_init(NULL);
if (!connect)
{
std::cout<<"MySQL Initialization failed";
return 1;
}
connect=mysql_real_connect(connect, SERVER, USER, PASSWORD, NULL ,0,NULL,0);
if (connect)
{
std::cout<<"connection Succeededn";
}
else
{
std::cout<<"connection failedn";
exit(1);
}
mysql_query (connect, "drop database if exists TTU;");
mysql_query (connect,"create database TTU;");
mysql_query (connect, "use TTU;");
mysql_query (connect, "create table students(tnumber char(8) PRIMARY KEY,");
mysql_query (connect, "firstname varchar(20) NOT NULL,");
mysql_query (connect, "lastname varchar(20) NOT NULL,");
mysql_query (connect, "dateofbirth date,");
mysql_query (connect, "INDEX 'lastname_i' ('lastname'),");
mysql_query (connect, "ENGINE=INNODB);");
mysql_query (connect, "insert into students(tnumber, firstname, lastname, dateofbirth)");
mysql_query (connect, "values (00001234, Joe, Smith, 1950-08-12);");
MYSQL_RES *res_set;
MYSQL_ROW row;
mysql_query (connect,"select * from students;");
unsigned int i =0;
res_set = mysql_store_result(connect);
unsigned int numrows = mysql_num_rows(res_set);
while ((row= mysql_fetch_row(res_set)) != NULL )
{
std::cout << row[i] << std::endl;
}
mysql_close (connect);
std::cout << "TEST" << std::endl;
return 0;
}
显示的代码中有多个错误。主要有两个bug:不正确的使用mysql_query()
,以及反复检查各种MySQL库函数的返回值失败,导致无法检测到各种错误。
mysql_query (connect, "create table students(tnumber char(8) PRIMARY KEY,");
这不是有效的SQL。mysql_query()
接受完整的 SQL
语句并执行它。它不采用SQL语句的单个片段,将其分解为多个连续调用,并且只在解析完整的SQL语句后执行它。
由于所示代码无法检查来自mysql_query()
的返回值,因此它无法检测到mysql_query()
调用的整个序列已经失败,并且表没有被创建。
后续调用也无法检查其他MySQL库函数的返回值
显示的代码很可能从mysql_store_result()
返回NULL
,检查失败,将NULL
指针传递给mysql_num_rows()
,然后崩溃。
相关文章:
- 在某些循环内使用vector.push_back时出现分段错误
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- 当我的阵列太大时出现分段错误
- 分段错误当我试图运行程序时出错
- 在c++中初始化矩阵时出现分段错误(核心转储)
- 尝试使用集合函数时出现分段错误
- 我无法缩小此分段错误的原因
- g++的分段错误(在NaN上使用to_string两次时)
- 我是如何在这段代码中出现分段错误的
- 创建结构的数组时遇到分段错误
- 在c++中键入向量中的所有值后,得到分段错误(核心转储)
- 在 c++ 中实现 Trie 时出现分段错误
- 为什么 fstream 在打开带有格式的文件时会导致分段错误?
- 为什么我遇到分段错误?
- 动态类的分段错误(家庭作业问题)
- 分段错误 - 读取初始化指针的数组
- 如何摆脱C ++中的分段错误错误?
- 使用 CTYPE 时出现分段错误
- 为什么代码给出分段错误?