文档章节

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

菅超鹏
 菅超鹏
发布于 2014/06/13 00:18
字数 373
阅读 80
收藏 0

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取代





© 著作权归作者所有

共有 人打赏支持
菅超鹏
粉丝 0
博文 10
码字总数 2856
作品 0
广州
程序员
私信 提问
C语言程序员编程学习文件操作与JSON

C语言是面向过程的,而C++是面向对象的 C和C++的区别: C是一个结构化语言,它的重点在于算法和数据结构。C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到...

小辰带你看世界
2018/03/15
0
0
JSON for Modern C++ 3.3.0 发布,C++ JSON 库

JSON for Modern C++ 3.3.0 已发布了。JSON for Modern C++ 是一个由德国大牛 nlohmann 编写的在 C++ 下使用的 JSON 库。 具有以下特点 直观的语法 整个代码由一个头文件组成 json.hpp,没有...

达尔文
2018/10/07
1K
1
跨平台网络通信与服务器编程框架库(acl库)介绍

一、描述 acl 工程是一个跨平台(支持LINUX,WIN32,Solaris,MacOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能 库。通过该库,用户可以非常容易地编写支持多种模式(...

郑树新
2014/08/18
7
0
跨平台网络通信与服务器编程框架库(acl库)介绍

一、描述 acl 工程是一个跨平台(支持LINUX,WIN32,Solaris,MacOS,FreeBSD)的网络通信库及服务器编程框架,同时提供更多的实用功能 库。通过该库,用户可以非常容易地编写支持多种模式(...

郑树新
2014/08/23
0
0
ajson 0.2.0版发布,飞快的JSON C++序列化库

http://git.oschina.net/lordoffox/ajson ajson a utility for serialize C++ and json. 动机: 为什么要设计ajson? 在工作中经常有这样的需求,获得一段json编码的文本,将它解析为dom对象...

lordoffox
2016/02/19
3.7K
16

没有更多内容

加载失败,请刷新页面

加载更多

mariadb 内存占用优化

本文由云+社区发表 作者:工程师小熊 摘要:我们在使用mariadb的时候发现有时候不能启动起来,在使用过程中mariadb占用的内存很大,在这里学习下mariadb与内存相关的配置项,对mariadb进行调...

腾讯云加社区
53分钟前
2
0
spring security 自定义登录认证

spring security 自定义认证登录 1.概要 1.1.简介 spring security是一种基于 Spring AOP 和 Servlet 过滤器的安全框架,以此来管理权限认证等。 1.2.spring security 自定义认证流程 1)认证...

EasyProgramming
53分钟前
1
0
PAI通过流式机器学习算法解决实时热点新闻挖掘案例

(机器学习PAI Online Learning模块上线邀测,目前只支持华北2(北京)区域使用,本实验会用到流式机器学习算法) PAI地址:https://data.aliyun.com/product/learn 邀测申请地址:https://dat...

阿里云官方博客
57分钟前
1
0
Win下Jenkins-2.138源码编译及填坑笔记

源码编译篇 1、 安装JDK1.8-181,操作系统添加JDK环境变量。Java -version验证一下。 注:Jenkins2.138版本,JDK必须jkd1.8.0-101以上,不支持Java9,Maven必须3.5.3以上。 2、 解压Maven3....

编程SHA
59分钟前
2
0
Oracle数据库常用函数 转换函数 日期函数 字符型函数 数值函数

在讲解函数的功能和用法之前,先了解一下dual这个表。 dual这个表是一张只有一个字段,一行记录的表。它是一个虚拟表,用来构成select的语法规则。所以我们接下来会用到这个表来讲解常用函数。...

Sakura20
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部