C++操作数据库写入到json配置文件中

1. 这次加了对int和varchar的处理

#include <iostream>
#include <string>
#include <vector>
#include <mysql/mysql.h>
#include "json/json.h"
#include <fstream>
#include <cstdlib>

using namespace std;

int main(int argc, char* argv[])
{
	MYSQL mysql;
	mysql_init( &mysql );

	mysql_real_connect(
		&mysql,
		"192.168.16.114",
		"root",
		"root",
		"test",
		3306,
		NULL,
		0
	);

	string sql = "show tables;";
	mysql_query( &mysql, sql.c_str() );
	
	MYSQL_RES *result = NULL;
	result = mysql_store_result( &mysql );
	
	vector<string> tables;
	MYSQL_ROW row = NULL;
	//得到所有的表
	row = mysql_fetch_row( result );
	while ( NULL != row )
	{
		tables.push_back( row[0] );
		cout << row[0] << endl;
		row = mysql_fetch_row( result );
	}

	for(vector<string>::const_iterator cit = tables.begin(); cit != tables.end(); ++ cit)
	{
		sql = "select * from " + *cit;
		mysql_query( &mysql, sql.c_str() );
		
		cout << sql << endl;
		//得到表中列的数量
		result = mysql_store_result( &mysql );
	
		MYSQL_FIELD* field = NULL;
		
		ofstream os;
		string tableName = *cit + ".json";
		os.open( tableName.c_str() );

		Json::Value jsonTable;
		MYSQL_ROW row1 = mysql_fetch_row( result );
		int field_count = mysql_num_fields( result );
		while ( NULL != row1 )
		{
			Json::Value jsonRow;
			for(int i = 0; i < field_count; ++i)
			{
				field = mysql_fetch_field_direct( result, i );
				
					
				switch(field->type)	
				{
				case MYSQL_TYPE_TINY:
					cout << "MYSQL_TYPE_TINY" << endl;
					break;
				case MYSQL_TYPE_SHORT:
					cout << "MYSQL_TYPE_SHORT" << endl;
					break;
				case MYSQL_TYPE_BLOB:
					cout << "MYSQL_TYPE_BLOB" << endl;
					break;
				case MYSQL_TYPE_LONG:
					jsonRow[field->name] = Json::Value( atoi(row1[i]) );	
					cout << "MYSQL_TYPE_LONG" << endl;
					break;
				case MYSQL_TYPE_VAR_STRING:
					cout << "MYSQL_TYPE_VAR_STRING" << endl;
					jsonRow[field->name] = Json::Value( row1[i] );	
					break;
				}
			
			}
			
			row1 = mysql_fetch_row( result );
			//cout << *cit << endl;
			
			jsonTable.append(jsonRow);
		}
		
		
		os << jsonTable;
		os << flush;
		os.close();
	}
	
	return 0;
}

上面只处理了一些两种类型 其他类型如下

MYSQL_TYPE_TINY                     TINYINT字段

MYSQL_TYPE_SHORT                    SMALLINT字段

MYSQL_TYPE_LONG                     INTEGER字段

MYSQL_TYPE_INT24                    MEDIUMINT字段

MYSQL_TYPE_LONGLONG                 BIGINT字段

MYSQL_TYPE_DECIMAL                  DECIMAL或NUMERIC字段

MYSQL_TYPE_NEWDECIMAL               精度数学DECIMAL或NUMERIC

MYSQL_TYPE_FLOAT                    FLOAT字段

MYSQL_TYPE_DOUBLE                   DOUBLE或REAL字段

MYSQL_TYPE_BIT                      BIT字段

MYSQL_TYPE_TIMESTAMP                TIMESTAMP字段

MYSQL_TYPE_DATE                     DATE字段

MYSQL_TYPE_TIME                     TIME字段

MYSQL_TYPE_DATETIME                 DATETIME字段

MYSQL_TYPE_YEAR                     YEAR字段

MYSQL_TYPE_STRING                   CHAR字段

MYSQL_TYPE_VAR_STRING               VARCHAR字段

MYSQL_TYPE_BLOB                     BLOB或TEXT字段(使用max_length来确定最大长度)

MYSQL_TYPE_SET                      SET字段

MYSQL_TYPE_ENUM                     ENUM字段

MYSQL_TYPE_GEOMETRY                 Spatial字段

MYSQL_TYPE_NULL                     NULL-type字段

MYSQL_TYPE_CHAR                     不再重视,用MYSQL_TYPE_TINY取代





转载于:https://my.oschina.net/jianchaopeng/blog/278926

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值