• 使用这个东西,首先要包含2个头文件:
    #include <netdb.h>
    #include <sys/socket.h>

    struct hostent *gethostbyname(const char *name);
    这个函数的传入值是域名或者主机名,例如"www.google.cn
    ","wpc"等等。
    传出值,是一个hostent的结构(如下)。如果函数调用失败,将返回NULL。

    struct hostent
    {
      char  *h_name;
      char  **h_aliases;
      int   h_addrtype;
      int   h_length;
      char  **h_addr_list;
    };
    解释一下这个结构:
    其中,
      char *h_name 表示的是主机的规范名。例如
    www.google.com的规范名其实是www.l.google.com
      char   **h_aliases 表示的是主机的别名.www.google.com
    就是google他自己的别名。有的时候,有的主机可能有好几个别名,这些,其实都是为了易于用户记忆而为自己的网站多取的名字。
      int   h_addrtype 表示的是主机ip地址的类型,到底是ipv4(AF_INET),还是pv6(AF_INET6)
      int   h_length 表示的是主机ip地址的长度
      int   **h_addr_lisst 表示的是主机的ip地址,注意,这个是以网络字节序存储的。千万不要直接用printf带%s参数来打这个东西,会有问题的哇。所以到真正需要打印出这个IP的话,需要调用inet_ntop()。

    const char *inet_ntop(int af, const void *src, char *dst, socklen_t cnt) :
    这个函数,是将类型为af的网络地址结构src,转换成主机序的字符串形式,存放在长度为cnt的字符串中。
    这个函数,其实就是返回指向dst的一个指针。如果函数调用错误,返回值是NULL。

     
    下面是例程,有详细的注释。

    #include <netdb.h>
    #include <sys/socket.h>

    int main(int argc, char **argv)
    {
        char *ptr,**pptr;
        struct hostent *hptr;
        char str[32];

        /* 取得命令后第一个参数,即要解析的域名或主机名 */
        ptr = argv[1];

        /* 调用gethostbyname()。调用结果都存在hptr中 */
        if((hptr = gethostbyname(ptr)) == NULL)
        {
            printf("gethostbyname error for host:%s\n", ptr);
            return 0; /* 如果调用gethostbyname发生错误,返回1 */
        }

        /* 将主机的规范名打出来 */
        printf("official hostname:%s\n",hptr->h_name);

        /* 主机可能有多个别名,将所有别名分别打出来 */
        for(pptr = hptr->h_aliases; *pptr != NULL; pptr++)
            printf("  alias:%s\n",*pptr);

        /* 根据地址类型,将地址打出来 */
        switch(hptr->h_addrtype)
        {
            case AF_INET:
            case AF_INET6:
                pptr=hptr->h_addr_list;

                /* 将刚才得到的所有地址都打出来。其中调用了inet_ntop()函数 */
                for(;*pptr!=NULL;pptr++)
                printf("  address:%s\n", inet_ntop(hptr->h_addrtype,                                  *pptr, str, sizeof(str)));
            break;
            default:
                printf("unknown address type\n");
            break;
        }

        return 0;
    }

  • From 伏尔泰

  • 嘘,安静~

    我回来了

  • 2009-02-26

    关于DB2的锁

    锁级别分类

    行级
        NS    ?
        NW    ?
        WE    ?
    表级
        IN    ?
        IS
        IX
        SIX    ?
        Z    ?

    行或表级
        S
        U
        X

    锁的获取


    通过Index Scan
        有更新意图    IX on table --> S or X on rows
        无更新意图    IS on table --> S on rows
    通过Table Scan
        有更新意图    X on table
        无更新意图    S on table

  • 本质:

    索引的本质应该就是map,更具体的讨论 请看这里。借此,可以加速检索的速度。

    在数据库表中创建索引可能有两个目的:

    • 确保列值的唯一性
    • 提高查询的性能

    索引的种类:

    • 唯一索引 (UNIQUE)   唯一索引用于保证唯一性,在创建主键时,会隐式地创建一个唯一索引
    • 非唯一索引
    • 降序/升序索引(DESC/AESC)   建立的索引都会按照一定顺序排序存储,可以显示地指定这个顺序。
    • 双向索引 (ALLOW REVERSE SCAN ) 可以同时加速 MIN,MAX操作。
    • 聚集索引 (CLUSTER)  建立聚集索引可以按照索引键顺序排序记录的物理存储(在以某种顺序检索数据时可提高性能)

    p.s. 另外在索引中可以存储额外的列值(不必须为索引列),用以在检索数据时不必通过索引查询数据页,而直接取出结果。

     

    总结

    索引在加快检索的同时,会带来副作用(更慢的更新、插入和删除)。所以,应该根据需要使用索引:

    • 对使用MAX操作的查询,用降序索引;MIN用升序索引;都有则用双向索引;
    • select * from table where id > 100 and id < 200 针对这种查询聚集索引可以提高性能;
    • select name from books where id > 100 and id < 200 如果大量检索,需要取出固定列的值,应使用包含列数据,避免访问数据页的开销

    另外,总结几点与SQL有关的注意事项:

    • 使用谓词like: like 'x%' 将会使用索引,而like '%x'将不能使用索引,而且因为谓词like的检索时间与字符串长度呈线性关系,使用VARCHAR代替CHAR可以去掉多余的空格,加快检索
    • 使用 fetch first only 或 limit 限制结果集大小

    参考

    50种方法巧妙优化你的SQL Server数据库