【文件处理】给出TableNameColumnNameTypeName组成一个createTable语句

该博客介绍了一种方法,通过读取不同文本文件(表名、列名和类型)的内容,将这些信息组合成SQL `create table`语句。程序使用C++,并利用`fstream`处理文件,`map`存储表名及其列数,并通过迭代器遍历列名和类型,生成格式化的创建表语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <map>
#include <iostream>
#include <fstream>
#include <stdio.h>
#include <stdlib.h>
#include <string>
#include <vector>
#include <iomanip>
using namespace std;

int main(int argc,char **argv)
{
	//打开 表名.txt
	fstream TableName;
	TableName.open("C:\\Documents and Settings\\Administrator\\Desktop\\20120820\\Table.txt",ios::in);
	if(!TableName.is_open())
	{
		cout << "failure to open"<<endl;
	}
	//打开 列名.txt
	fstream ColumnName;
	ColumnName.open("C:\\Documents and Settings\\Administrator\\Desktop\\20120820\\Column.txt",ios::in);
	if(!ColumnName.is_open())
	{
		cout << "failure to open"<<endl;
	}
	vector<string> columnV;
	string ColumnLine;
	while(getline(ColumnName,ColumnLine))
	{
		columnV.push_back(ColumnLine);
	}
	cout <<"列数:" <<columnV.size()<<endl;
	//打开 类型.txt
	fstream TypeName;
	TypeName.open("C:\\Documents and Settings\\Administrator\\Desktop\\20120820\\Type.txt",ios::in);
	if(!TypeName.is_open())
	{
		cout << "failure to open!" << endl;
	}
	vector<string> TypeV;
	string TypeLine;
	while(getline(TypeName,TypeLine))
	{
		TypeV.push_back(TypeLine);
	}
	cout <<"类型:" <<TypeV.size()<<endl;
	//定义 结果集
	fstream CreateTable;
	CreateTable.open("C:\\Documents and Settings\\Administrator\\Desktop\\20120820\\CreateTable.txt",ios::out);
	if(!CreateTable.is_open())
	{
		cout << "failure to open"<<endl;
	}
	//统计表名,及每个表名的个数,也就是表的列数
	map<string,int> TableNameNumber;
	string line;
	while(getline(TableName,line))
	{
		pair<map<string,int>::iterator,bool> ret = TableNameNumber.insert(make_pair(line,1));
		if(!ret.second)
		{
			++ret.first->second;
		}
	}
	//构建create table SQL语句
	string Column;
	string Type;
	int i;
	vector<string>::iterator columnIter = columnV.begin();
	vector<string>::iterator typeIter = TypeV.begin();
	cout.setf(ios::left); //设置对齐方式为left
	cout.width(8); //设置宽度为7,不足用空格填充
	for(map<string,int>::iterator begin = TableNameNumber.begin();
		begin != TableNameNumber.end(); begin++)
	{
		cout << "create table "+(*begin).first << endl;
		cout << "("                                        << endl;
		for(
			i=0;
			i<(*begin).second; 
			i++,columnIter++,typeIter++
				)
		{
			cout <<"\t"<<setw(10)<<left <<(*columnIter);
			cout.unsetf(ios::left);
		
			cout<<"\t" << (*typeIter)<< "," <<endl;
		}
		cout << ")"                                        << endl;
	}
	TableName.close();
	ColumnName.close();
	TypeName.close();
}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值