mysql 教程 存儲(chǔ)過程

最近用mysql + asp.net來寫網(wǎng)站,既然mysql已經(jīng)支持存儲(chǔ)過程了,那么像分頁(yè)這么常用的東西,當(dāng)然要用存儲(chǔ)過程啦

不過在網(wǎng)上找了一些,發(fā)現(xiàn)都有一個(gè)特點(diǎn)——就是不能傳出總記錄數(shù),干脆自己研究吧。終于,算是搞出來了,效率可能不是很好,但是我也覺得不錯(cuò)了。貼代碼吧直接:也算是對(duì)自己學(xué)習(xí)mysql的一個(gè)記錄。
   代碼如下:
CREATE PROCEDURE p_pageList
  (
  m_pageNo int ,
  m_perPageCnt int ,
  m_column varchar(1000) ,
  m_table varchar(1000) ,
  m_condition varchar(1000),
  m_orderBy varchar(200) ,
  out m_totalPageCnt int
  )
  BEGIN
  SET @pageCnt = 1; — 總記錄數(shù)
  SET @limitStart = (m_pageNo – 1)*m_perPageCnt;
  SET @limitEnd = m_perPageCnt;
  SET @sqlCnt = CONCAT(‘select count(1) into @pageCnt from ‘,m_table); — 這條語(yǔ)句很關(guān)鍵,用來得到總數(shù)值
  SET @sql = CONCAT(‘select ‘,m_column,’ from ‘,m_table);
  IF m_condition IS NOT NULL AND m_condition ” THEN
  SET @sql = CONCAT(@sql,’ where ‘,m_condition);
  SET @sqlCnt = CONCAT(@sqlCnt,’ where ‘,m_condition);
  END IF;
  IF m_orderBy IS NOT NULL AND m_orderBy ” THEN
  SET @sql = CONCAT(@sql,’ order by ‘,m_orderBy);
  END IF;
  SET @sql = CONCAT(@sql, ‘ limit ‘, @limitStart, ‘,’, @limitEnd);
  PREPARE s_cnt from @sqlCnt;
  EXECUTE s_cnt;
  DEALLOCATE PREPARE s_cnt;
  SET m_totalPageCnt = @pageCnt;
  PREPARE record from @sql;
  EXECUTE record;
  DEALLOCATE PREPARE record;
  END

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊10 分享