国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:74日期:2023-10-26 16:12:26
5。版面模塊設(shè)計(jì) ;;所謂分類,更多的是為telnet服務(wù)端考慮的,在cq66模式下,用戶可以按 照自己的意愿進(jìn)行分類,反正最后都是直接以版為基本單位訪問的。 ;;對(duì)于版面文章的訪問,存放的時(shí)候以整篇文章為參數(shù),文章的分塊由本層 完成,如果上層以塊為單位傳送,則在上層全部傳完,組合后,再傳參到本層 分解;在讀取 的時(shí)候,本層則以塊為單位訪問,如果上層要以全文為單位訪問 ,則在上層做合并 工作,本層不管。 ;;至于要不要獨(dú)立出索引,不影響上層的操作,主要和下層的數(shù)據(jù)庫構(gòu)造有 關(guān), 主要考慮可行性,效率需求等。 ;;權(quán)限的檢查放在哪里進(jìn)行呢?還是放在上層吧,其實(shí)就telnet服務(wù)器端, 和cq66 的客戶端,根本不會(huì)給一般用戶顯示特殊指令的菜單,當(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 ); ;;;;;;將已建好的版加入某分類中,專門針對(duì)特殊分類,對(duì)一般分類,其 ;;;;;;效果和modifyboardinfo一樣, ;;;;int DeleteClassBoard( const char *classname, char *boardname ); ;;;;;;從分類中刪除某個(gè)版,也是針對(duì)特殊分類,對(duì)一般分類,效果也 ;;;;;;是和modifyboardinfo一樣,一個(gè)版的分類屬性可以為空,即不屬 ;;;;;;于任何分類。 ;;;;// 有關(guān)版的信息的操作。 ;;;;int NewBoard( const char *boardid,char *boardname); ;;;;;;新建一個(gè)版,建立對(duì)應(yīng)的表。其他參數(shù)取默認(rèn)值。 ;;;;int DeleteBoard( const char *boardid ); ;;;;;;刪除一個(gè)版,刪除對(duì)應(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,對(duì)應(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 ); ;;;;;;刪除文章,只是做一個(gè)標(biāo)記,并不立刻修改對(duì)應(yīng)的table。 ;;;;int FlushTable( char *boardid ); ;;;;;;刷新版面,刪除被刪文章的對(duì)應(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ù)制,另一方面,空間的申請(qǐng)釋放,究竟是在上層中完成還是在本層中完成 ;;呢?一不小心,很容易有內(nèi)存錯(cuò)誤。
標(biāo)簽: MySQL 數(shù)據(jù)庫
主站蜘蛛池模板: 纯欧美一级毛片_免费 | 成人在线一区二区 | 久久国产亚洲欧美日韩精品 | 亚洲国产精品久久久久秋霞不卡 | 亚洲天堂网视频 | 欧美成人看片一区二区三区 | 国产久视频 | 日本韩国中文字幕 | 国产在线精品一区二区三区不卡 | 国产精品免费_区二区三区观看 | 99免费在线观看 | 亚洲在线观看视频 | 国产亚洲精品美女一区二区 | 国产成人三级 | 欧美精品日日鲁夜夜添 | 中国老妇色xxxxx | 在线a视频网站 | 国产高清视频在线播放 | 在线观看91精品国产入口 | 亚洲精品精品 | 日韩在线视频免费不卡一区 | 成人毛片18女人毛片免费 | 手机在线免费毛片 | 久久免费观看国产精品 | 日本一在线中文字幕天堂 | 久久久久毛片成人精品 | 在线观看免费视频网站色 | 久久亚洲欧美成人精品 | 欧美大片一级毛片 | 美女视频一区二区三区 | 国产免费爱在线观看视频 | 日本一区二区三区不卡视频中文字幕 | 欧美一级高清片免费一级 | 国产在线精品观看一区 | 久久国产精品免费一区二区三区 | 久久精品福利视频 | 黄色网址视频在线观看 | 日韩免费一级片 | 老色歌uuu26| 在线观看免费亚洲 | 一级高清毛片免费a级高清毛片 |