SQLServer运维二

标签: 无 分类: 未分类 创建时间:2022-06-09 02:48:59 更新时间:2025-01-17 10:39:22

前言

SQL 运维这个东西已经写了好几篇文章了,现在还要继续的补充。

1.自动备份

这里需要注意的就是 要在 “维护计划”,右键点击“维护计划”,打开“维护计划向导”,创建一个备份计划,然后再配置子任务,进行定时备份。

2.设置用户对某一个特定的表具有访问权限

需求就是增加一个用户,只能读取某一个特定的表,其他的表看不到。

(1) 在数据库连接上,选择安全性,右键新建登录名,设定密码
(2) 设定服务器角色,默认
(3) 设置用户映射,选择需要查看的数据库,数据库成员身份中,只需要勾选public一个即可
(4) 在数据库下点击新建查询,输入sql 语句,授权查询权限给某一个用户,不要在全局新建查询,可能会出现找不到用户或者是数据库表。

1
grant select on tablename to username

3.批量删除

执行批量删除,但是报错了。解决事务日志已满的问题(SQL Server 错误 9002)

1
DELETE FROM realtime WHERE RecordTime <='2020-01-01 00:00:00';

【尝试方案】
(1)我尝试将日志文件进行收缩,结果没有效果

【解决方案】
分成小批量的删除,执行下面的语句。

1
2
3
4
5
6
7
declare @onedeletecount int
set @onedeletecount=1000
while 1=1
begin
delete top(@onedeletecount) from realtime where RecordTime <='2020-01-01 00:00:00' ;
IF (@@rowcount<@onedeletecount) BREAK;
end
参考文章:
【1】.“PhEMS安吉琥珀热电”的事务日志已满,原因为“ACTIVE_TRANSACTION”
【2】.解决事务日志已满的问题(SQL Server 错误 9002)
【3】.事务日志已满,原因为“ACTIVE_TRANSACTION” 这里设置恢复模式为简单,然后在任务里面进行日志收缩。
【4】.SQL批量删除数据操作 删除指定数据
【5】.Sql Server 数据库事务日志爆满问题处理 选择数据库右键进入“properties”,然后进入“files”,查看test_data_log行,autogrowth列 ,这里有控制最大不能超过500MB,应该要修改为不受限制。
【6】.SQL Server删除大量数据造成日志满(批量删除) 分批删除

4.日志收缩

数据删除后,数据库文件还是太大。

【尝试方案】
(1) 我尝试了收缩数据库文件,好像没有效果,还是一样的。

(2) 查询分析器输入,结果报错了:此语句不支持一个或多个选项(no_log)

1
BACKUP LOG database_name WITH NO_LOG

(3) 使用收缩脚本

1
2
3
4
-- 修改数据库恢复模式
ALTER DATABASE mydb SET RECOVERY SIMPLE
-- 收缩日志至10MB
DBCC SHRINKFILE (mydb_Log, 10);

【解决方案】
后来我发现,我已经通过界面把数据库日志文件收缩到了 1280 页。

参考文章:
【1】.【小5聊】Sql Server 删除表记录后,mdf文件还是占很大空间,甚至大小没变 初始大小设置太大,或者表记录已经占用到了10G,然后这个初始大小也会跟着变化
【2】.sql server 测试delete后数据空间情况 1.如果是索引组织表,删除的数据空间是会被文件设置为可用状态,其他表都可以使用。2.如果是堆表,删除数据空间也会设置为可用状态,但是只能给被删除数据的表使用。3.truncate删除表数据、drop table 表,是会释放数据空间(即把占用部分数据空间置为空闲)给数据文件(注意,这里是给数据文件而不是操作系统,数据文件本身大小不会改变),然后所有表对象的增删改都可以使用这部分空间。
【3】.SQL Server删除数据会变大 解决方法:1.手动清理数据;
【4】.SQL Server 数据库清除日志的方法 1.收缩数据库–收缩文件.2.设置检查点,自动截断日志。3.通过SQL收缩日志。4.删除日志文件。
【5】.sql server 2012 如何收缩事务日志
【6】.sql server 中mdf文件太大,删掉数据表后,mdf文件没有变小。 DBCC SHRINKDATABASE(数据库名字),如我的数据库名字为NMF, 或者右键数据库—–>任务——->收缩———->数据库(或者文件)
小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。