ExtAspNet应用技巧(十一) - Subsonic配置与使用

来源:互联网 发布:数据库管理需要会什么 编辑:程序博客网 时间:2024/06/13 13:47

前言

曾经尝试过很多DotNet下的ORM工具(只是DotNet2.0下的),有IBatis.Net, NHibernate, MyGeneration doodads, Microsoft EntLib, SubSonic等,觉得最简单的要数doodads,最好用的当属SubSonic。

因此在AppBox项目中,我毫不犹疑的选择SubSonic作为ORM工具。为了兼容dotnet2.0的程序,我们不会使用最新的SubSonic3.0版本,而是使用SubSonic2.2版本。 因为2.2版本已经有两年左右的稳定时间,所以应该不会出现大的BUG并且很容易在网上找到问题的解决办法。



约定优先于配置

这是一条由 Ruby On Rails 发扬广大的编程规则,SubSonic也非常重视这条规则,并在创建数据库表时有一些有用的约定:
1. 每个表都应该包含如下四个列(不是必需的),这样在使用SubSonic的创建和更新函数时可以方便的修改这些字段:
  • CreatedOn (datetime)
  • CreatedBy (nvarchar(50))
  • ModifiedOn (datetime)
  • ModifiedBy (nvarchar(50))

2. 如果你想使用逻辑删除,可以增加列:Deleted (bit)
这样当你调用数据库表映射类的静态方法 Delete 时,SubSonic会首先判断此表是否存在Deleted字段,如果存在则设为true。否则,则调用 Destory 函数,即是永久删除。

3. 对表名和列名的约定。

  • 表名为单数形式
  • 列名不要包含保留字(比如system,string等)
  • 列名不要和表名相同


那么如何在Asp.net2.0 WebApplication项目中使用SubSonic,我想大概有如下几个步骤:
  • 创建数据库和表
  • 配置Web.config
  • 通过sonic.exe连接数据库,生成所有的映射类
  • 使用映射类对数据库进行CRUD




创建数据库和表

首先我们再SqlServer2005中新建一个数据库AppBox,然后创建用户表: 

可以看到,我们遵守了SubSonic的约定增加了CreatedOn,CreatedBy,ModifiedOn,ModifiedBy。不过没有使用逻辑删除。



配置Web.config

      <configSections>        <section name="SubSonicService" type="SubSonic.SubSonicSection, SubSonic"/>      </configSections>      <connectionStrings>        <clear/>        <add name="Default" connectionString="Password=sa;Persist Security Info=True;User ID=sa;Initial Catalog=AppBox;Data Source=."/>      </connectionStrings>      <SubSonicService defaultProvider="Default">        <providers>          <clear/>          <add name="Default" type="SubSonic.SqlDataProvider, SubSonic" connectionStringName="Default" generatedNamespace="AppBox"/>        </providers>      </SubSonicService>    

我们在connectionStrings 配置节中执行了数据库连接字符串(名称为Default),并在SubSonicService配置节中指定connectionStringName为Default,这就为SubSonic指定了数据库连接。

通过 generatedNamespace="AppBox" 是为下一步做准备,让代码自动生成的映射类拥有 AppBox 的命名空间。



通过sonic.exe生成所有的映射类

把下面一行命令保存为批处理文件(比如generate.bat),双击运行即可生成所有的数据库映射类代码(以后表有改动,只需重新执行一次这个命令即可)。
    .\library\subsonic\sonic\sonic.exe generate /config .\ /out .\Business\Subsonic    

这个命令中:
  • /config .\
    执行使用当前目录下的 Web.config 中的SubSonicService建立数据库连接。所以此generate.bat应该和Web.config在同一目录。
  • /out .\Business\Subsonic
    指定输出目录为当前目录下Business目录下的SubSonic子目录。


我们看一下生成的文件: 


其实我们没有必须管这些都是什么文件,我们只需要知道调用方法就可以了。你可以在 Working with ActiveRecord 和 Working with the Query Tool 阅读到整个项目中使用到的 99% 的调用方法。
相信我,真的很简单。



使用SubSonic

这里只举一个查询用户的例子,更多的使用方法可以参考上面给出的链接。
    string userName = tbxUserName.Text.Trim();    string password = tbxPassword.Text.Trim();    XUser user = new Select().From<XUser>()        .Where(XUser.NameColumn).IsEqualTo(userName)        .And(XUser.EnabledColumn).IsEqualTo(true)        .ExecuteSingle<XUser>();    



如果你想运行本章中使用的代码,可以从 http://appbox.codeplex.com/SourceControl/ListDownloadableCommits.aspx 下载全部源代码。

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 学车脑子不好使怎么办 生完二胎脑子不好使怎么办 羽毛球鞋买小了怎么办 羽毛球鞋买大了怎么办 感觉自己脑子越来越笨了怎么办? 生完孩子后身体素质差怎么办 胃口太好越来越胖怎么办 心情一紧张心跳手抖怎么办 消防兵新兵连俯卧撑不够怎么办 cf枪王永久禁赛怎么办 换了手机号花呗怎么办 xp系统无限重启怎么办 魔域配置资源读取错误怎么办 魔域异地交易了怎么办 魔域手游宝宝亲密度不够怎么办 魔域手游怎么改密码忘了怎么办 魔域装备注灵怎么办 lol外服账号忘记了怎么办 美服lol下载慢怎么办 台服天堂2延迟怎么办 梦幻专用瑞兽没有泰山怎么办 冲错了游戏点券怎么办 新手玩联盟很菜怎么办 cf玩一会儿卡退怎么办 魔域先锋区封号了怎么办 吃了减肥药头疼怎么办 冬天没用完的霜怎么办 手表带起来大了怎么办 碰到舞警打人该怎么办 合租者偷了东西却没有证据怎么办 钥匙锁在房间了怎么办 家里门钥匙丢了怎么办 合租朝北晒衣服怎么办 卧室门钥匙丢了怎么办 邻居在我家防盗窗上凉被子怎么办 有钥匙打不开门怎么办 白色腈纶衣服洗完发黄怎么办 在部队有人整你怎么办 老公掉粪坑了你怎么办图片 好久没跑步腿疼怎么办 跑1000米要5分钟怎么办