VC用MYSQL提供的LIB查询数据库
#include "winsock.h"
#include "mysql.h"
void query_example(void)
{
MYSQL *pDbCon = NULL;
char *pszHost = "localhost";
char *pszUser = "guest";
char *pszPsw = "";
char *pszDbName = "mysql_db_name";
int iPort = 3306;
pDbCon = mysql_init((MYSQL*) 0);
if (NULL != pDbCon)
{
if (mysql_real_connect(pDbCon, pszHost, pszUser, pszPsw, pszDbName, iPort, NULL, 0))
{
if (!mysql_select_db(pDbCon, pszDbName))
{
pDbCon->reconnect = 1;
char *pszSql = "select * from tb_name";
if (!mysql_query(pDbCon, pszSql))
{
long i = 0;
MYSQL_RES *pReSet = mysql_store_result(pDbCon);
long iFieldNum = mysql_num_fields(pReSet);
long iRecordNum = (long)mysql_num_rows(pReSet);
//printf name of fields
MYSQL_FIELD *pField = mysql_fetch_fields(pReSet);
for (i = 0; i < iFieldNum; i++)
{
//printf("%s, ", pField[i].name);
}
//printf all data
MYSQL_ROW stRow;
while (stRow = mysql_fetch_row(pReSet))
{
//printf row's data
for (i = 0; i < iFieldNum; i++)
{
if (stRow[i] != NULL)
{
//printf("%s ", stRow[i]);
}
}
}
}
}
else
{
//printf("unable to select the database!\n");
}
}
else
{
//printf("can't connect to the mysql server!\n");
}
mysql_close(pDbCon);
}
}
相关文档:
mysql text 长度
文章分类:数据库
今天在做DB设计的时候在想用TEXT 是否能够满足将来的数据,能够出现装不下的情况。
后来查询了一下官方手册得到了一个答案。
一个BLOB或TEXT列,最大长度为65535(2^16-1)个字符。
MEDIUMBLOB
MEDIUMTEXT
一个BLOB或TEXT列,最大长度为16777215(2^24-1)个字符。
LONG ......
今天在写实习生的培训PPT时,用mysql的command line client插入一条带中文的记录时,报data to long的错误,
在网上查看了相关资料,说的是因为这个console使用了一种编码方式,把命令编码后再发送到数据库,具体请参看http://www.cnblogs.com/ovliverlin/archive/2007/11/26/972549.html,说的比较详细,本人看完后,直接 ......
对于每个类型拥有的值范围以及并且指定日期何时间值的有效格式的描述见7.3.6 日期和时间类型。
这里是一个使用日期函数的例子。下面的查询选择了所有记录,其date_col的值是在最后30天以内:
mysql> SELECT something from table
WHERE TO_DAYS(NOW()) - TO_DAYS(date_col) select DAYOFWEEK('1998-02-03');
-&g ......