用C语言制作图书管理系统
时间: 2023-09-08 09:09:55 浏览: 55
好的,制作图书管理系统需要考虑以下几个方面:
1. 数据库设计:需要设计一个数据库来存储图书信息,包括书名、作者、出版社、ISBN号、价格等。
2. 用户界面设计:需要设计一个用户界面来实现图书的查询、添加、删除、修改等操作。
3. 数据库连接:需要使用C语言的数据库连接库来连接数据库,实现数据的增删改查等操作。
4. 数据输入输出:需要使用C语言的文件操作库来实现数据的输入输出,将图书信息保存到文件或从文件中读取信息。
下面是一个简单的示例代码,实现了图书管理系统的基本功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <mysql/mysql.h>
#define MAX_QUERY_LEN 2048
// 数据库连接信息
const char *db_host = "localhost";
const char *db_username = "root";
const char *db_password = "123456";
const char *db_name = "library";
// 初始化数据库连接
MYSQL *init_mysql() {
MYSQL *conn = mysql_init(NULL);
if (conn == NULL) {
printf("Failed to initialize MySQL connection!\n");
exit(1);
}
if (mysql_real_connect(conn, db_host, db_username, db_password, db_name, 0, NULL, 0) == NULL) {
printf("Failed to connect to MySQL database: Error: %s\n", mysql_error(conn));
mysql_close(conn);
exit(1);
}
return conn;
}
// 查询图书信息
void query_book_info(MYSQL *conn, const char *book_name) {
char query[MAX_QUERY_LEN];
sprintf(query, "SELECT * FROM books WHERE name='%s'", book_name);
if (mysql_query(conn, query)) {
printf("Failed to query database: Error: %s\n", mysql_error(conn));
return;
}
MYSQL_RES *res = mysql_store_result(conn);
if (res == NULL) {
printf("Failed to store result: Error: %s\n", mysql_error(conn));
return;
}
int num_fields = mysql_num_fields(res);
MYSQL_ROW row;
while ((row = mysql_fetch_row(res))) {
for (int i = 0; i < num_fields; i++) {
printf("%s\t", row[i] ? row[i] : "NULL");
}
printf("\n");
}
mysql_free_result(res);
}
// 添加图书信息
void add_book_info(MYSQL *conn, const char *name, const char *author, const char *publisher, const char *isbn, double price) {
char query[MAX_QUERY_LEN];
sprintf(query, "INSERT INTO books(name, author, publisher, isbn, price) VALUES ('%s', '%s', '%s', '%s', %lf)",
name, author, publisher, isbn, price);
if (mysql_query(conn, query)) {
printf("Failed to add book info: Error: %s\n", mysql_error(conn));
return;
}
printf("Add book info successfully!\n");
}
// 删除图书信息
void delete_book_info(MYSQL *conn, const char *book_name) {
char query[MAX_QUERY_LEN];
sprintf(query, "DELETE FROM books WHERE name='%s'", book_name);
if (mysql_query(conn, query)) {
printf("Failed to delete book info: Error: %s\n", mysql_error(conn));
return;
}
printf("Delete book info successfully!\n");
}
// 更新图书信息
void update_book_info(MYSQL *conn, const char *book_name, double new_price) {
char query[MAX_QUERY_LEN];
sprintf(query, "UPDATE books SET price=%lf WHERE name='%s'", new_price, book_name);
if (mysql_query(conn, query)) {
printf("Failed to update book info: Error: %s\n", mysql_error(conn));
return;
}
printf("Update book info successfully!\n");
}
int main() {
MYSQL *conn = init_mysql();
// 查询图书信息
query_book_info(conn, "C语言程序设计");
// 添加图书信息
add_book_info(conn, "Python编程从入门到实践", "Eric Matthes", "人民邮电出版社", "9787115476886", 69.0);
// 删除图书信息
delete_book_info(conn, "Java编程思想");
// 更新图书信息
update_book_info(conn, "C++ Primer Plus", 99.0);
mysql_close(conn);
return 0;
}
```
上述代码使用了MySQL数据库连接库,实现了查询、添加、删除、更新图书信息等功能。代码只是一个示例,实际应用中需要根据具体需求进行修改和优化。