|

楼主 |
发表于 2004-5-15 22:31:56
|
显示全部楼层
回复: 回复: 我想用MySQL自带的C_API来编写基于GTK+的实现查询,更新等功能的图形界面
使用MYsql的C_API写的一个例子:- #include <stdio.h>
- #include <mysql.h>
-
- int main() {
- MYSQL_RES *query_result;
- MYSQL_ROW row;
- MYSQL *db_handle,mysql;
- int query_error;
-
- mysql_init(&mysql);
- db_handle = mysql_real_connect (&mysql,"localhost","name","password","station_system",0,0,0);
- if (db_handle == NULL) {
- printf (mysql_error(&mysql));
- return 1;
- }
- query_error = mysql_query(db_handle,"SELECT id,company FROM unit");
- if (query_error != 0) {
- printf(mysql_error(db_handle));
- return 1;
- }
- query_result = mysql_store_result(db_handle);
- while (( row = mysql_fetch_row(query_result)) != NULL) {
- printf("Name: %s %s\n",(row[0] ? row[0] : "NULL"),
- (row[1] ? row[1] : "NULL"));
- }
- mysql_free_result(query_result);
- mysql_close(db_handle);
- }
复制代码
用gcc -o example example.c -I/usr/include/mysql -L/usr/lib/mysql可以编译
一个用GTK+写的helloworld:
- #include <gtk/gtk.h>
- /* 这是一个回调函数。data 参数在本示例中被忽略。
- * 后面有更多的回调函数示例。*/
- void hello( GtkWidget *widget,
- gpointer data )
- {
- g_print ("Hello World\n");
- }
- gint delete_event( GtkWidget *widget,
- GdkEvent *event,
- gpointer data )
- {
- /* 如果你的 "delete_event" 信号处理函数返回 FALSE,GTK 会发出 "destroy" 信号。
- * 返回 TRUE,你不希望关闭窗口。
- * 当你想弹出“你确定要退出吗?”对话框时它很有用。*/
- g_print ("delete event occurred\n");
- /* 改 TRUE 为 FALSE 程序会关闭。*/
- return TRUE;
- }
- /* 另一个回调函数 */
- void destroy( GtkWidget *widget,
- gpointer data )
- {
- gtk_main_quit ();
- }
- int main( int argc,
- char *argv[] )
- {
- /* GtkWidget 是构件的存储类型 */
- GtkWidget *window;
- GtkWidget *button;
-
- /* 这个函数在所有的 GTK 程序都要调用。参数由命令行中解析出来并且送到该程序中*/
- gtk_init (&argc, &argv);
-
- /* 创建一个新窗口 */
- window = gtk_window_new (GTK_WINDOW_TOPLEVEL);
-
- /* 当窗口收到 "delete_event" 信号 (这个信号由窗口管理器发出,通常是“关闭”
- * 选项或是标题栏上的关闭按钮发出的),我们让它调用在前面定义的 delete_event() 函数。
- * 传给回调函数的 data 参数值是 NULL,它会被回调函数忽略。*/
- g_signal_connect (G_OBJECT (window), "delete_event",
- G_CALLBACK (delete_event), NULL);
-
- /* 在这里我们连接 "destroy" 事件到一个信号处理函数。
- * 对这个窗口调用 gtk_widget_destroy() 函数或在 "delete_event" 回调函数中返回 FALSE 值
- * 都会触发这个事件。*/
- g_signal_connect (G_OBJECT (window), "destroy",
- G_CALLBACK (destroy), NULL);
-
- /* 设置窗口边框的宽度。*/
- gtk_container_set_border_width (GTK_CONTAINER (window), 10);
-
- /* 创建一个标签为 "Hello World" 的新按钮。*/
- button = gtk_button_new_with_label ("Hello World");
-
- /* 当按钮收到 "clicked" 信号时会调用 hello() 函数,并将NULL传给
- * 它作为参数。hello() 函数在前面定义了。*/
- g_signal_connect (G_OBJECT (button), "clicked",
- G_CALLBACK (hello), NULL);
-
- /* 当点击按钮时,会通过调用 gtk_widget_destroy(window) 来关闭窗口。
- * "destroy" 信号会从这里或从窗口管理器发出。*/
- g_signal_connect_swapped (G_OBJECT (button), "clicked",
- G_CALLBACK (gtk_widget_destroy),
- window);
-
- /* 把按钮放入窗口 (一个 gtk 容器) 中。*/
- gtk_container_add (GTK_CONTAINER (window), button);
-
复制代码
可以用gcc -o example example.c `gtk-config --cflags --libs`编译
但如果我要在两个程序间通信,把mysql的查询结果用gtk的图形显示出来,要如何做?让我觉得困惑的是,mysql_C_API是用在标准的C写的,而gtk虽然说数据类型的定义什么的没有什么差别,只是在语句前加一个g,比如int写成了gint,我尝试把第一个例子程序把int,char等改成gtk的gint等,用gcc -o example example.c -I/usr/include/mysql -L/usr/lib/mysql `gtk-config --cflags --libs`编译却通不过
可能我的想当然应该如此,因为没做过真正的程序开发,所以不了解,请兄弟们指导一二:thank :thank :thank |
|