逆向而行—ASP的O/R MAPPING-阿里云开发者社区

开发者社区> 橘子红了呐> 正文

逆向而行—ASP的O/R MAPPING

简介:
+关注继续查看


您看的没错,是ASP not ASP.Net 我也没有发疯,我的目标就是实现一个简单的ASP环境下的O/R MAPPING,Visual Basic 6.0来实现.当然,由于Visual Basic毕竟不如C#,VB.net哪么强大,甚至它是否真正的面向对象也存在争论。所以 实现起来还是有一定的难度。

       我想和我一样,很多ASP的程序员,也饱受SQL语句之苦。特别是一些表单特别多的程序, 不断的做着重复的工作,就是 画表单,写SQL,然后插入,更新,删除,套用一句流行话语“我最烦这些SQL语句,一点技术含量都没有。如果 表的字段一多的话,哪简直就是写的昏天暗地。写好了还不一定对,调试SQL又是一个艰苦的工作。特别容易出错,不小心少了个号什么的,有时候找都找不出来。可是ASP程序员做得最多的就是这些。重复做除了字段不一样,其它都一样的工作。

       当我接触了一些 .Net  JavaO/R Mapping以后,最让我激动的不是其强大的功能,支持事务等等一些优秀功能,而是,终于不用在写SQL了,爽啊,真得想就此放弃了ASP投入.Net的怀抱,但是没有办法, 现在还有很多项目 ,需要用ASP来实现,也还有很多同胞挣扎在ASP中。所以 要是有一个ASP下的的O/R Mapping工具改是多么美妙啊, 但是翻遍了互联网也没有找到,所以才出此下策,不如自己写一个试试。

       一开始目标,我也不想强求我的ASP O/R Mapping有多么强大,所以在设计的时候,组件就提供了 add update delete三个方法,至少,insert ,update,delete语句不用写sql了,呵呵。实体文件我用vbscript的类来实现,例如:

None.gifclass testclass 
None.gif 
None.gif
private s_id 
None.gif 
None.gif
private s_name 
None.gif 
None.gif
private s_article 
None.gif 
None.gif
private s_addtime 
None.gif 
None.gif  
None.gif 
None.gif
Public Property Let id(value) 
None.gif 
None.gif       s_id
=value 
None.gif 
None.gif
End Property  
None.gif 
None.gif
Public Property Get id 
None.gif 
None.gif       id
=s_id 
None.gif 
None.gif
End Property 
None.gif 
None.gif  
None.gif 
None.gif
Public Property Let name(value) 
None.gif 
None.gif       s_name
=value 
None.gif 
None.gif
End Property 
None.gif 
None.gif
Public Property Get name 
None.gif 
None.gif       Name
=s_name 
None.gif 
None.gif
End Property 
None.gif 
None.gif
public property get article 
None.gif 
None.gif       article
=s_article 
None.gif 
None.gif
end property 
None.gif 
None.gif
public property let article(value) 
None.gif 
None.gif       s_article
=value 
None.gif 
None.gif
end property 
None.gif 
None.gif  
None.gif 
None.gif
public property get addtime 
None.gif 
None.gif       addtime
=s_addtime 
None.gif 
None.gif
end property 
None.gif 
None.gif
public property let addtime(value) 
None.gif 
None.gif       s_addtime
=value 
None.gif 
None.gif
end property 
None.gif 
None.gif
End class 
None.gif

关于实体文件没有什么过多可以解释的,反正 和数据库里的各个字段对映就可以了,而且vbscript不是强类型的语言,都不用指定数据类型。

接下来就是 映射文件了,当来xml文件是首选

None.gif<?xml version="1.0" encoding="utf-8" ?> 
None.gif 
None.gif
<aurora-map> 
None.gif 
None.gif       
<class className="testclass"> 
None.gif 
None.gif              
<table> 
None.gif 
None.gif                     
<id type="numeric" iskey="true" /> 
None.gif 
None.gif                     
<name type="text" /> 
None.gif 
None.gif                     
<article type="text" /> 
None.gif 
None.gif                     
<addtime type="text" /> 
None.gif 
None.gif              
</table> 
None.gif 
None.gif       
</class> 
None.gif 
None.gif
</aurora-map> 
None.gif

这里的设计想法是 
<table>
中是一个表的字段描述

Id name article addtime 都是字段名,

Type 指定 该数据类型是文本,还是数字型的,这个的作用其实很简单,就是在生成sql的时候判断要不要加上单引号,本来打算是type是指定各个字段的数据类型的。但是后来一想没有一个毕要,哪样做反而麻烦,所以就简单至上了。

Iskey 属性是指定是否用关键字段。

       还有一个就是配置文件了

None.gif<configuration> 
None.gif 
None.gif       
<aurora> 
None.gif 
None.gif              
<add key="application" value="web" /> //指定是web应用还是,exe程序应用 
None.gif 
None.gif              
<add key="mapfile" value="\" />           //指定 mapflie的目录 
None.gif 
None.gif              
<add key="databasetype" value="access" /> //指定所有数据库 
None.gif 
None.gif              
<add key="driver" value="Provider = Microsoft.Jet.OLEDB.4.0;" /> //这两个是数据库的配置,根据不同数据库而不同 
None.gif 
None.gif              
<add key="Data Source" value="db2.mdb" /> 
None.gif 
None.gif       
</aurora> 
None.gif 
None.gif
</configuration> 
None.gif

整个的功能实现做成了AcitveX来实现,这是一个简单的类图,第一次画,有很多错误还请指出 Capture_8.jpg

到现在为此这里的功能基本完成,但是还有很多需要优化和加强的地方。Bug也很多。先放出我昨天晚上编译的版本,这个也只是用于调试的版本。放出来是让大家帮我试试,给我提点意见,让我能更好的完善他,还有如果有什么好的建议,新的功能。也可以提出来,我们一起来实现。 
测试下载 
http://www.chinasunflower.com/test.rar  





    本文转自无心之柳.NET博客园博客,原文链接:http://www.cnblogs.com/9527/archive/2004/12/22/80443.html,如需转载请自行联系原作者


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
怎么设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程
6886 0
阿里云服务器ECS远程登录用户名密码查询方法
阿里云服务器ECS远程连接登录输入用户名和密码,阿里云没有默认密码,如果购买时没设置需要先重置实例密码,Windows用户名是administrator,Linux账号是root,阿小云来详细说下阿里云服务器远程登录连接用户名和密码查询方法
2821 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
4452 0
使用OpenApi弹性释放和设置云服务器ECS释放
云服务器ECS的一个重要特性就是按需创建资源。您可以在业务高峰期按需弹性的自定义规则进行资源创建,在完成业务计算的时候释放资源。本篇将提供几个Tips帮助您更加容易和自动化的完成云服务器的释放和弹性设置。
7744 0
windows server 2008阿里云ECS服务器安全设置
最近我们Sinesafe安全公司在为客户使用阿里云ecs服务器做安全的过程中,发现服务器基础安全性都没有做。为了为站长们提供更加有效的安全基础解决方案,我们Sinesafe将对阿里云服务器win2008 系统进行基础安全部署实战过程! 比较重要的几部分 1.
5442 0
阿里云服务器安全组设置内网互通的方法
虽然0.0.0.0/0使用非常方便,但是发现很多同学使用它来做内网互通,这是有安全风险的,实例有可能会在经典网络被内网IP访问到。下面介绍一下四种安全的内网互联设置方法。 购买前请先:领取阿里云幸运券,有很多优惠,可到下文中领取。
9415 0
腾讯云服务器 设置ngxin + fastdfs +tomcat 开机自启动
在tomcat中新建一个可以启动的 .sh 脚本文件 /usr/local/tomcat7/bin/ export JAVA_HOME=/usr/local/java/jdk7 export PATH=$JAVA_HOME/bin/:$PATH export CLASSPATH=.
2133 0
2873
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载