socket连接、数据库操作简单文档



参考链接:
http://www.cnblogs.com/justinzhang/archive/2011/09/23/2185963.html
http://www.cnblogs.com/skynet/archive/2010/12/12/1903949.html


服务器端

第一步:
创建socket操作,建立流式套接字,返回套接字号sockSrv
    SOCKET socket(int af, int type, int protocol);
    第一个参数,指定地址簇(TCP/IP只能是AF_INET,也可写成PF_INET)
    第二个,选择套接字的类型(流式套接字),第三个,特定地址家族相关协议(0为自动)
    
    第二步:
套接字sockSrv与本地地址相连
    int bind(SOCKET s, const struct sockaddr* name, int namelen);
    第一个参数,指定需要绑定的套接字;
    第二个参数,指定该套接字的本地地址信息,该地址结构会随所用的网络协议的不同而不同
    第三个参数,指定该网络协议地址的长度


    第三步:
将套接字设置为监听模式(连接请求), listen()通知TCP服务器准备好接收连接
    int listen(SOCKET s,  int backlog);
    第一个参数指定需要设置的套接字,第二个参数为(等待连接队列的最大长度)


    第四步: (一般是在一个死循环里)
    accept(),接收连接,等待客户端连接
    SOCKET accept(  SOCKET s,  struct sockaddr* addr,  int* addrlen);
    第一个参数,接收一个处于监听状态下的套接字
    第二个参数,sockaddr用于保存客户端地址的信息
    第三个参数,用于指定这个地址的长度
    返回的是向与这个监听状态下的套接字通信的套接字








    客户端:


    第一步同服务器端的第一步


    第二步:
    将套接字sockClient与远程主机相连
    int connect( SOCKET s,  const struct sockaddr* name,  int namelen);
    第一个参数:需要进行连接操作的套接字
    第二个参数:设定所需要连接的地址信息
    第三个参数:地址的长度




客户端与用户端进行通信


    send(), 在套接字上发送数据
    int send( SOCKET s,  const char* buf,  int len,  int flags);
    第一个参数,需要发送信息的套接字,
    第二个参数,包含了需要被传送的数据,
    第三个参数是buffer的数据长度,
    第四个参数,一些传送参数的设置


    recv(), 在套接字上接收数据
    int recv(  SOCKET s,  char* buf,  int len,  int flags);
    第一个参数,建立连接后的套接字,
    第二个参数,接收数据
    第三个参数,接收数据的长度,
    第四个参数,一些传送参数的设置


    //优雅的切割线/


    上述函数发生错误的话,会返回-1


    //再次优雅的的切割线/


    数据库
    数据库是有增删查改功能滴,
    如果是要查找,需要一个结果集来记录。


  


    第一步:
    mysql_init(&mysql);
    初始化一个mysql地址结构体。
    也有mysql_init(NULL)的写法。分别暂不明


    第二步:
    mysql句柄与一个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 int client_flag)
第一个参数,一个现存MYSQL结构的地址。
第二个参数,host值可以是一个主机名或一个IP地址。如果host是NULL或字符串"localhost",假定是到本地主机的一个连接。
第三个参数,user参数包含用户的MySQL登录ID。如果user是NULL,假定是当前用户。
第四个参数,passwd参数为user连接口令。
第五个参数,db是数据库名。如果db不是NULL,连接将缺省数据库设置为这个值。
第六个参数,port是端口名。如果port不是0,值对于TCP/IP连接将用作端口号。注意host参数决定连接的类型。
第七个参数 如果unix_socket不是NULL,字符串指定套接字或应该被使用的命名管道。注意host参数决定连接的类型。
第八个参数 client_flag值通常是0


第六、七、八参数我都是用0,NULL,0的,没去细究


第三步:
开始操作数据库,有两个函数
int mysql_real_query(MYSQL *mysql, const char *query, unsigned int length)
int mysql_query(MYSQL *mysql, const char *query)
对于包含二进制数据的查询,你必须使用mysql_real_query()而不是mysql_query(),因为二进制代码数据可能包含“\0”字符,而且,mysql_real_query()比mysql_query()更快,因为它对查询字符串调用strlen()。
但贪懒不相写多个length,现在用的是mysql_query
query 就是具体的sql语句


如果是select(即查找操作)会有第四步:
把结果保存在一个MYSQL_RES的结构体里
MYSQL_RES *mysql_store_result(MYSQL *mysql)


然后用
MYSQL_RES *result;
    MYSQL_ROW row;
        while ((row = mysql_fetch_row(result))){
  
        }
来遍历这个结构体



  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值