青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 15,comments - 21,trackbacks - 0
      最近閑來無事,想看看mysql預(yù)處理執(zhí)行效率和直接執(zhí)行的效率差別有多大。先去網(wǎng)上查了查,兩種聲音都有,沒辦法,只好自己來驗證驗證。
     我打算測試插入的效率,下來建一個表
      
CREATE TABLE `test` (
  `id` int(11NOT NULL AUTO_INCREMENT,
  `col1` 
varchar(64NOT NULL DEFAULT '',
  `col2` 
char(60DEFAULT NULL,
  `col3` blob,
  `col4` 
timestamp NULL DEFAULT NULL,
  
PRIMARY KEY (`id`)
) ENGINE
=MyISAM DEFAULT CHARSET=utf8;
接下來貼上兩段分別用預(yù)處理插入的語句和直接插入的語句
預(yù)處理代碼
bool insert()
{
    if (mysql_stmt_prepare(stmt, "INSERT test(col1,col2,col3,col4) values(?,?,?,?)", strlen("INSERT test(col1,col2,col3,col4) values(?,?,?,?)")))
    {
        fprintf(stderr, 
" mysql_stmt_prepare(), insert failed\r\n");
        fprintf(stderr, 
" %s\r\n", mysql_stmt_error(stmt));
        
return false;
    }
    
    
//測試mysql_stmt_field_count()作用
    
//printf("mysql_stmt_field_count return value[%d]\r\n",mysql_stmt_field_count(stmt));
    MYSQL_BIND    bind[4];
    unsigned 
long length[4];
    my_bool       is_null[
4];
    
    memset(bind,
0,sizeof(bind));
    memset(length,
0,sizeof(length));
    memset(is_null,
0,sizeof(is_null));
    
    
char varchar_var[STRING_SIZE] = "hello yg";
    
char char_var[STRING_SIZE] = "hello dl";
    
    
struct st_stud st;
    st.id 
= 1;
    strncpy(st.name,
"shine.yang",16);
    st.score 
= 10.0f;
    
    time_t cur_t 
= time(NULL);
    
struct tm cur_tm;
    localtime_r(
&cur_t,&cur_tm);
    MYSQL_TIME    ts;
    ts.year 
= cur_tm.tm_year+1900, ts.month = cur_tm.tm_mon+1, ts.day = cur_tm.tm_mday,ts.hour = cur_tm.tm_hour, ts.minute = cur_tm.tm_min, ts.second = cur_tm.tm_sec;
    
    bind[
0].buffer_type= MYSQL_TYPE_STRING;
    bind[
0].buffer= varchar_var;
    bind[
0].buffer_length = STRING_SIZE;
    length[
0= strlen(varchar_var);
    bind[
0].length = &length[0];
    bind[
0].is_null= &is_null[0];
    
    bind[
1].buffer_type= MYSQL_TYPE_STRING;
    bind[
1].buffer= char_var;
    bind[
1].buffer_length = STRING_SIZE;
    length[
1= strlen(char_var);
    bind[
1].length = &length[1];
    bind[
1].is_null= &is_null[1];
    
    bind[
2].buffer_type= MYSQL_TYPE_BLOB;
    bind[
2].buffer= (char *)&st;
    bind[
2].buffer_length = sizeof(st);
    length[
2= sizeof(st);
    bind[
2].length = &length[2];
    bind[
2].is_null= &is_null[2];
    
    bind[
3].buffer_type = MYSQL_TYPE_TIMESTAMP;
    bind[
3].buffer= (char *)&ts;
    bind[
3].buffer_length = sizeof(ts);
    length[
3= sizeof(ts);
    bind[
3].length = &length[3];
    bind[
3].is_null= &is_null[3];
    
    dword time1 
= get_time();
    
for ( int i = 0; i < INSERT_ITEM_CNT;++i )
    {
        
if ( mysql_stmt_bind_param(stmt,bind) )
        {
            fprintf(stderr,
"mysql_stmt_bind_param failed,err = %s\r\n",mysql_stmt_error(stmt));
            
return false;
        }
        
        
if ( mysql_stmt_execute(stmt) )
        {
            fprintf(stderr,
"mysql_stmt_excute failed,err = %s\r\n",mysql_stmt_error(stmt));
            
return false;
        }
        
        
//printf("Total effect rows [%d]\r\n",(int)mysql_stmt_affected_rows(stmt));
    }
    dword time2 
= get_time();
    fprintf(stdout,
"stmt insert %d items,during time[%d]\r\n",INSERT_ITEM_CNT,time2-time1);
    
return true;
}
直接插入的代碼
bool insert()
{
    char varchar_var[STRING_SIZE] = "hello yg";
    
char char_var[STRING_SIZE] = "hello dl";
    
struct st_stud st;
    st.id 
= 1;
    strncpy(st.name,
"shine.yang",16);
    st.score 
= 10.0f;
    
    
char blob_var[128];
    mysql_real_escape_string(sql, blob_var, (
char *)&st,sizeof(st));
    
    
char query[1024= {0};
    
int len = snprintf(query,1024,"insert test(col1,col2,col3,col4) values('%s','%s','%s',NOW())",varchar_var,char_var,blob_var);
    dword time1 
= get_time();
    
for (int i = 0;i < INSERT_ITEM_CNT;++i )
    {
        mysql_real_query(sql,query,len);
    }
    dword time2 
= get_time();
    fprintf(stdout,
"direct insert %d items,during time[%d]\r\n",INSERT_ITEM_CNT,time2-time1);
    
    
return true;
}
下面是測試結(jié)果
                        預(yù)處理耗時(單位微秒)         直接操作耗時(單位微秒)
插入10000條         660763                              746571
插入100000條       8597130                            8784918
插入1000000條     95070524                          100157193
可以看出,插入方面,預(yù)處理效率要高些
posted on 2012-01-29 16:28 梨樹陽光 閱讀(731) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产一区二区三区高清播放| 亚洲一级片在线观看| 麻豆成人在线播放| 麻豆视频一区二区| 久久精品最新地址| 欧美激情一区三区| 欧美视频精品在线| 国产麻豆一精品一av一免费| 狠狠久久五月精品中文字幕| 亚洲精品乱码| 亚洲综合视频一区| 老司机亚洲精品| 久久在线免费观看视频| 欧美日韩另类丝袜其他| 国产亚洲欧美色| 牛牛国产精品| 午夜视频在线观看一区二区| 欧美韩国日本一区| 国产一区av在线| 欧美激情一区二区三区| 性色一区二区三区| 1024亚洲| 久久免费高清| 亚洲一级在线| 在线观看中文字幕亚洲| 日韩视频在线播放| 久久久久久一区| 国内精品久久久久久| 校园激情久久| 99视频一区二区| 欧美国产日韩精品| 欧美专区在线观看| 亚洲一区综合| 国产精品久久久久久影院8一贰佰| 亚洲欧洲久久| 欧美 日韩 国产精品免费观看| 欧美久久久久免费| 亚洲日本激情| 欧美亚洲视频一区二区| 国产精品第一区| 中国成人在线视频| 亚洲日本中文字幕| 久久天天躁狠狠躁夜夜av| 中文精品99久久国产香蕉| 欧美色另类天堂2015| 久久综合综合久久综合| 国产精品福利影院| 亚洲国产精品va在看黑人| 久久久噜噜噜久久人人看| 亚洲一区欧美二区| 欧美大片在线看| 亚洲午夜精品17c| 亚洲综合国产| 尤物九九久久国产精品的特点| 欧美顶级大胆免费视频| 欧美精品一区二区三| 另类激情亚洲| 国产视频一区二区在线观看| 噜噜噜91成人网| 国产日韩欧美在线| 麻豆av一区二区三区| 尤物yw午夜国产精品视频| 中日韩美女免费视频网址在线观看| 在线免费观看日本欧美| 欧美在线免费观看视频| 亚洲黄色成人| 亚洲小视频在线| 亚洲免费网站| 欧美一区二区三区久久精品茉莉花| 亚洲视频精品在线| 欧美日韩国产综合网| 久久久xxx| 欧美国产日韩在线观看| 欧美激情综合| 亚洲精品日韩精品| 欧美77777| 欧美尤物一区| 欧美精品三级日韩久久| 亚洲日本激情| 国产精品网站在线播放| 亚洲视频在线看| 欧美日韩精品免费观看视一区二区 | 久久综合狠狠综合久久综合88| 国产欧美视频在线观看| 亚洲黄色影院| 国产精品手机视频| 欧美亚洲一区| 麻豆av福利av久久av| 亚洲精品五月天| 国产精品欧美久久| 香蕉成人久久| 亚洲国产乱码最新视频| 亚洲一区成人| 激情久久久久久| 制服丝袜激情欧洲亚洲| 久久九九有精品国产23| 在线看视频不卡| 欧美日韩在线视频一区| 欧美尤物一区| 亚洲毛片在线看| 亚洲国产精品免费| 久久久福利视频| 亚洲人成网站色ww在线| 欧美一区二区精品久久911| 黄色精品免费| 欧美日韩一区二区三区免费| 欧美怡红院视频一区二区三区| 欧美激情一区二区三区| 久久se精品一区精品二区| 91久久在线视频| 国产一区二区三区不卡在线观看| 欧美激情第8页| 久久精品网址| 亚洲一区二区三区精品在线观看 | 欧美va亚洲va日韩∨a综合色| 亚洲精品孕妇| 欧美成人一品| 久久aⅴ乱码一区二区三区| 亚洲另类视频| 欧美激情一区二区三区不卡| 欧美在线视频免费| 一区二区三区色| 欧美日韩在线观看一区二区三区| 久久精品三级| 午夜精品福利视频| 久久久免费观看视频| 亚洲影视在线播放| 亚洲精品乱码久久久久久蜜桃91| 狠狠色狠狠色综合日日91app| 欧美日韩亚洲综合| 欧美丰满少妇xxxbbb| 久久久亚洲欧洲日产国码αv | 亚洲精品裸体| 欧美电影免费观看高清| 欧美亚洲三区| 午夜久久影院| 黄色工厂这里只有精品| 国产免费成人在线视频| 欧美午夜在线| 久久久精品免费视频| 欧美一区二区三区的| 亚洲欧美变态国产另类| 亚洲综合色自拍一区| 亚洲天堂av图片| 正在播放亚洲一区| 99re6热在线精品视频播放速度| 亚洲经典三级| 99精品欧美一区| 一区二区三区四区国产| 久久久综合免费视频| 欧美亚洲三级| 久久精品中文字幕免费mv| 欧美一区二视频| 麻豆精品在线视频| 免费的成人av| 性欧美超级视频| 久久国产乱子精品免费女| 99热免费精品| 在线电影国产精品| 亚洲激情女人| 制服丝袜激情欧洲亚洲| 午夜精品久久久久99热蜜桃导演| 亚洲欧美日本日韩| 久久久久在线| 亚洲国产精品一区在线观看不卡| 亚洲精品无人区| 亚洲欧美日韩一区| 久久精品国产久精国产爱| 亚洲天堂激情| 久久精品午夜| 欧美区一区二| 国产日韩欧美视频在线| 亚洲国产1区| 亚洲一区二区三区在线看| 久久精品国产96久久久香蕉| 欧美成年视频| 一区二区三区久久久| 欧美在线观看www| 欧美激情视频给我| 国产日韩欧美成人| 亚洲精选在线| 久久av免费一区| 亚洲国内精品在线| 欧美一区二区精美| 欧美区一区二区三区| 国产亚洲aⅴaaaaaa毛片| 99精品国产热久久91蜜凸| 欧美一区二区三区电影在线观看| 欧美韩国在线| 亚洲欧美国产毛片在线| 欧美另类videos死尸| 国精产品99永久一区一区| 亚洲午夜精品网| 欧美黑人国产人伦爽爽爽| 亚洲欧美综合精品久久成人| 欧美91大片| 精品不卡一区| 欧美一区午夜精品| 99精品欧美一区二区蜜桃免费| 久久婷婷麻豆|