关闭

数据库调整所遵循的“开闭原则”简介

发表于:2012-2-13 10:01

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:张占岭    来源:51Testing软件测试网采编

  数据库调整也可以遵循“开闭原则”的,本文我们就通过一个具体的实例来介绍这部分内容,首先如如果在原表上改,牵动太大,所以就想到了面向对象的“开闭原则”,在不改变原表的同时,添加一个附加表,即和原表有相同的主键,并且是一对一的关系(有时,如果一张表太复杂,字段太多,我们也可以用这个方法把复杂表进行拆分),添加后的结构如下:

  这样在不改原表的基础上,就完成的需求的变更。

  我的需求改动还涉及到了跨域问题,用jsonp解决的,实例代码如下:

  1. <script> 
  2. $(function() {  
  3. $("#btn").click(function() {  
  4. $.ajax({  
  5. type: "GET",  
  6. dataType: "jsonp",  
  7. jsonp: "jsonpcallback",  
  8. data: { userid: '<%=Standard.ClientHelper.Current.UserInfo.ID %>',   
  9. username: '<%=Standard.ClientHelper.Current.UserInfo.UserName %>',  
  10. _email: $("#email").val() },  
  11. url: "http://sso.c2cedu.com/Register/SendEmailInsertInvite",  
  12. success: function(data) {  
  13. //填写用户激活后送C币的逻辑  
  14. if (data.success == true)  
  15. alert("邀请成功");  
  16. else  
  17. alert("邀请失败");  
  18. }  
  19. });  
  20. });  
  21. });  
  22. </script>

  另外一网站的CS端程序如下:

  1. public ContentResult SendEmailInsertInvite(string userid, string username, string _email)  
  2. {  
  3. string queryStr = Request.QueryString["jsonpcallback"];  
  4. string res = "{success:false}";  
  5. try  
  6. {  
  7. res = "{success:true}";  
  8. #region 发邀请邮件,并将checkcode记录和邀请表记录插入  
  9. Array.ForEach(_email.Split(','), i => 
  10. {  
  11. CheckCodeRecord checkCodeRecord = new CheckCodeRecord  
  12. //有几个email地址,就产生几个checkcode记录  
  13. {  
  14. CheckCode = VCommons.Utils.GetNewGuid(),  
  15. Description = "邀请送C币" 
  16. };  
  17. UserInviteCCoin entity = _UserBaseServices.GetUserInviteCCoinByUserId(userid)  
  18. ?? new UserInviteCCoin  
  19. {  
  20. UserID = userid,  
  21. InviteID = VCommons.Utils.GetNewGuid(),  
  22. };  
  23. entity.IPAddr = checkCodeRecord.CheckCode;  
  24. _UserBaseServices.AddInviteRecord(entity, checkCodeRecord);  
  25. email.UserInviteEmail(entity, username, i);  
  26. });  
  27. #endregion  
  28. }  
  29. catch (Exception)  
  30. {  
  31. throw;  
  32. }  
  33. return Content(queryStr + "(" + res + ")");  
  34. }

  以上就是数据库调整所遵循的“开闭原则”的相关知识的介绍,本文我们就介绍到这里了,希望本次的介绍能够对您有所收获!

《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号