代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
C
】
linux下c实现的数据库备份
作者:
Yvette
/ 发布于
2015/7/20
/
1055
Linux下c实现的数据库备份,只要修改数据库列表文件的信息即可。 db_list.txt把后缀去掉即可,一个数据库一行。
#include<sys/types.h> #include<sys/wait.h> #include<ctype.h> #include<unistd.h> #include<string.h> #include<stdlib.h> #include<stdio.h> //待备份的数据表文件(一个数据库一行) #define DB_FILE "./db_list" //最多可以备份的数据库数量 #define NUM 20 //一个数据库名字的最长字符数 #define LEN 128 //保存从DB_FILE中读取到的数据库 char *db_list[NUM]; //从DB_FILE文件中读取到的数据库数量 int read_num; //请求内存函数 void malloc_dblist(); //释放内存函数 void free_dblist(); //读取数据库文件 void readDbFile(); int main(int argc, char *argv[]) { pid_t pid; int i; char buf[LEN]; //从文件读取数据库信息 readDbFile(); pid = fork(); if (pid < 0) { fprintf(stderr, "fork error\n"); exit(1); } switch (pid) { case -1: fprintf(stderr, "fork failed\n"); exit(1); case 0: //子进程进行数据库的备份 for (i = 0; i < read_num; i++) { memset(buf, '\0', LEN); sprintf(buf, "%s%s%s%s%s", "mysqldump -uroot ", db_list[i], " > ", db_list[i], ".sql"); system(buf); printf("%d,%s\n", i, buf); } break; } //等待子进程的结束 if (pid > 0) { int stat_val; pid_t child_pid; child_pid = wait(&stat_val); if (!WIFEXITED(stat_val)) { fprintf(stdout, "Child terminated abnormaly\n"); } exit(1); } free_dblist(); exit(0); } void malloc_dblist() { int i = 0; //malloc for db_list for (i = 0; i < NUM; i++) { db_list[i] = malloc(LEN); memset(db_list[i], '\0', LEN); } } void free_dblist() { int i; //free db_list's memory for (i = 0; i < NUM; i++) { free(db_list[i]); } } void readDbFile() { FILE *fp; fp = fopen(DB_FILE, "r"); if (!fp) { fprintf(stderr, "%s not found\n", DB_FILE); } else { malloc_dblist(); read_num = 0; while (fscanf(fp, "%127[^\r\n]\n", db_list[read_num]) == 1) { puts(db_list[read_num]); read_num++; } fclose(fp); } } db_list.txt admin book #include<sys/types.h> #include<sys/wait.h> #include<ctype.h> #include<unistd.h> #include<string.h> #include<stdlib.h> #include<stdio.h> //待备份的数据表文件(一个数据库一行) #define DB_FILE "./db_list" //最多可以备份的数据库数量 #define NUM 20 //一个数据库名字的最长字符数 #define LEN 128 //保存从DB_FILE中读取到的数据库 char *db_list[NUM]; //从DB_FILE文件中读取到的数据库数量 int read_num; //请求内存函数 void malloc_dblist(); //释放内存函数 void free_dblist(); //读取数据库文件 void readDbFile(); int main(int argc, char *argv[]) { pid_t pid; int i; char buf[LEN]; //从文件读取数据库信息 readDbFile(); pid = fork(); if (pid < 0) { fprintf(stderr, "fork error\n"); exit(1); } switch (pid) { case -1: fprintf(stderr, "fork failed\n"); exit(1); case 0: //子进程进行数据库的备份 for (i = 0; i < read_num; i++) { memset(buf, '\0', LEN); sprintf(buf, "%s%s%s%s%s", "mysqldump -uroot ", db_list[i], " > ", db_list[i], ".sql"); system(buf); printf("%d,%s\n", i, buf); } break; } //等待子进程的结束 if (pid > 0) { int stat_val; pid_t child_pid; child_pid = wait(&stat_val); if (!WIFEXITED(stat_val)) { fprintf(stdout, "Child terminated abnormaly\n"); } exit(1); } free_dblist(); exit(0); } void malloc_dblist() { int i = 0; //malloc for db_list for (i = 0; i < NUM; i++) { db_list[i] = malloc(LEN); memset(db_list[i], '\0', LEN); } } void free_dblist() { int i; //free db_list's memory for (i = 0; i < NUM; i++) { free(db_list[i]); } } void readDbFile() { FILE *fp; fp = fopen(DB_FILE, "r"); if (!fp) { fprintf(stderr, "%s not found\n", DB_FILE); } else { malloc_dblist(); read_num = 0; while (fscanf(fp, "%127[^\r\n]\n", db_list[read_num]) == 1) { puts(db_list[read_num]); read_num++; } fclose(fp); } }
试试其它关键字
数据库备份
同语言下
.
获取手机通讯录 iOS去除数字以外的所有字符
.
异步加载音乐等资源
.
交通罚单管理系统
.
freemark实现,简单的替换
.
计算斐波那契数列
.
base64解码 包括解码长度
.
图像显示
.
冒泡排序
.
输入十进制数,输出指定进制
.
链式栈
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
Yvette
贡献的其它代码
(
20
)
.
计算文档每行出现的数字个数,并计算整个文档的数字总
.
去除input和textarea点击选中框,只能输入数字
.
获取昨天日期、今天日期、明天日期以及前一个小时和后
.
返回字符串A从start位置到结尾的字符串
.
不使用第三个变量完成两个整数的交换
.
获取本机内网和外网IP
.
遍历子目录文件
.
获取工程目录
.
自定义导航栏按钮(左侧)
.
上传文件
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3