分享:SQL一键备份用户数据库

大家都知道,Ms Sql 有自动备份的功能,但如果由于某种原因不能自动备份,或者我们想手动备份的话,就可以用下边的sql语句来执行备份。

--------------------代码开始-------------


------删除旧数据-------------------------------------------------------------
DECLARE@delTimeVARCHAR(100)
SET@delTime= CONVERT(VARCHAR(100), GETDATE(),126) -----当前时间

EXECUTE MASTER.dbo.xp_delete_file0,'D:\DataBak','bak',@delTime,1


DECLARE@FILENAMEVARCHAR(500)
  
DECLARE@DATABakPathVARCHAR(500) 
 
DECLARE@DATABaseNameVARCHAR(500) 
 
DECLARE@DATAFullNameVARCHAR(500) 
 
SET@DATABakPath= 'D:\DataBak\' 
 
DECLARE@tempTABLE(a INT, b INT, c INT) 
 
DECLARE@exeTextVARCHAR(100) 
 
SET@FILENAME= REPLACE(
REPLACE(
REPLACE(CONVERT(VARCHAR, GETDATE(),120),'-',''),
' ',
''
),
':',
''
) +'.bak' 
 
 
------------遍历所有用户数据库 进行备份-------------------------------------------------------------------
 
 
DECLARE My_Cursor CURSOR --定义游标
FOR
(
SELECT NAME
FROM sys.databases
WHERE NAME NOT IN ('master','msdb','tempdb','model',
'ReportServerTempDB','ReportServer')
) --查出需要的集合放到游标中
OPEN My_Cursor; --打开游标
FETCH NEXT FROM My_Cursor INTO@DATABaseName; --读取第一行数据
WHILE @@FETCH_STATUS=0
BEGIN
SET@DATAFullName=@DATABakPath+@DATABaseName
 
SET@exeText='mkdir '+@DATAFullName--创建备份目录
EXEC xp_cmdshell@exeText,
no_output
 
SET@DATAFullName=@DATAFullName+'\' + @FILENAME + ''
 
BACKUP DATABASE@DATABaseNameTO DISK =@DATAFullName
 
FETCH NEXT FROM My_Cursor INTO@DATABaseName; --读取下一行数据
END
CLOSE My_Cursor; --关闭游标
DEALLOCATE My_Cursor; --释放游标
 
 
PRINT'-----------备份完成---------------------'+ CONVERT(VARCHAR(100), GETDATE(),126)+'---------------'
 
--------------------代码结束-------------


ASP.NET 使用application和session对象写的简单聊天室程序

ASP.Net中有两个重要的对象,一个是application对象,一个是session对象。

 
Application:记录应用程序参数的对象,该对象用于共享应用程序级信息。
 
Session:记录浏览器端的变量对象,用来存储跨网页程序程序的变量或者对象。
 
 
 
说实话,写了快一年的asp.net,application对象还真没怎么用过。看了看书,根据这两个对象的特性写了一个简单的聊天室程序。真的是非常的简陋。
 
 
 
 
 
思路大概就是,在Default页登录时,输入的昵称存入session对象当中,并跳转到ChatRoom页,并把session中存的键为”nickname”存入application对象中去。遍历application对象,给左侧的listbox添加在线人的昵称。利用appliaction对象在Session_Start和Session_End方法中对键为”count”进行+1,-1用于记录当前在线人数。在利用application对象键为”content”存储聊天记录。下面上代码
 
Global.asax:
 
        protected void Application_Start(object sender, EventArgs e)
        {
            Application["count"] = 0;
            Application["content"] = "聊天记录\n";
        }
 
        protected void Session_Start(object sender, EventArgs e)
        {
            Application.Lock();
            Application["count"] = (int)Application["count"] + 1;
            Application.UnLock();
        }
        protected void Session_End(object sender, EventArgs e)
        {
            Application.Lock();
            Application["count"] = (int)Application["count"] - 1;
            Application.UnLock();
        }
Default.aspx:
 
        protected void button_login_Click(object sender, EventArgs e)
        {
            if (!string.IsNullOrEmpty(textbox_nickname.Text))
            {
                Session["nickname"] = textbox_nickname.Text;
            }
            Response.Redirect("ChatRoom.aspx");
        }
ChatRoom.aspx:
 
        protected void Page_Load(object sender, EventArgs e)
        {
            label_count.Text = "当前在线人数为" + Application["count"].ToString() + "人";
            if (!IsPostBack)
            {
                if (Session["nickname"] != null)
                {
                    Application.Add(Session["nickname"].ToString(), Session["nickname"]);
                }
                textbox_records.Text = Application["content"].ToString();
            }
            listbox_usernames.Items.Clear();
            foreach (string str in Application.Contents)
            {
                if (!str.Equals("content") && !str.Equals("count") && !str.Equals("name"))
                {
                    listbox_usernames.Items.Add(new ListItem(Application[str].ToString(), Application[str].ToString()));
                }
            }
        }
 
        protected void button_send_Click(object sender, EventArgs e)
        {
            if (Session["nickname"] != null)
            {
                Application["content"] += (Session["nickname"].ToString() + "说:" + textbox_sendmsg.Text + "\n");
                textbox_records.Text = Application["content"].ToString();
            }
        }
 
        protected void button_exit_Click(object sender, EventArgs e)
        {
            Application.Remove(Session["nickname"].ToString());
            Application["count"] = (int)Application["count"] - 1;
            Response.Redirect("WebCounter.aspx");
        }
这样简单的聊天室就完成了,在本地使用的时候,在一个浏览器下好像不会创建新的session,需要在不同浏览器下登录才能看到效果。
 
这里也要注意一点就是,在退出聊天室的时候,要把application键为”nickname”,即当前session[“nickname”]的值给remove掉。否则刷新listbox的时候,会发现退出的昵称还存在。
 
同时也要把键为”count”的application对象-1,也许你要问,不是在Session_End方法中已经-1了么?这块我还真不确定,可能是有两个原因,不知道是哪个?希望明白的朋友给予指点。
 
1、session没有过期,我只是把application中对应的键为session的对象干掉了,但是真正的session我并没有清。所以不会调用Session_End方法。(不过也许你会问,你把当前session[“nickname”]对象置空不就OK了吗?这个我试了,但是count没有-1。)
 
2、会不会是因为我在本地两个不同浏览器去做这个聊天操作的原因?
 
在一些特殊情况下,用application对象对我们的帮助真的非常大,session我就不用说了,绝对是我们经常用的。

.NET MVC通过反射获取数据修改历史记录

折磨了我一个晚上的问题,奈何对物理的反射印象太深了,整天去想着物理的反射、折射怎么解。感谢少将哥哥给我的指点,经过一个晚上对反射的恶补,最终搞定了。纪念一下。

 
  1.核心代码:
 
 

 1 private static void IsUpdate<T>(T old, T current, string id)
 2         {
 3             Model.PerFileHistory history = new Model.PerFileHistory();
 4             Model.Atrributes.ModifyFields atrr = null;
 5             Type type = typeof(T);
 6             PropertyInfo[] propertys = type.GetProperties();
 7             foreach (PropertyInfo property in propertys)
 8             {
 9                 if (property.PropertyType.IsValueType || property.PropertyType.Name == "String")
10                 {
11                     if (property.PropertyType.FullName.Contains("Guid"))
12                         continue;
13                     //if (property.Name != "CreateUserID" && property.Name != "CreateTime" && property.Name != "ModifyUserID" &&                                    property.Name != "LastModifyTime")//排除这些字段不做判断
14                     //{
15                     if (property.GetCustomAttributes(typeof(Model.Atrributes.ModifyFields), false).Count() > 0)
16                     {
17                         object o1 = property.GetValue(old, null); //以前的值
18                         object o2 = property.GetValue(current, null); //修改后的值
19                         string str1 = o1 == null ? string.Empty : o1.ToString();
20                         string str2 = o2 == null ? string.Empty : o2.ToString();
21                         //判断两者是否相同,不同则插入历史表中
22                         if (str1 != str2)
23                         {
24                             history.BeforeValue = str1; //修改前的值
25                             history.AfterValue = str2; //修改后的值
26                             history.PCardNo = id; //修改数据的ID
27                             history.IPAddress = HanNeng.Common.GetClientIP.GetRealIP(); //获取当前用户的IP地址
28                             atrr = property.GetCustomAttributes(typeof(Model.Atrributes.ModifyFields), false)[0] as                    Model.Atrributes.ModifyFields;
29                             history.ModifyField = property.Name;  //修改的字段名称
30                             history.ModifyFieldName = atrr.FieldsName; //修改的字段中文名称
31 
32                             new BLL.PerFileHistory().AddModel(history);
33                         }
34                     }
35                     //}
36                 }
37             }
38         }
复制代码
  2.获取字段中文名,这个是在Model的类名里设置,示例如下:
 
 
复制代码
 1 /// <summary>
 2     /// 获取字段名称
 3     /// </summary>
 4     public class ModifyFields : Attribute
 5     {
 6          public ModifyFields()
 7         {
 8         }
 9          public ModifyFields(string name)
10         {
11             this.FieldsName = name;
12         }
13         /// <summary>
14         /// 修改的字段中文名
15         /// </summary>
16          public string FieldsName
17         {
18             get;
19             set;
20         }
21     }
复制代码
 
复制代码
1          /// <summary>
2         /// 科部
3         /// </summary>
4         [Atrributes.ModifyFields("科部")]
5         public int? SubjectDep
6         {
7             set { _subjectdep = value; }
8             get { return _subjectdep; }
9         }
复制代码
  3.调用方式示例:
 
 
复制代码
 1          if (id != null)
 2                 {
 3                     Model.PersonFile Person = bllPerson.GetModel<Model.PersonFile>(id);
 4                     if (modelPerson != null)
 5                     {
 6                         Model.Identity identity = Session["Identity"] as Model.Identity;
 7                         //if (identity.RoleIDs.ToString() == "R01")  //如果是系统管理员,则不记录历史
 8                         //{
 9                         //对前后数据的不同进行比较
10                         Model.PersonFile OldPerson = Person;
11                         Model.PersonFile NewPerson = modelPerson;
12                         NewPerson.PersonAutoID = OldPerson.PersonAutoID;
13                         IsUpdate(OldPerson, NewPerson, id);
14                         //}
15                     }
16                 }