DELPHI基础教程:Delphi客户服务器应用开发(二)[3]

DELPHI基础教程:Delphi客户服务器应用开发(二)[3],第1张

  配置SQL环境

 与你的BDE应用程序一起安装的有BDE配置工具(BDECFG EXE) 该工具帮助用户修改他们的应用程序配置 配置参数被存于命名为IDAPI CFG的二进制文件中 当应用程序启动时 将读这个文件 通常该文件在应用安装过程中被置于BDE文件目录中(C:\Program Files\Common\BDE)

 本节描述怎样使用BDE配置工具设置应用程序的SQL环境 一旦配置好BDE应用环境 就可开始联接网络 并访问SQL服务器

 关于怎样使用BDE配置工具的详细介绍 可参见BDE用户指南或按运行BDE配置工具选择Help按钮显示在线帮助

 在开始配置SQL环境前 必须已完成以下工作

 ● 已安装SQL Links软件

 ● 退出所有其它Borland应用程序

 ● 在Windows 中打开应用程序组Borland Delphi

 ● 选择IDAPI配置工具图标 出现配置工作窗口后进入驱动程序管理页

  配置SQL Link驱动程序缺省设置的方法

 SQL Link驱动程序缺省设置是指在BDE配置工具的Drivers页中的参数设置 这些参数在建立新的Alias中使用 Alias是描述网络资源的一组参数的集合 BDE应用使用Alias 联接共享数据库 Alias对于访问局部数据库并不是必要的 但要访问SQL数据库 却是必不可少

 SQL Links驱动程序的缺省设置 是你建立新的Alias 的原型 尽管你在建立Alias后能定制它 但在建立新的Alias前设置相应的缺省设置要来的容易 因为这样建立的每一个Alias将继承这些设置

 要描述驱动程序的缺省设置 要完成以下几项

 ● 将亮条移到驱动程序的入口 驱动程序管理程序显示所有的该驱动程序的配置参数 在参数列表表端可用滚行杠检察各配置参数

 ● 如果需要编辑驱动程序的缺省配置参数 如果光标停在这格 配置工作将自动套用缺省参数

 ● 当完成这些工作 选择File|Save 修改将在应用程序下一次启动时生效

  SQL Links驱动程序的缺省设置项目的含义

  VERSION

 SQL Links驱动程序的版本号

  TYPE

 描述当前驱动程序类型 SERVER就表示该驱动程序用于连接一个SQL服务器 FILE就表示驱动程序用于连接一个标准的基于文件服务器

  DLL选项

 所选SQL Links的 位驱动程序的动态链接库名

  DLL

 所选SQL Links的 位驱动程序的动态链接库名

  DRIVER FIAGS

 内部的产品描述标志

  TRACE MODE

 描述记录跟踪信息的类型

  SERVER NAME

 指定目标SQL服务器名 如果指定为InterBase服务器 将包含数据库文件的全部路径 Servername:/Usr/gds/directoryname/databasenam gdb

  USER NAME

 访问SQL服务器的缺省用户名

  OPENMODE

 OPENMODE是SQL Links打开SQL数据库时的读写模式 取值可以是READ/WRITE或READ ONLY 缺省值是READ/WRITE 把OPEN MODE设为READ ONLY 将影响用户端的操作 但对SQL服务器没有影响

  SCHEMA CACHE SIZE

 描述被贮存视图信息的SQL表个数 取值范围是 缺省值为

  LANGDRIVER

 用来操作来自SQL 服务器的数据的语言驱动程序 当光标停止LANGDRIVER域时 一个滚行框出现在正文域的左侧 用滚行杠可以用于你的驱动程序的可选的语言列表 如使用美国英语 该缺省值是空格

 当描述的语言驱动程序与一个服务器别名相适应 那么你的应用程序将使用该驱动程序处理从服务器发来的数据 这包括你察看的所有表和所有查询返回的结果表 运行在不同系统上的服务器利用字符集的转换来决定怎样对数据编码 如果你操作在非英语环境 你的BDE应用程序可以使用不同于SQL服务器的字符集 如果你的平台上的字符集同SQL服务器上的不匹配 那么在两种不同平台间传递数据将引起下列问题

 ● 数据在你的平台上不正确的显示

 ● SQL数据库上将记录错误的字符

 为防止这种情况的出现 SQL Links提供语言驱动程序 实现你的应用程序的字符集与SQL数据库的字符集的数据转换 这将使从SQL服务器传来的数据在你的平台上正确显示 或将你输入的数据可靠地传送到服务器上

 语言驱动程序包含有关排序和大小写转换的信息 无论何时 对SQL数据库的查询按本地数据库的规则处理应用程序的语言驱动程序用于评测排序的字符范围 如果平台上的排序和大小写转换与SQL服务器上的不同 你的应用程序就会显示不一致的结果

 如果SQL数据库使用扩展字符集 请确信用于访问SQL 服务的别名中描述正确的 SQL Links语言版本选择的驱动程序的字符集应当与SQL服务器的相同 如果你没有找到合适的SQL Links语言驱动 你可修改别名中的SQLQRYMODE入口 防止按局部数据库规则处理查询

  SQLPASSTHRU MODE

 描述应用程序访问SQL服务器时是否借助平台命令和传递式SQL 取值范围和它们的含义列于下表

 表 SQLPASSTHRU MODE设置

 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

 设置            含 义

 ──────────────────────────────────────

 NOT SHARED    传递SQL和非传递性SQL不共享相同的连接

 SHARED AUTOMIT  缺省值 传递SQL和非传递SQL将共享相同连接 传递式SQL将以与非传递SQL相似的方式动作 也就说用户的传递式SQL表达式将被自动提交

 SHARED NOAUTOMIT 传递式SQL和非传递式SQL将共享同一个连接 但SQL驱动程序并不自动提交SQL表达式 在这种模式下 传递行为是服务器独立的

 ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

 SHARED AUTOMIT和SHARED NOAUTOMIT 模式并不支持所有的传递式表达式 当SHARED AUTOMIT或SHARED NOAUTOMIT模式被设置 在传递式SQL中不需执行事务控制语言 使用你的BDE应用编程语言来开始 提交回送事务 当传递式SQL和非传递式SQL共享一个连接 记录快存并不立即反映传递SQL操作的更新

lishixinzhi/Article/program/Delphi/201311/25134

很多同学接触Linux不多,对Linux平台的开发更是一无所知。而现在的趋势越来越表明,作为一个优秀的软件开发人员,或计算机IT行业从业人员,掌握Linux是一种很重要的谋生资源与手段。下来我将会结合自己的几年的个人开发经验,及对Linux,更是类UNIX系统,及开源软件文化,谈谈Linux的学习方法与学习中应该注意的一些事。

就如同刚才说的,很多同学以前可能连Linux是什么都不知道,对UNIX更是一无所知。所以我们从最基础的讲起,对于Linux及UNIX的历史我们不做多谈,直接进入入门的学习。

Linux入门是很简单的,问题是你是否有耐心,是否爱折腾,是否不排斥重装一类的大修。没折腾可以说是学不好Linux的,鸟哥说过,要真正了解Linux的分区机制,对LVM使用相当熟练,没有20次以上的Linux装机经验是积累不起来的,所以一定不要怕折腾。

由于大家之前都使用Windows,所以我也尽可能照顾这些“菜鸟”。我的推荐,如果你第一次接触Linux,那么首先在虚拟机中尝试它。虚拟机我推荐VirtualBox,我并不主张使用VM,原因是VM是闭源的,并且是收费的,我不希望推动盗版。当然如果你的Money足够多,可以尝试VM,但我要说的是即使是VM,不一定就一定好。付费的软件不一定好。首先,VirtualBox很小巧,Windows平台下安装包在80MB左右,而VM动辄600MB,虽然功能强大,但资源消耗也多,何况你的需求VirtualBox完全能够满足。所以,还是自己选。如何使用虚拟机,是你的事,这个我不教你,因为很简单,不会的话Google或Bai都可以,英文好的可以直接看官方文档。

现在介绍Linux发行版的知识。正如你所见,Linux发行版并非Linux,Linux仅是指操作系统的内核,作为科班出生的你不要让我解释,我也没时间。我推荐的发行版如下:

UBUNTU适合纯菜鸟,追求稳定的官方支持,对系统稳定性要求较弱,喜欢最新应用,相对来说不太喜欢折腾的开发者。

Debian,相对UBUNTU难很多的发行版,突出特点是稳定与容易使用的包管理系统,缺点是企业支持不足,为社区开发驱动。

Arch,追逐时尚的开发者的首选,优点是包更新相当快,无缝升级,一次安装基本可以一直运作下去,没有如UBUNTU那样的版本概念,说的专业点叫滚动升级,保持你的系统一定是最新的。缺点显然易见,不稳定。同时安装配置相对Debian再麻烦点。

Gentoo,相对Arch再难点,考验使用者的综合水平,从系统安装到微调,内核编译都亲历亲为,是高手及黑客显示自己技术手段,按需配置符合自己要求的系统的首选。

Slackware与Gentoo类似。

CentOS,社区维护的RedHat的复刻版本,完全使用RedHat的源码重新编译生成,与RedHat的兼容性在理论上来说是最好的。如果你专注于Linux服务器,如网络管理,架站,那么CentOS是你的选择。

LFS,终极黑客显摆工具,完全从源代码安装,编译系统。安装前你得到的只有一份文档,你要做的就是照文档你的说明,一步步,一条条命令,一个个软件包的去构建你的Linux,完全由你自己控制,想要什么就是什么。如果你做出了LFS,证明你的Linux功底已经相当不错,如果你能拿LFS文档活学活用,再将Linux从源代码开始移植到嵌入式系统,我敢说中国的企业你可以混的很好。

你得挑一个适合你的系统,然后在虚拟机安装它,开始使用它。如果你想快速学会Linux,我有一个建议就是忘记图形界面,不要想图形界面能不能提供你问题的答案,而是满世界的去找,去问,如何用命令行解决你的问题。在这个过程中,你最好能将Linux的命令掌握的不错,起码常用的命令得知道,同时建立了自己的知识库,里面是你积累的各项知识。

再下个阶段,你需要学习的是Linux平台的C/C开发,同时还有Bash脚本编程,如果你对Java兴趣很深还有Java。同样,建议你抛弃掉图形界面的IDE,从VIM开始,为什么是VIM,而不是Emacs,我无意挑起编辑器大战,但我觉得VIM适合初学者,适合手比较笨,脑袋比较慢的开发者。Emacs的键位太多,太复杂,我很畏惧。然后是GCC,Make,Eclipse(Java,C或者)。虽然将C列在了Eclipse中,但我并不推荐用IDE开发C,因为这不是Linux的文化,容易让你忽略一些你应该注意的问题。IDE让你变懒,懒得跟猪一样。如果你对程序调试,测试工作很感兴趣,GDB也得学的很好,如果不是GDB也是必修课。这是开发的第一步,注意我并没有提过一句Linux系统API的内容,这个阶段也不要关心这个。你要做的就是积累经验,在Linux平台的开发经验。我推荐的书如下:C语言程序设计,谭浩强的也可以。C语言,白皮书当然更好。C推荐CPrimerPlus,Java我不喜欢,就不推荐了。工具方面推荐VIM的官方手册,GCC中文文档,GDB中文文档,GNU开源软件开发指导(电子书),汇编语言程序设计(让你对库,链接,内嵌汇编,编译器优化选项有初步了解,不必深度)。

如果你这个阶段过不了就不必往下做了,这是底线,最基础的基础,否则离开,不要霍霍Linux开发。不专业的Linux开发者作出的程序是与Linux文化或UNIX文化相背的,程序是走不远的,不可能像Bash,VIM这些神品一样。所以做不好干脆离开。

接下来进入Linux系统编程,不二选择,APUE,UNIX环境高级编程,一遍一遍的看,看10遍都嫌少,如果你可以在大学将这本书翻烂,里面的内容都实践过,有作品,你口头表达能力够强,你可以在面试时说服所有的考官。(可能有点夸张,但APUE绝对是圣经一般的读物,即使是Windows程序员也从其中汲取养分,Google创始人的案头书籍,扎尔伯克的床头读物。)

这本书看完后你会对Linux系统编程有相当的了解,知道Linux与Windows平台间开发的差异在哪?它们的优缺点在哪?我的总结如下:做Windows平台开发,很苦,微软的系统API总在扩容,想使用最新潮,最高效的功能,最适合当前流行系统的功能你必须时刻学习。Linux不是,Linux系统的核心API就100来个,记忆力好完全可以背下来。而且经久不变,为什么不变,因为要同UNIX兼容,符合POSIX标准。所以Linux平台的开发大多是专注于底层的或服务器编程。这是其优点,当然图形是Linux的软肋,但我站在一个开发者的角度,我无所谓,因为命令行我也可以适应,如果有更好的图形界面我就当作恩赐吧。另外,Windows闭源,系统做了什么你更本不知道,永远被微软牵着鼻子跑,想想如果微软说Win8不支持QQ,那腾讯不得哭死。而Linux完全开源,你不喜欢,可以自己改,只要你技术够。另外,Windows虽然使用的人多,但使用场合单一,专注与桌面。而Linux在各个方面都有发展,尤其在云计算,服务器软件,嵌入式领域,企业级应用上有广大前景,而且兼容性一流,由于支持POSIX可以无缝的运行在UNIX系统之上,不管是苹果的Mac还是IBM的AS400系列,都是完全支持的。另外,Linux的开发环境支持也绝对是一流的,不管是C/C,Java,Bash,Python,PHP,Javascript,。就连C#也支持。而微软除VisualStdio套件以外,都不怎么友好,不是吗?

如果你看完APUE的感触有很多,希望验证你的某些想法或经验,推荐UNIX程序设计艺术,世界顶级黑客将同你分享他的看法。

现在是时候做分流了。大体上我分为四个方向:网络,图形,嵌入式,设备驱动。

如果选择网络,再细分,我对其他的不是他熟悉,只说服务器软件编写及高性能的并发程序编写吧。相对来说这是网络编程中技术含量最高的,也是底层的。需要很多的经验,看很多的书,做很多的项目。

我的看法是以下面的顺序来看书:

APUE再深读_尤其是进程,线程,IPC,套接字

多核程序设计-Pthread一定得吃透了,你很NB

UNIX网络编程_卷一,卷二

TCP/IP网络详解_卷一再看上面两本书时就该看了

5TCP/IP网络详解_卷二我觉得看到卷二就差不多了,当然卷三看了更好,努力,争取看了

6Lighttpd源代码-这个服务器也很有名了

7Nginx源代码_相较于Apache,Nginx的源码较少,如果能看个大致,很NB。看源代码主要是要学习里面的套接字编程及并发控制,想想都激动。如果你有这些本事,可以试着往暴雪投简历,为他们写服务器后台,想一想全球的魔兽都运行在你的服务器软件上。

Linux内核TCP/IP协议栈_深入了解TCP/IP的实现

如果你还喜欢驱动程序设计,可以看看更底层的协议,如链路层的,写什么路由器,网卡,网络设备的驱动及嵌入式系统软件应该也不成问题了。

当然一般的网络公司,就算百度级别的也该毫不犹豫的雇用你。只是看后面这些书需要时间与经验,所以35岁以前办到吧!跳槽到给你未来的地方!

图形方向,我觉得图形方向也是很有前途的,以下几个方面。

Opengl的工业及游戏开发,国外较成熟。

影视动画特效,如皮克斯,也是国外较成熟。

GPU计算技术,可以应用在浏览器网页渲染上,GPU计算资源利用上,由于开源的原因,有很多的文档程序可以参考。如果能进火狐开发,或google做浏览器开发,应该会很好。

嵌入式方向:嵌入式方向没说的,Linux很重要。

掌握多个架构,不仅X86的,ARM的,单片机什么的也必须得懂。硬件不懂我预见你会死在半路上,我也想走嵌入式方向,但我觉得就学校教授嵌入式的方法,我连学电子的那帮学生都竞争不过。奉劝大家,一定得懂硬件再去做,如果走到嵌入式应用开发,只能祝你好运,不要碰上像Nokia,Hp这样的公司,否则你会很惨的。

驱动程序设计:软件开发周期是很长的,硬件不同,很快。每个月诞生那么多的新硬件,如何让他们在Linux上工作起来,这是你的工作。由于Linux的兼容性很好,如果不是太低层的驱动,基本C语言就可以搞定,系统架构的影响不大,因为有系统支持,你可能做些许更改就可以在ARM上使用PC的硬件了,所以做硬件驱动开发不像嵌入式,对硬件知识的要求很高。可以从事的方向也很多,如家电啊,特别是如索尼,日立,希捷,富士康这样的厂子,很稀缺的。

LDD_Linux驱动程序设计与内核编程的基础读物

深入理解Linux内核_进阶的

Linux源代码_永无止境的

当然你还的看个方面的书,如《linux就该这么学》啊什么的。

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » DELPHI基础教程:Delphi客户服务器应用开发(二)[3]

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情