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

数据库 SQL Server
本文我们以一个实例介绍了数据库调整可以遵循的“开闭原则”的相关知识,希望本次的介绍能够对您有所帮助。

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

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

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

我的需求改动还涉及到了跨域问题,用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 + ")");  

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

【编辑推荐】

  1. SQL Server 2005导入Oracle 10g的C#源码
  2. SQL Server 2008快速清理日志文件的代码
  3. SQL Server 2008数据库中CDC的功能使用及说明
  4. SQL Server 2008阻止保存要求重新创建表的更改的问题
  5. SQL Server数据库row_number() over() 来自动产生行号
责任编辑:赵鹏 来源: 博客园
相关推荐

2023-07-05 08:00:52

兼容性Oracle数据库

2011-07-04 17:59:03

开闭原则

2011-03-17 14:51:33

数据库自我调整

2015-08-21 12:59:38

Oracle数据库

2022-09-27 09:21:34

SOLID开闭原则Go

2010-04-19 13:59:17

Oracle 数据库

2015-08-31 11:35:50

数据中心布线

2015-03-02 16:48:40

数据处理大数据原则

2012-03-15 11:15:13

Java设计模式

2011-04-14 13:01:53

Oracle数据库

2016-09-23 20:20:10

2010-03-29 10:19:24

2010-05-13 14:07:39

MySQL数据库

2011-03-03 10:45:34

PureftpdMYSQL

2011-03-11 17:00:08

SQL

2009-11-02 18:56:49

调整Oracle数据库

2017-10-31 11:25:34

无缝迁移数据中心原则

2017-10-20 14:35:38

数据库设计原则

2010-09-07 16:12:36

SQL语句数据库压缩

2010-05-06 12:44:47

Oracle数据库
点赞
收藏

51CTO技术栈公众号