Blog list & Book list

Blog list
张晏的博客:
酷壳:
服务器运维与网站架构|Linux运维|X研究:
现代简明魔法-数据之美:
阮一峰的博客:
……
 
Book list
《C语言程序设计》- 谭浩强 
《黑客与画家》- Paul Graham (作者), 阮一峰 (译者)
《失控》- 凯文•凯利 (Kevin Kelly) 
……
 

sublime text2 配置SVN

sublime text2是一款绝对性感、好用的编辑器,用用你就知道…

使用Package Control组件安装

安装package control组件,然后直接在线安装:

按Ctrl+` 调出console
粘贴以下代码到底部命令行并回车:

重启Sublime Text 2。
如果在Perferences->package settings中看到package control这一项,则安装成功。

如果这种方法不能安装成功,可以下载文件手动安装,点击下载
用Package Control安装插件的方法:

按下Ctrl+Shift+P调出命令面板,输入install 调出 Install Package 选项并回车

install
然后在列表中选中要安装的插件,建议装TortoiseSVN 。

svn

配置SVN

打开 preference –> Browse package  然后找到文件夹名称为 TortoiseSVN 的,点进去,用本编辑器打开 TortoiseSVN.sublime-settings 这个文件,把这个地址改成你的SVN安装地址。

seting
配置成功后,就可以用了
ssss
快捷键
alt+u 更新 svn_update
alt+c 提交 svn_commit
官方下载:sublime text2
sublimetxet插件

 

 

Hello Universe!

1.PHP中session默认有效期是1440秒(24分钟)。

2.面向对象程序设计的三大思想是:封装、继承、多态。

3.多态,就是指基类和派生类中可以有同名但功能完全不同的函数或方法。

4. …

linux下用C语言连接mysql实现增删改查

公司内部培训,领导要求在linux环境下用c语言连接mysql数据库,实现增删改查功能,做一个demo。

环境:Red Hat Enterprise Linux 4

①安装mysql

②创建数据库表:bbb

CREATE TABLE `bbb` (
`id` int(11) NOT NULL auto_increment,
`name2` varchar(20) default NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8

C的代码:

#include 
#include 
#include 
#include  
/*定义数据库连接需要的宏*/
#define HOST "localhost"
#define USERNAME "root"
#define PASSWORD "ictspace"
#define DATABASE "test"

/*执行传入的sql語句*/
void exe_sql(char* sql) {
	MYSQL my_connection; /*这是一个数据库连接*/
	int res; /*执行sql語句后的返回标志*/
	/*初始化mysql连接my_connection*/
	mysql_init(&my_connection);
	if (mysql_real_connect(&my_connection, HOST, USERNAME, PASSWORD,DATABASE, 0, NULL, 0)) {
		/*连接成功*/
		printf("数据库执行exe_sql连接成功!n");
		mysql_query(&my_connection, "set names utf8");
		/*mysql_query函数执行传入的sql語句,返回一个int值,如果为0,执行成功*/
		res = mysql_query(&my_connection, sql);
		if (res) {/*执行失败了*/
			printf("Error: mysql_query !\n");
			mysql_close(&my_connection);
		} else {/*执行成功了*/
			/*mysql_affected_rows返回执行sql后影响的行数*/
			printf("%d 行受到影响!\n", mysql_affected_rows(&my_connection));
			mysql_close(&my_connection);
		}
	} else {
		/*数据库连接失败*/
		printf("数据库执行exe_sql连接失败!\n");
	}
}

/*执行传入的sql語句,并打印出查询結果*/
void query_sql(char* sql) {
	MYSQL my_connection; /*这是一个数据库连接*/
	int res; /*执行sql語句后的返回标志*/
	MYSQL_RES *res_ptr; /*指向查询结果的指针*/
	MYSQL_FIELD *field; /*字段结构指针*/
	MYSQL_ROW result_row; /*按行返回的查询信息*/
	int row, column; /*查询返回的行数和列数*/
	int i, j; /*只是控制循环的两个变量*/
	/*初始化mysql连接my_connection*/
	mysql_init(&my_connection);
	if (mysql_real_connect(&my_connection, HOST, USERNAME, PASSWORD,DATABASE, 0, NULL, 0)) {/*连接成功*/
		printf("数据库查询query_sql连接成功!\n");
		mysql_query(&my_connection, "set names utf8");
		/*执行传入的sql語句,返回一个int值,如果为0,证明語句执行成功*/
		res = mysql_query(&my_connection, sql);
		if (res) { /*执行失败*/
			printf("Error: mysql_query !\n");
			mysql_close(&my_connection);
		} else { 
			/*执行成功了*/
			/*将查询的結果给res_ptr*/
			res_ptr = mysql_store_result(&my_connection);
			/*如果结果不为空,就把结果print*/
			if (res_ptr) {
				/*取得結果的行数和*/
				column = mysql_num_fields(res_ptr);
				row = mysql_num_rows(res_ptr);
				printf("查询到 %lu 行 \n", row);
				/*输出結果的字段名*/
				for (i = 0; field = mysql_fetch_field(res_ptr); i++)
				printf("%s\t", field->name);
				printf("\n");
				/*按行输出結果*/
				for (i = 1; i < row; i++) {
					result_row = mysql_fetch_row(res_ptr);
					for (j = 0; j < column; j++)
					printf("%s\t", result_row[j]);
					printf("\n");
				}
			}
			mysql_close(&my_connection);
		}
	}
}

int main(int argc, char *argv[]) {
	char *query;
	/*插入操作*/
	char *exe = "insert into bbb values('','eee');";
	/*更新操作*/
	//char *exe = "update `bbb` set `name2` = 'zzz' where `id` = 10";
	/*删除操作*/
	//char *exe = "delete from bbb where `name2` = 'eee'";
	exe_sql(exe);
	/*测试查询*/
	query="select * from bbb;";
	query_sql(query);
	return 0;
}

编译命令:
gcc-o c_mysql_demo -g c_mysql_demo.c -I /usr/include/mysql/ -L /usr/lib/ -l mysqlclient

参数说明:

-I(大写的i) 表示要连接的头文件目录,因为使用了<mysql.h> ,-L表示要连接的库文件目录 -l(小写的L) 表示要连接的具体的库名称,在/usr/lib/ 下,有叫做libmysqlclient.so的库,指定具体的库的名字时,默认去掉头尾的lib和.so直接使用中间的mysqlclient
如果不用-I -L ,可能导致找不到头文件 或者 函数未定义的错误
by
无报错,编译成功。

查看表:
select

执行程序:
exe

再次查看表bbb:
select_2

数据插入成功!

更新、删除操作类似,只需改一下sql语句即可。