南瓜籽_ 2023-03-03 13:27:52
祝大家天天开心,代码无bug
...全文
成就一亿技术人!
拼手气红包 5.00元
787 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
{ *********************************************************************** }{ }{ Copular Chat Server and Client v3.0 Source Code }{ }{ Copyright (c) 1998-2002 SAF Studio }{ }{ Author : Niu Yu Ping }{ Nickname: DecimalOX }{ Address : Jilin City China }{ }{ QICQ : 103106262 }{ Homepage: www.safree.com }{ EMail : decimalox@sohu.com }{ }{ *********************************************************************** }解压完毕后,您可以先运行Server目录下的Server.exe和Client目录下的Client.exe来看一下效果。我提供了下面四个可以使用的帐号: 用户名  密码 aaa aaa ddd ddd decimalox decimalox 爱心 love由于没有完成用户注册功能,所以只能手工创建用户文件才可以增加新用户。目录--  程序简介  开发环境  相关工具  未能完成的部分  使用方法  作者简介  作者的话程序简介----  Copular Chat v3.0是我在今年4月份完成的,原本是为朋友的设计的实景聊天系统,但由于种种原因最终未能发布。之所以它的版本为3.0,是因为在那之前我也为东北电力学院制作过两个文字聊天系统Copular Chat v1.0和Copular Chat v2.0。其中的第一个版本由于设计上的失误,服务器程序经常由于资源耗尽而挂掉。而第二版本是为了修补第一个版本的bug而制作的。在重新设计编写了通信协议与内核服务程序之后,虽然资源使用的问题得以解决,但在功能上仍无法与当时流行的聊天系统ichat相抗衡,所以一直在校园网上使用,没有对外公布。我也由于事情太多,基本停止了这一系列软件的开发和更新。直到2002年初的时候,几个朋友请我为他们的网站开发一款类似于kele8实影聊天室的聊天系统,于是我开发了新的聊天系统。虽然新的系统在设计思路与使用方式上完全不同于Copular Chat的前两个版本,但为了保持个人作品的连贯性,我还是将其命名为CopularChat v3.0。天有不测风云,一些意外的事情使得这个聊天系统最终未能完成。我公开源代码的目的,就是希望广大编程爱好者可以继续完善它,使其不至夭折。就算我的心愿无法达成,如果能看到朋友们通过我的代码得到我的经验、有所收获,我也会非常高兴。开发环境----K6-2 400MHz 128M 启亨Tnt2 M64 Delphi7 企业版, DirectX 8.1, Photoshop 6.0中文版相关工具----DelphiX, DelphiX plus, AHM 2000, KsDev SkinEngine, FatMemo, RX以上皆为Delphi环境下的第三方控件,可以在解压缩后的Components目录中找到。在安装时,请选择支持版本最高的组件包安装。例:ComponentsDelphiXSource目录下有DelphiX_For3、DelphiX_For4、DelphiX_For5三个.dpk文件,此时应选择DelphiX_for5.dpk进行编译安装。注意:虽然DelphiX_for5原本是为Delphi5设计的,但我已经修改其中一些代码,使之适用于Delphi6以上版本,而且只能用于Delphi6以上版本。另外,AHM 2000的一些组件包可能无法在Delphi6以上版本中使用。在Copular Chat v3.0源代码中,我们只使用了Stardand和Enhanced两个组件包,使用时只需要安装这两个组件包即可。如果高级开发者打算修改地图资源或一些调用函数,可能还需要以下一些工具配合DelphiX使用的地图编辑器MapEdit,可以在DelphiX组件的目录中找到为DelphiX生成资源库的ImageLibaryBuilder,可以在DelphiX组件的目录中找到如果重新编译组件包,可能还需要DesignIntf.pas、DesignEditors.pas两件文件。这两个文件可以在Components目录下找到,也可以在Delphi6或Delphi7的安装目录下的SourceToolApi目录中找到。未能完成的部分-------源代码的以下部分未能完成用户信息注册部分,用来为新用户提供注册服务用户信息更新部分,用来为老用户提供修改个人信息的服务还有以下bug未能清除在98下运行时与显示相关的一些bugSocket连接的一些bug使用方法----下载压缩包后将其解压到一个目录后,此目录下应该包含以下目录和文件Server目录存放服务器源程序Client目录存放客户端源程序Core目录存放核心库程序,此目录下的单元会被Server和Client引用,非常重要Components目录存放开发时需要的组件CopularChat3.bpg文件为项目文件,直接用Delphi打开此文件即可装入Server和Client源程序在打开源程序之前,请先安装Components目录下的所有组件,这些组件原本是为不同版本的Delphi设计编写的。我对其中的一些组件源文件进行了修改,使之可以在Delphi6以上的版中使用。因此,如果请没有丰富的开发经验,请尽量安装Delphi6以上的版本,这样可以避免组件无法安装的问题。作者简介----牛宇平 男 1979年12月14日出生长像勉强对得起观众,身高173厘米(穿鞋174),体重64公斤,属于苗条型。生性乐观开郎大方,a little bad ,a little shy “)。现就读于东北电力学院2002年成为自由软件开发者,没什么收入,但活得很开心。2001年3月份供职于北京市政府外事信息。2000年11月通过国家程序员考试,2001年10月的高级程序员考试上午成绩差一分,不幸挂掉。2002年再考高级程序员,虽然成绩还没出来,但估计上午成绩又将再劫难逃。也难怪,天天不是玩就是写程序,哪有时间背书。2000年为东北电力学院信息中心开发校园网聊天系统。1999为吉林市安必升公司(一家业务类似于传销的商务公司)开发财务结算软件,就是那种根据谁是谁上线,谁是谁直接下线,谁是谁间接下线....来计算个人和公司收益的软件。(绝对高难度,考验算法、数据结构、数理统计和分析以及理解能力·#%#¥%臭吹)。1998年获得吉林市第一界电脑明星大赛软件设计类二等奖。1997年获吉林省信息学竞赛第十名,吉林省电子技术学校(中专)C语言竞争第一名....还有一些,记不清了1997年以没什么好说的,还处于天天与代码为伍的阶段,没做过什么。1997---2002年间还有很多自认为非常好的作品,但大多都没有发布,只流传于朋友圈子里。作者的话----  从16岁开始写程序,写到现在,7年多了,从未感觉到辛苦。看到那种多人在叫喊着苦呀累呀,心里就替他们悲哀。这些里,一些人是真的累了,一些人却是在做秀。总有一种不敢说出口的感觉,成为我前进的动力。也曾和一些朋友们说起,他们却说我疯了,因为我告诉他们“code is my wife”,别怀疑,是wife不是life。我一直把写程序当做与自己最亲密的人在交流,她有感情有生命。我可以自己的行为影响她改变她,她也可以用她的行为影响我改变我;她可以用自己的方式来表达自己的喜努哀乐,可以发脾气、使性子;她可以为我带来欢乐,也可以使我惆怅.....也许是一个人生活久了,总要找些寄托。朋友劝我去看心理医生,可我却不想,因为我知道,这只是一种感觉,一种久违的感觉而已。  请不要害怕,我的心理绝对正常。我会整夜与代码为相伍,但我仍会通宵搓麻,仍会喝酒唱歌,仍会侃山吹牛,仍会游泳打球.....我是一个乐观上进、充满活力的人。  曾几何时,周围的人们都用起了电脑,谈论起IT,我曾欣喜的等待着交流与梦想。然而,随之而来却是更多的自私、漫骂、欺诈、无耻、傲慢和排挤,这便是一些中国programmer的真实写照。我失望、悲伤、痛恨,又有什么用。我不敢说自己可以改变世界,但我敢说理解、交流和帮助一定可以改变这个世界,这个已经铜臭味十足的coding世界。我渴望理解,愿意勾通和交流,愿意帮助需要帮助朋友。  那些毕竟只是阴暗的东西,毕竟还有那么多真诚的朋友在为信念而奋斗,正是因为他们,这个世界才会如此美好。  我诅咒阴险的人们遭到报应,我福善良的人们永远快乐,永远幸福。  ......很不好意思把这次机会做为了自己发泄的途径,作为补偿,向大家推荐一部激动人心的美国大片《Armageddon》(绝世天劫),希望没有看过的朋友一定要看看,扣人心弦、气势磅礴。2002年10月23日 牛宇平 于 中国吉林
导入/导出是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为Exp/Imp是一种好的备份方式,正确的说法是Exp/Imp只能是一个好的转储工具,特别是在小型数据库的转储,表空间的迁移,表的抽取,检测逻辑和物理冲突等中有不小的功劳。当然,我们也可以把它作为小型数据库的物理备份后的一个逻辑辅助备份,也是不错的建议。对于越来越大的数据库,特别是TB级数据库和越来越多数据仓库的出现,EXP/IMP越来越力不从心了,这个时候,数据库的备份都转向了RMAN和第三方工具。下面说明一下EXP/IMP的使用。   如何使exp的帮助以不同的字符集显示:set nls_lang=simplified chinese_china.zhs16gbk,通过设置环境变量,可以让exp的帮助以中文显示,如果set nls_lang=American_america.字符集,那么帮助就是英文的了 程序代码EXP的所有参数(括号中为参数的默认值): USERID 用户名/口令 如: USERID=duanl/duanl FULL 导出整个数据库 (N) BUFFER 数据缓冲区的大小 OWNER 所有者用户名列表,你希望导出哪个用户的对象,就用owner=username FILE 输出文件 (EXPDAT.DMP) TABLES 表名列表 ,指定导出的table名称,如:TABLES=table1,table2 COMPRESS 导入一个extent (Y) RECORDLENGTH IO 记录的长度 GRANTS 导出权限 (Y) INCTYPE 增量导出类型 INDEXES 导出索引 (Y) RECORD 跟踪增量导出 (Y) ROWS 导出数据行 (Y) PARFILE 参数文件名,如果你exp的参数很多,可以存成参数文件. CONSTRAINTS 导出约束 (Y) CONSISTENT 交叉表一致性 LOG 屏幕输出的日志文件 STATISTICS 分析对象 (ESTIMATE) DIRECT 直接路径 (N) TRIGGERS 导出触发器 (Y) FEEDBACK 显示每 x 行 (0) 的进度 FILESIZE 各转储文件的最大尺寸 QUERY 选定导出表子集的子句 下列关键字仅用于可传输的表空间 TRANSPORT_TABLESPACE 导出可传输的表空间元数据 (N) TABLESPACES 将传输的表空间列表 程序代码IMP的所有参数(括号中为参数的默认值): USERID 用户名/口令 FULL 导入整个文件 (N) BUFFER 数据缓冲区大小 FROMUSER 所有人用户名列表 FILE 输入文件 (EXPDAT.DMP) TOUSER 用户名列表 SHOW 只列出文件内容 (N) TABLES 表名列表 IGNORE 忽略创建错误 (N) RECORDLENGTH IO 记录的长度 GRANTS 导入权限 (Y) INCTYPE 增量导入类型 INDEXES 导入索引 (Y) COMMIT 提交数组插入 (N) ROWS 导入数据行 (Y) PARFILE 参数文件名 LOG 屏幕输出的日志文件 CONSTRAINTS 导入限制 (Y) DESTROY 覆盖表空间数据文件 (N) INDEXFILE 将表/索引信息写入指定的文件 SKIP_UNUSABLE_INDEXES 跳过不可用索引的维护 (N) ANALYZE 执行转储文件中的 ANALYZE 语句 (Y) FEEDBACK 显示每 x 行 (0) 的进度 TOID_NOVALIDATE 跳过指定类型 id 的校验 FILESIZE 各转储文件的最大尺寸 RECALCULATE_STATISTICS 重新计算统计值 (N) 下列关键字仅用于可传输的表空间 TRANSPORT_TABLESPACE 导入可传输的表空间元数据 (N) TABLESPACES 将要传输到数据库的表空间 DATAFILES 将要传输到数据库的数据文件 TTS_OWNERS 拥有可传输表空间集中数据的用户 关于增量参数的说明:exp/imp的增量并不是真正意义上的增量,所以最好不要使用。 使用方法: Exp parameter_name=value or Exp parameter_name=(value1,value2……) 只要输入参数help=y就可以看到所有帮助. EXP常用选项 1.FULL,这个用于导出整个数据库,在ROWS=N一起使用时,可以导出整个数据库的结构。例如: exp userid=test/test file=./db_str.dmp log=./db_str.log full=y rows=n compress=y direct=y 2. OWNER和TABLE,这两个选项用于定义EXP的对象。OWNER定义导出指定用户的对象;TABLE指定EXP的table名称,例如: exp userid=test/test file=./db_str.dmp log=./db_str.log owner=duanl exp userid=test/test file=./db_str.dmp log=./db_str.log table=nc_data,fi_arap 3.BUFFER和FEEDBACK,在导出比较多的数据时,我会考虑设置这两个参数。例如: exp userid=test/test file=yw97_2003.dmp log=yw97_2003_3.log feedback=10000 buffer=100000000 tables=WO4,OK_YT 4.FILE和LOG,这两个参数分别指定备份的DMP名称和LOG名称,包括文件名和目录,例子见上面。 5.COMPRESS参数不压缩导出数据的内容。用来控制导出对象的storage语句如何产生。默认值为Y,使用默认值,对象的存储语句的init extent等于当前导出对象的extent的总和。推荐使用COMPRESS=N。 6. FILESIZE该选项在8i中可用。如果导出的dmp文件过大时,最好使用FILESIZE参数,限制文件大小不要超过2G。如: exp userid=duanl/duanl file=f1,f2,f3,f4,f5 filesize=2G owner=scott 这样将创建f1.dmp, f2.dmp等一系列文件,每个大小都为2G,如果导出的总量小于10G EXP不必创建f5.bmp. IMP常用选项 1、FROMUSER和TOUSER,使用它们实现将数据从一个SCHEMA中导入到另外一个SCHEMA中。例如:假设我们做exp时导出的为test的对象,现在我们想把对象导入用户: imp userid=test1/test1 file=expdat.dmp fromuser=test1 touser=test1 2、IGNORE、GRANTS和INDEXES,其中IGNORE参数将忽略表的存在,继续导入,这个对于需要调整表的存储参数时很有用,我们可以先根据实际情况用合理的存储参数建好表,然后直接导入数据。而GRANTS和INDEXES则表示是否导入授权和索引,如果想使用新的存储参数重建索引,或者为了加快到入速度,我们可以考虑将INDEXES设为N,而GRANTS一般都是Y。例如:imp userid=test1/test1 file=expdat.dmp fromuser=test1 touser=test1 indexes=N 表空间传输 表空间传输是8i新增加的一种快速在数据库间移动数据的一种办法,是把一个数据库上的格式数据文件附加到另外一个数据库中,而不是把数据导出成Dmp文件,这在有些时候是非常管用的,因为传输表空间移动数据就象复制文件一样快。 关于传输表空间有一些规则,即: ·源数据库和目标数据库必须运行在相同的硬件平台上。 ·源数据库与目标数据库必须使用相同的字符集。 ·源数据库与目标数据库一定要有相同大小的数据块 ·目标数据库不能有与迁移表空间同名的表空间 ·SYS的对象不能迁移 ·必须传输自包含的对象集 ·有一些对象,如物化视图,基于函数的索引等不能被传输 可以用以下的方法来检测一个表空间或一套表空间是否符合传输标准: exec sys.dbms_tts.transport_set_check(‘tablespace_name’,true); select * from sys.transport_set_violation; 如果没有行选择,表示该表空间只包含表数据,并且是自包含的。对于有些非自包含的表空间,如数据表空间和索引表空间,可以一起传输。 以下为简要使用步骤,如果想参考详细使用方法,也可以参考ORACLE联机帮助。 1.设置表空间为只读(假定表空间名字为APP_Data 和APP_Index) alter tablespace app_data read only; alter tablespace app_index read only; 2.发出EXP命令 SQL>host exp userid=”””sys/password as sysdba””” transport_tablespace=y tablespace=(app_data, app_index) 以上需要注意的是 ·为了在SQL中执行EXP,USERID必须用三个引号,在UNIX中也必须注意避免“/”的使用 ·在816和以后,必须使用sysdba才能操作 ·这个命令在SQL中必须放置在一行(这里是因为显示问题放在了两行) 3.拷贝数据文件到另一个地点,即目标数据库 可以是cp(unix)或copy(windows)或通过ftp传输文件(一定要在bin方式) 4.把本地的表空间设置为读写 5.在目标数据库附加该数据文件 imp file=expdat.dmp userid=”””sys/password as sysdba””” transport_tablespace=y “datafile=(c:\temp\app_data,c:\temp\app_index)” 6.设置目标数据库表空间为读写 alter tablespace app_data read write; alter tablespace app_index read write; 优化EXP/IMP的方法: 当需要exp/imp的数据量比较大时,这个过程需要的时间是比较长的,我们可以用一些方法来优化exp/imp的操作。 exp:使用直接路径 direct=y oracle会避开sql语句处理引擎,直接从数据库文件中读取数据,然后写入导出文件. 可以在导出日志中观察到: exp-00067: table xxx will be exported in conventional path 如果没有使用直接路径,必须保证buffer参数的值足够大. 有一些参数于direct=y不兼容,无法用直接路径导出可移动的tablespace,或者用query参数导出数据库子集. 当导入导出的数据库运行在不同的os下时,必须保证recordlength参数的值一致. imp:通过以下几个途径优化 1.避免磁盘排序 将sort_area_size设置为一个较大的值,比如100M 2.避免日志切换等待 增加重做日志组的数量,增大日志文件大小. 3.优化日志缓冲区 比如将log_buffer容量扩大10倍(最大不要超过5M) 4.使用阵列插入与提交 commit = y 注意:阵列方式不能处理包含LOB和LONG类型的表,对于这样的table,如果使用commit = y,每插入一行,就会执行一次提交. 5.使用NOLOGGING方式减小重做日志大小 在导入时指定参数indexes=n,只导入数据而忽略index,在导完数据后在通过脚本创建index,指定 NOLOGGING选项 导出/导入与字符集 进行数据的导入导出时,我们要注意关于字符集的问题。在EXP/IMP过程中我们需要注意四个字符集的参数:导出端的客户端字符集,导出端数据库字符集,导入端的客户端字符集,导入端数据库字符集。 我们首先需要查看这四个字符集参数。 查看数据库的字符集的信息: SQL> select * from nls_database_parameters; PARAMETER VALUE ------------------------------ -------------------------------------------------------------------------------- NLS_LANGUAGE AMERICAN NLS_TERRITORY AMERICA NLS_CURRENCY $ NLS_ISO_CURRENCY AMERICA NLS_NUMERIC_CHARACTERS ., NLS_CHARACTERSET ZHS16GBK NLS_CALENDAR GREGORIAN NLS_DATE_FORMAT DD-MON-RR NLS_DATE_LANGUAGE AMERICAN NLS_SORT BINARY NLS_TIME_FORMAT HH.MI.SSXFF AM NLS_TIMESTAMP_FORMAT DD-MON-RR HH.MI.SSXFF AM NLS_TIME_TZ_FORMAT HH.MI.SSXFF AM TZH:TZM NLS_TIMESTAMP_TZ_FORMAT DD-MON-RR HH.MI.SSXFF AM TZH:TZM NLS_DUAL_CURRENCY $ NLS_COMP BINARY NLS_NCHAR_CHARACTERSET ZHS16GBK NLS_RDBMS_VERSION 8.1.7.4.1 NLS_CHARACTERSET:ZHS16GBK是当前数据库的字符集。 我们再来查看客户端的字符集信息: 客户端字符集的参数NLS_LANG=_< territory >. language:指定oracle消息使用的语言,日期中日和月的显示。 Territory:指定货币和数字的格式,地区和计算星期及日期的习惯。 Characterset:控制客户端应用程序使用的字符集。通常设置或等于客户端的代码页。或者对于unicode应用设为UTF8。 在windows中,查询和修改NLS_LANG可在注册表中进行: HKEY_LOCAL_MACHINE\SOFTWARE\Oracle\HOMExx\ xx指存在多个Oracle_HOME时的系统编号。 在unix中: $ env|grep NLS_LANG NLS_LANG=simplified chinese_china.ZHS16GBK 修改可用: $ export NLS_LANG=AMERICAN_AMERICA.UTF8 通常在导出时最好把客户端字符集设置得和数据库端相同。当进行数据导入时,主要有以下两种情况: (1) 源数据库和目标数据库具有相同的字符集设置。 这时,只需设置导出和导入端的客户端NLS_LANG等于数据库字符集即可。 (2) 源数据库和目标数据库字符集不同。 先将导出端客户端的NLS_LANG设置成和导出端的数据库字符集一致,导出数据,然后将导入端客户端的NLS_LANG设置成和导出端一致,导入数据,这样转换只发生在数据库端,而且只发生一次。 这种情况下,只有当导入端数据库字符集为导出端数据库字符集的严格超集时,数据才能完全导成功,否则,可能会有数据不一致或乱码出现。 不同版本的EXP/IMP问题 一般来说,从低版本导入到高版本问题不大,麻烦的是将高版本的数据导入到低版本中,在Oracle9i之前,不同版本Oracle之间的EXP/IMP可以通过下面的方法来解决: 1、在高版本数据库上运行底版本的catexp.sql; 2、使用低版本的EXP来导出高版本的数据; 3、使用低版本的IMP将数据库导入到低版本数据库中; 4、在高版本数据库上重新运行高版本的catexp.sql脚本。 但在9i中,上面的方法并不能解决问题。如果直接使用低版本EXP/IMP会出现如下错误: EXP-00008: orACLE error %lu encountered orA-00904: invalid column name 这已经是一个公布的BUG,需要等到Oracle10.0才能解决,BUG号为2261722,你可以到METALINK上去查看有关此BUG的详细信息。 BUGBUG,我们的工作还是要做,在没有Oracle的支持之前,我们就自己解决。在Oracle9i中执行下面的SQL重建exu81rls视图即可。 Create or REPLACE view exu81rls (objown,objnam,policy,polown,polsch,polfun,stmts,chkopt,enabled,spolicy) AS select u.name, o.name, r.pname, r.pfschma, r.ppname, r.pfname, decode(bitand(r.stmt_type,1), 0,'', 'Select,') || decode(bitand(r.stmt_type,2), 0,'', 'Insert,') || decode(bitand(r.stmt_type,4), 0,'', 'Update,') || decode(bitand(r.stmt_type,8), 0,'', 'Delete,'), r.check_opt, r.enable_flag, DECODE(BITAND(r.stmt_type, 16), 0, 0, 1) from user$ u, obj$ o, rls$ r where u.user# = o.owner# and r.obj# = o.obj# and (uid = 0 or uid = o.owner# or exists ( select * from session_roles where role='Select_CATALOG_ROLE') ) / grant select on sys.exu81rls to public; / 可以跨版本的使用EXP/IMP,但必须正确地使用EXP和IMP的版本: 1、总是使用IMP的版本匹配数据库的版本,如:要导入到817中,使用817的IMP工具。 2、总是使用EXP的版本匹配两个数据库中最低的版本,如:从9201往817中导入,则使用817版本的EXP工具。 例子 exp system/manager@mydb file=my.dmp log=20020101.log owner=scott exp 用户名/密码@服务名 file=c:\fr_yusnhu.dmp ower=用户 exp fr_yunshu/fr_yunshu@orcl file=d:\fr_yunshu.dmp owner=fr_yunshu exp system/manager@orcl file=111.dmp log=111.log direct=y compress=y feedback=10000 exp nc50/1 inctype=complete file=E:\data.dmp full=y(导出全部) exp nc50/1 file=E:\data.dmp OWNER = nc50(导出指定用户nc50) imp nc50/1@orcl inctype=complete file=E:\data.dmp full=Y(导入全部) imp nc50/1@orcl file=E:\data.dmp fromuser=nc50 touser=nc50(导入指定用户nc50)

319

社区成员

发帖
与我相关
我的任务
社区描述
除非我不想赢,否则没人能让我输.
java后端 个人社区
社区管理员
  • 南瓜籽_
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧