SQL Server常见问题及解决方法分享
写在前面在QQ群,微信群,论坛中经常帮助使用SQL Server数据库的朋友解决问题,但是有一些最常见最基本的问题,每天都有人问,回答多了也不想再解答了,索性把这些问题整理一下,再有人问到直接发链接。 一时想法而写这篇文章,问题可能不全面,后续会一直更新。 基础问题收集资源下载描述:XX版本数据库操作系统在哪里下载? 答: 里面很多东西,有兴趣的自己看吧 连接问题描述:数据库连接不上 答:请确认SQL服务是否启动,用户密码是否正确,连接的实例名称,端口是否正确 日志问题描述:系统日志LDF满了 或 日志文件非常大 如何收缩? 答:简单恢复模式下SQL Server会自动截断日志文件,完整模式下需要日志备份 恢复模式查看 日志备份的方式 收缩日志 查询很久很慢描述:查询很久都查不出数据,很慢! 答:这样的情况出现一般是查询语句被其他语句阻塞。在查询中添加 select * from table with (nolock)如果能查出来说明阻塞 具体的阻塞情况 可以使用sp_who2 或者 sys.dm_exec_requests 视图查询 具体脚本(查看语句运行情况) 50 AND es.session_Id NOT IN (@@SPID) ) SELECT * FROM sess UNION ALL SELECT es.session_id,database_name = '',es.status,'',qt.text,es.last_request_start_time,NULL AS query_plan FROM sys.dm_exec_sessions es INNER JOIN sys.dm_exec_connections ec ON es.session_id = ec.session_id CROSS APPLY sys.dm_exec_sql_text(ec.most_recent_sql_handle)as qt WHERE ec.most_recent_session_id IN ( SELECT blocking_session_id FROM sess WHERE blocking_session_id NOT IN(SELECT DISTINCT session_id FROM sess) ) ORDER BY 1,2分区表问题描述:数据量千万级别了使用分区表提升性能 答:分区表的使用场景主要是管理数据,而提升性能主要是靠IO并行,需要合理规划多块物理磁盘,大多数的场景下几千万数据单一的模式查询只需要添加正确的索引即可。 高可用的选择答:SQL自带的高可用或读写分离技术主要有:故障转移群集、发布订阅、镜像、日志传送、AlwaysON可用组(具体可以在进阶问题的资料中详细查看) 一般选用读写分离需要根据不同的场景和要求,比如同步的实时性,读写分离功能的需要情况 主要列出几个优缺点: 故障转移群集:主备模式,单活(辅助机不可读),硬件资源浪费,主要场景是数据库的高可用。 发布订阅:读写分离常用方式,配置灵活,副本节点可以多个,可以发布订阅部分数据(即可以对数据筛选),并提供多种发布订阅模式,缺点:维护比较麻烦,一般不能用作高可用。 镜像:主备模式,单活(辅助机不可读),硬件资源浪费,主要场景是数据库的高可用。相对于故障转移群集镜像是数据库级别的高可用。在镜像中可以使用快照的方式实现读写分离。 日志传送:主要用于灾备,在备用机上可读,但缺点是日志还原时不能读,读时不能还原。 AlwaysON可用组:综合性方案,满足高可用、读写分离等需要,要求:SQL Server2012 以上版本 第三方产品:moebius负载均衡集群,实现双活,读负载均衡、读写分离等。缺点实时同步不适合类似采集系统的大规模写入系统。 服务无法启动答:服务无法启动有很多原因,需要具体问题具体定位,如果遇到此类问题要首先查看日志定位问题,日志主要两部分,SQL启动日志和windows日志,下面给出两篇经典解析SQL启动的文章:
数据库设计,表设计的问题 大多数这样的问题,在QQ群里问是根本得不到答案的,很多业务场景不是几句话可以描述清楚的。 SQL语句问题描述:SQL语句增加或者减少一个条件就变得很慢 答:SQL语句的运行变化很微妙,需要理解执行计划,几句话或者贴个图无法解决,一些语句的习惯是需要养成的,请参见:
AlwaysOn配置问题AlwaysOn配置问题请参见桦仔的几篇非常细致的文章:
2016的AlwaysOn 搭建: AlwaysOn新建用户首先要明白AlwaysOn可用组中: 1.只有主节点是可以写入的,辅助节点只读 2.权限分成两部分,实例级别“登录名”和数据库级别“用户” 3.在主节点创建登录名称并选择数据库权限后,因为数据同步,所以从库上已经有了新创建用户的数据库权限,但是没有登录名。 4.不能在辅助节点同样的方式创建登录名,这样就是“用户孤立”问题 解决方法: 1.在主节点上直接添加的是“登录名”,比如创建一个登录名 KK 2.选择数据库权限及用户映射 3.查询刚才创建“登录名”的脚本(此脚本也可以用于升级或迁移数据库还原后,登录名同步的问题) SELECT @charvalue = '0x'SELECT @i = 1 SELECT @length = DATALENGTH (@binvalue) SELECT @hexstring = '0123456789ABCDEF' WHILE (@i <= @length) BEGIN DECLARE @tempint int DECLARE @firstint int DECLARE @secondint int SELECT @tempint = CONVERT(int,SUBSTRING(@binvalue,@i,1)) SELECT @firstint = FLOOR(@tempint/16) SELECT @secondint = @tempint - (@firstint*16) SELECT @charvalue = @charvalue + SUBSTRING(@hexstring,@firstint+1,1) + SUBSTRING(@hexstring,@secondint+1,1) SELECT @i = @i + 1 END SELECT @hexvalue = @charvalue GO DECLARE @name sysname OPEN login_curs FETCH NEXT FROM login_curs INTO @Principal_id,@SID_varbinary,@name,@type,@is_disabled,@defaultdb,@language,@hasaccess,@denylogin -- obtain password policy state SET @tmpstr = 'CREATE LOGIN ' + QUOTENAME( @name ) + ' WITH PASSWORD = ' + @PWD_string + ' HASHED,SID = ' + @SID_string + ',DEFAULT_DATABASE = [' + @defaultdb + '],DEFAULT_LANGUAGE = [' + @language + ']' IF ( @is_policy_checked IS NOT NULL ) FETCH NEXT FROM server_role_members_curs INTO @rolename DROP PROCEDURE #sp_hexadecimal 4.找到查询出的脚本,在辅助节点运行(其中主要的就是SID) 进阶问题请大家点击原文阅读。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- ASE的isql中有一个“隐藏”的reset指令
- sql – reportviewer条形图,条形宽度不正确
- 如何使用SQL修复数据库中损坏的MPTT树(嵌套集)?
- sql-server – 如何使用COALESCE多行而不使用逗号?
- 记录一次SqlServer查询优化的过程(聚合索引的使用)
- SQL datetime需要读取00:00:00.000
- SQLServer 使用sp_repldone标识所有未分发的事务为已分发
- 数据库 – django.contrib.gis.db.backends.postgis vs dja
- mysql 5.7 docker 主从复制架构搭建教程
- sql-server – 内连接更新?