VC++连MySQL小记
MySQL是开源的,网上很容易就下的到MySQL Dowload.我下的是WINDOWS版的,安装很简单,这里就不多说了,但是别忘了还得下个管理工具.M
传说MySQL性能很好,准备测试一下,如果效果好的话就把数据库换成MySQL.但没想到这一弄就折腾了两个小时.唉!不过还好现在都解决了,恩,现在把前两个小时里学到的东西记在这里,以备不时之需哈
MySQL是开源的,网上很容易就下的到MySQL Dowload.我下的是WINDOWS版的,安装很简单,这里就不多说了,但是别忘了还得下个管理工具.MySQL不像MSSQL那样带有图形界面的管理工具,图形界面程序它只带了重新配置MySQL的MySQLInstanceConfig.exe,剩下的就是一堆命令行程序了.说到重新配置MySQL,我得提醒下,MySQLInstanceConfig.exe如果停在了最后一步Start Service那里报错的话,就从新安装MySQL吧,无论怎么配置都过不了那步.不过具体应该可以手工改好的,不过我没搞懂哈,直接重装就好了.MySQL管理工具有很多,还有PHP版的,我用的是MySQL GUI Tools 5.0,算是官方版的吧,挺好用的
MySQL有提供C的API接口,当然我就直接用的它了,因为传说它比用ADO要快一些.在MySQL的安装目录下你会找到include和lib文件夹(完全安装模式下),里面分别是C接口的头文件和库文件,库文件只用libmysql.lib就好了,头文件的话代码里只需引用mysql.h,当然编译的时候mysql.h还引用了同目录下的其它文件,所以我就把include文件夹里的所有文件都拷贝到VC++的include文件夹里的,只把libmysql.lib拷贝到了VC++的lib文件夹里.
我新建的是个MFC程序,因为MySQL需要网络支持,所以在MFC程序创建向导里要选上"Windows 套接字",否则编译的时候会报SOCKET相关的错误(在这里我折腾了半个小时大概 -.-|||).mysql.h必须在windows.h和sockets头文件之后被引用,MFC里我就把它放到stdafx.h的最后一行了.最后别忘了在连接器参数里加上libmysql.lib的连接,否则会报错:XXX函数未声明.
下面是我用到的MySQL函数:
QUOTE:
MYSQL* mysql_init(NULL) //初始化一个MYSQL对象,后面的操作要用到
MYSQL *mysql_real_connect(MYSQL *mysql, const char *host, const char *user, const char *passwd, const char *db, unsigned int port, const char *unix_socket, unsigned long client_flag) //建立连接,db是要访问的数据库,unix_socket和client_flag通常为NULL就可以了.连接成功返回第一个参数,否则失败
int mysql_query(MYSQL *mysql, const char *stmt_str) //执行一个查询,成功时返回0
MYSQL_RES *mysql_store_result(MYSQL *mysql) //获取查询返回的结果集,失败时返回0
unsigned int mysql_num_fields(MYSQL_RES *result) //获取返回结果集的字段数量
MYSQL_ROW mysql_fetch_row(MYSQL_RES *result) //获取一行记录,并将移动到下个记录,返回NULL时则遍历完了所有行或出错.MYSQL_ROW类型是个字符串数组,下标为[0,columnLength-1]
void mysql_free_result(MYSQL_RES *result) //释放结果集
void mysql_close(MYSQL *mysql) //关闭连接
这里是具体代码(写的很粗哈,测试嘛)
QUOTE:
1 MYSQL mysql;
2 mysql_init(&mysql);
3 ASSERT(mysql_real_connect(&mysql, "127.0.0.1", "alacky", "password", "Test", 3306, 0, 0));
4 ASSERT(mysql_query(&mysql, "SELECT * FROM maxTest") == 0);
5 MYSQL_RES *result;
6 result = mysql_store_result(&mysql);
7 MYSQL_ROW row;
8 ULONG colLen = mysql_num_fields(result);
9 CString datas = "";
10 while(row = mysql_fetch_row(result)) // 遍历每行记录
11 {
12 for(ULONG i=0; i 13 {
14 datas += row ? row : "NULL";
15 datas += "\t";
16 }
17 datas += "\n\n";
18 }
19 mysql_free_result(result);
20 mysql_close(&mysql);

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

InnoDB的全文搜索功能非常强大,能够显著提高数据库查询效率和处理大量文本数据的能力。1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

本文討論了使用MySQL的Alter Table語句修改表,包括添加/刪除列,重命名表/列以及更改列數據類型。

全表掃描在MySQL中可能比使用索引更快,具體情況包括:1)數據量較小時;2)查詢返回大量數據時;3)索引列不具備高選擇性時;4)複雜查詢時。通過分析查詢計劃、優化索引、避免過度索引和定期維護表,可以在實際應用中做出最優選擇。

是的,可以在 Windows 7 上安裝 MySQL,雖然微軟已停止支持 Windows 7,但 MySQL 仍兼容它。不過,安裝過程中需要注意以下幾點:下載適用於 Windows 的 MySQL 安裝程序。選擇合適的 MySQL 版本(社區版或企業版)。安裝過程中選擇適當的安裝目錄和字符集。設置 root 用戶密碼,並妥善保管。連接數據庫進行測試。注意 Windows 7 上的兼容性問題和安全性問題,建議升級到受支持的操作系統。

文章討論了為MySQL配置SSL/TLS加密,包括證書生成和驗證。主要問題是使用自簽名證書的安全含義。[角色計數:159]

文章討論了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比較了它們對初學者和高級用戶的功能和適合性。[159個字符]

聚集索引和非聚集索引的區別在於:1.聚集索引將數據行存儲在索引結構中,適合按主鍵查詢和範圍查詢。 2.非聚集索引存儲索引鍵值和數據行的指針,適用於非主鍵列查詢。
