什么是C ++ mysql中的分段错误?

时间:2016-10-27 00:30:52

标签: 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 Succeeded\n";
    } 
    else 
    {
        std::cout<<"connection failed\n";
        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;
}

1 个答案:

答案 0 :(得分:1)

显示的代码中存在多个错误。有两个主要错误: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库函数的返回值。

显示的代码可能会从NULL返回mysql_store_result(),无法检查,将NULL指针传递给mysql_num_rows(),然后崩溃。