所謂分類,更多的是為telnet服務(wù)端考慮的,在cq66模式下,用戶可以按
照自己的意愿進(jìn)行分類,反正最后都是直接以版為基本單位訪問的。
對于版面文章的訪問,存放的時候以整篇文章為參數(shù),文章的分塊由本 " /> 久久精品全国免费观看国产,波多野结衣最新,日韩精品免费视频

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

基于mysql的bbs設(shè)計(四)

5。版面模塊設(shè)計
  所謂分類,更多的是為telNET服務(wù)端考慮的,在cq66模式下,用戶可以按
照自己的意愿進(jìn)行分類,反正最后都是直接以版為基本單位訪問的。
  對于版面文章的訪問,存放的時候以整篇文章為參數(shù),文章的分塊由本層
完成,如果上層以塊為單位傳送,則在上層全部傳完,組合后,再傳參到本層
分解;在讀取 的時候,本層則以塊為單位訪問,如果上層要以全文為單位訪問
,則在上層做合并 工作,本層不管。
  至于要不要獨(dú)立出索引,不影響上層的操作,主要和下層的數(shù)據(jù)庫構(gòu)造有
關(guān), 主要考慮可行性,效率需求等。
  權(quán)限的檢查放在哪里進(jìn)行呢?還是放在上層吧,其實就telNET服務(wù)器端,
和cq66 的客戶端,根本不會給一般用戶顯示特殊指令的菜單,當(dāng)然,用戶可
以直接發(fā)送cq66 的指令,服務(wù)器方還是要檢查的。但應(yīng)該不用在它下面的功
能模塊層再檢查一次吧
。   Class BoardManage {
  private:

  public:
    // 有關(guān)分類的操作
    int GetClassNameInfo( int maxclass, char **classid,
              char ** classname );
      返回分類的信息,中英文名。
    int GetBoardName( int maxboards, char *classid,
              char **boardname );
      返回某分類中的版面信息,一般分類,直接select ..
      from sboard
      where boardclass == .... 特殊分類則查相應(yīng)的表。。。。

    // 修改需要版面管理員以上的特權(quán)
    int NewClass( char * newclassname, int type );
      新建分類,普通分類還是特殊分類,
    int DeleteClass( char *newclassname );
      刪除分類,但不cascade,即本層不負(fù)責(zé)一致性,由上層負(fù)責(zé)將
      相應(yīng)的版面的分類信息改為別的。分類改名也是先刪再建,
    int AddClassBoard( const char *classname, char *newboardname );
      將已建好的版加入某分類中,專門針對特殊分類,對一般分類,其
      效果和modifyboardinfo一樣,
    int DeleteClassBoard( const char *classname, char *boardname );
      從分類中刪除某個版,也是針對特殊分類,對一般分類,效果也
      是和modifyboardinfo一樣,一個版的分類屬性可以為空,即不屬
      于任何分類。

    // 有關(guān)版的信息的操作。
    int NewBoard( const char *boardid,char *boardname);
      新建一個版,建立對應(yīng)的表。其他參數(shù)取默認(rèn)值。
    int DeleteBoard( const char *boardid );
      刪除一個版,刪除對應(yīng)的表。
    int GetBoardInfo( const char *boardid, char *boardname,
            int& numposts, char *masters, char *class,
            long &level );
      取的版面的信息。
    int ModifyBoardId( const char *oldid, char *newid );
      改變版的英文id,對應(yīng)table的名稱也要改變,
    int ModifyBoardInfo( const char *boardid, char *boardname,
            int numposts, char *masters, char *class,
            long level );
      修改版面信息,需要特權(quán)。

    // 有關(guān)版面文章的操作。
    int AddText( char *boardid, char *title, char *writer,
            char *text );
      往版面中增加文章,內(nèi)部將長文章分割成2k的塊。
    int DeleteText( char *boardid, int num );
      刪除文章,只是做一個標(biāo)記,并不立刻修改對應(yīng)的table。
    int FlushTable( char *boardid );
      刷新版面,刪除被刪文章的對應(yīng)的記錄。
    int MarkText( char *boardid, int num, char mark );
      給文章做標(biāo)記。
    int ModifyTitle( char *boardid, int num, char *newtitle );
      修改文章的標(biāo)題。
    int ModifyText( char *boardid, int num, char *newtext );
      修改文章內(nèi)容,不是自己的文章需要特權(quán)。
    int GetTextInfo( const char *boardid, int num, char *title,
            char *writer, char& mark );
      取得文章的標(biāo)題信息。
    int GetText( const char *boardid, int num, int block,
            char *text );
      讀取文章的內(nèi)容,以塊為單位。

    // 文章和作者的查詢
    // 一次將查詢的結(jié)果全部返回?
    int QueryWriter( const char *boardid, char *writer,
            char **result );
      查詢版面上,某作者的文章。
    int QueryTitle( const char *boardid, char *title,
            char **result );
      查詢版面上,標(biāo)題中包含指定內(nèi)容的文章。
  }
    參數(shù)的傳遞是一件比較討厭的事,從抽象的角度,希望返回的數(shù)據(jù)與
  底層無關(guān),所以應(yīng)該加以處理,但從效率的角度,又不希望數(shù)據(jù)進(jìn)行多次
  復(fù)制,另一方面,空間的申請釋放,究竟是在上層中完成還是在本層中完成
  呢?一不小心,很容易有內(nèi)存錯誤。

php技術(shù)基于mysql的bbs設(shè)計(四),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国语精品视频在线观看不卡 | 精品一区二区三区波多野结衣 | 亚欧美视频 | 黄网站在线观看 | 亚洲午夜小视频 | 91社区在线观看 | 337p亚洲精品色噜噜狠狠 | 玖玖在线国产精品 | 婷婷射 | 亚洲第一页视频 | 午夜免费的国产片在线观看 | 精品国产成人 | 日韩亚洲欧洲在线com91tv | 亚洲精品9999久久久久 | 免费一级毛片不卡不收费 | 特别黄的免费视频大片 | 亚洲毛片视频 | 国产女同一区二区三区五区 | 国产精品合集一区二区三区 | 国产高清国产专区国产精品 | 天天色综合天天 | www色在线 | 精品国产高清自在线一区二区三区 | 免费自拍视频 | 精品久久久影院 | 国产在线播放网站 | 精品一二三区 | 精品国产成人a在线观看 | 亚洲视频国产视频 | 国产美女精品 | 国产真实乱子伦精品 | 国产成人亚洲毛片 | 在线亚洲欧美性天天影院 | 视频一区二区三区在线 | 91精品国产闺蜜国产在线 | 婷婷狠狠 | 色综合五月天 | 国内精品福利在线视频 | 久久久久久久综合日本亚洲 | 婷婷激情亚洲 | 国产精品久久精品福利网站 |