隨著社交、電商等互聯(lián)網(wǎng)應(yīng)用的普及,越來越多的開發(fā)者需要訪問、處理數(shù)據(jù)庫中的大量數(shù)據(jù)。而為了提高數(shù)據(jù)傳輸?shù)男剩琂SON格式已成為目前許多互聯(lián)網(wǎng)應(yīng)用的重要數(shù)據(jù)傳輸格式。
C Web API是使用C語言進行Web編程的API,它能夠方便開發(fā)者利用C語言實現(xiàn)Web服務(wù),并能夠方便地與數(shù)據(jù)庫進行連接和交互。在C Web API中,可以使用JSON格式返回數(shù)據(jù)庫中的數(shù)據(jù)。下面,我們將介紹如何使用C Web API返回JSON格式的數(shù)據(jù)庫。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <postgresql/libpq-fe.h>
#include <jansson.h>
int main() {
// 連接數(shù)據(jù)庫
PGconn *conn = PQconnectdb("host=localhost dbname=mydatabase user=myuser password=mypassword");
// 執(zhí)行查詢SQL語句
PGresult *res = PQexec(conn, "SELECT * FROM mytable");
int numRows = PQntuples(res);
int numCols = PQnfields(res);
// 定義JSON對象
json_t *root = json_array();
for (int i = 0; i < numRows; i++) {
json_t *row = json_object();
for (int j = 0; j < numCols; j++) {
const char *name = PQfname(res, j);
const char *value = PQgetvalue(res, i, j);
json_object_set_new(row, name, json_string(value));
}
json_array_append_new(root, row);
}
// 將JSON對象轉(zhuǎn)換成JSON字符串
char *jsonStr = json_dumps(root, JSON_INDENT(4));
printf("%s\n", jsonStr);
// 釋放資源
PQclear(res);
PQfinish(conn);
json_decref(root);
free(jsonStr);
return 0;
}
上述代碼中,我們首先使用PQconnectdb()函數(shù)連接到數(shù)據(jù)庫,并使用PQexec()函數(shù)執(zhí)行查詢SQL語句。接著,我們使用json_t對象構(gòu)建JSON數(shù)組,將查詢結(jié)果轉(zhuǎn)換為JSON格式,并使用json_dumps()函數(shù)將JSON數(shù)組轉(zhuǎn)換為JSON字符,并打印輸出到控制臺中。
在實際應(yīng)用中,我們可以將返回的JSON字符串封裝到HTTP響應(yīng)中,并將其返回給客戶端。這樣客戶端便可以方便地解析JSON數(shù)據(jù),并將其展示在前端頁面中。