婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > SQL Server常見問題及解決方法分享

SQL Server常見問題及解決方法分享

熱門標簽:我要地圖標注數量有限制嗎 電銷需要外呼系統嗎 千呼電話機器人可以試用嗎 家庭農場地圖標注名稱怎樣起名 零成本地圖標注賺錢 安卡拉地圖標注app 400電話辦理泰安 互聯網電話外呼系統 電話機器人怎么代理商

寫在前面

  在QQ群,微信群,論壇中經常幫助使用SQL Server數據庫的朋友解決問題,但是有一些最常見最基本的問題,每天都有人問,回答多了也不想再解答了,索性把這些問題整理一下,再有人問到直接發鏈接。

  一時想法而寫這篇文章,問題可能不全面,后續會一直更新。

基礎問題收集資源下載

  描述:XX版本數據庫操作系統在哪里下載?

  答:http://www.itellyou.cn/ 里面很多東西,有興趣的自己看吧

連接問題

  描述:數據庫連接不上

  答:請確認SQL服務是否啟動,用戶密碼是否正確,連接的實例名稱,端口是否正確

日志問題

  描述:系統日志LDF滿了 或 日志文件非常大 如何收縮?

  答:簡單恢復模式下SQL Server會自動截斷日志文件,完整模式下需要日志備份

恢復模式查看

日志備份的方式

收縮日志

查詢很久\很慢

  描述:查詢很久都查不出數據,很慢!

  答:這樣的情況出現一般是查詢語句被其他語句阻塞。在查詢中添加 select * from table with (nolock)如果能查出來說明阻塞

  具體的阻塞情況 可以使用sp_who2 或者 sys.dm_exec_requests 視圖查詢

  具體腳本(查看語句運行情況)

WITH sess AS
(
 SELECT
 es.session_id,
 database_name = DB_NAME(er.database_id),
 er.cpu_time,
 er.reads,
 er.writes,
 er.logical_reads,
 login_name,
 er.status,
 blocking_session_id,
 wait_type,
 wait_resource,
 wait_time,
 individual_query = SUBSTRING (qt.text, (er.statement_start_offset/2)+1, ((CASE WHEN er.statement_end_offset = -1 THEN LEN(CONVERT(NVARCHAR(MAX), qt.text)) * 2 ELSE er.statement_end_offset END - er.statement_start_offset)/2)+1),
 parent_query = qt.text,
 program_name,
 host_name,
 nt_domain,
 start_time,
 DATEDIFF(MS,er.start_time,GETDATE()) as duration,
 (SELECT query_plan FROM sys.dm_exec_query_plan(er.plan_handle)) AS query_plan
 FROM
 sys.dm_exec_requests er
 INNER JOIN sys.dm_exec_sessions es ON er.session_id = es.session_id
 CROSS APPLY sys.dm_exec_sql_text(er.sql_handle)as qt
 WHERE
 es.session_id > 50
 AND es.session_Id NOT IN (@@SPID)
)
SELECT
 *
FROM
 sess
UNION ALL SELECT
 es.session_id,
 database_name = '',
 0,
 0,
 0,
 0,
 login_name,
 es.status,
 0,
 '',
 '',
 '',
 qt.text,
 parent_query = qt.text,
 program_name,
 host_name,
 nt_domain,
 es.last_request_start_time,
 DATEDIFF(MS,es.last_request_start_time,GETDATE()) as duration,
 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啟動的文章:

  你所不知道的SQL Server數據庫啟動過程(用戶數據庫加載過程的疑難雜癥)

  你所不知道的SQL Server數據庫啟動過程,以及啟動不起來的各種問題的分析及解決技巧  

數據庫設計,表設計的問題

  大多數這樣的問題,在QQ群里問是根本得不到答案的,很多業務場景不是幾句話可以描述清楚的。  

SQL語句問題

  描述:SQL語句增加或者減少一個條件就變得很慢

  答:SQL語句的運行變化很微妙,需要理解執行計劃,幾句話或者貼個圖無法解決,一些語句的習慣是需要養成的,請參見:

  SQL SERVER全面優化-------寫出好語句是習慣

  SQL SERVER全面優化-------索引有多重要?  

AlwaysOn配置問題

  AlwaysOn配置問題請參見樺仔的幾篇非常細致的文章:

  從0開始搭建SQL Server AlwaysOn 第一篇(配置域控)

  從0開始搭建SQL Server AlwaysOn 第二篇(配置故障轉移集群)

  從0開始搭建SQL Server AlwaysOn 第三篇(配置AlwaysOn)

  從0開始搭建SQL Server AlwaysOn 第四篇(配置異地機房節點)

  2016的AlwaysOn 搭建:SQL SERVER 2016 AlwaysOn 無域集群+負載均衡搭建與簡測

AlwaysOn新建用戶

  首先要明白AlwaysOn可用組中:

  1.只有主節點是可以寫入的,輔助節點只讀

  2.權限分成兩部分,實例級別“登錄名”和數據庫級別“用戶”

  3.在主節點創建登錄名稱并選擇數據庫權限后,因為數據同步,所以從庫上已經有了新創建用戶的數據庫權限,但是沒有登錄名。

  4.不能在輔助節點同樣的方式創建登錄名,這樣就是“用戶孤立”問題

  解決方法:  

  1.在主節點上直接添加的是“登錄名”,比如創建一個登錄名 KK

  2.選擇數據庫權限及用戶映射

  3.查詢剛才創建“登錄名”的腳本(此腳本也可以用于升級或遷移數據庫還原后,登錄名同步的問題)  

CREATE PROCEDURE #sp_hexadecimal
 @binvalue varbinary(256),
 @hexvalue varchar (514) OUTPUT
AS
 DECLARE @charvalue varchar (514)
 DECLARE @i int
 DECLARE @length int
 DECLARE @hexstring char(16)

 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
DECLARE @type varchar (1)
DECLARE @hasaccess int
DECLARE @denylogin int
DECLARE @is_disabled int
DECLARE @PWD_varbinary varbinary (256)
DECLARE @PWD_string varchar (514)
DECLARE @Principal_id int
DECLARE @SID_varbinary varbinary (85)
DECLARE @SID_string varchar (514)
DECLARE @tmpstr varchar (1024)
DECLARE @is_policy_checked varchar (3)
DECLARE @is_expiration_checked varchar (3)
DECLARE @defaultdb sysname
DECLARE @language sysname
DECLARE @rolename sysname
DECLARE login_curs CURSOR FOR SELECT 
 p.principal_id,
 p.sid, 
 p.name, 
 p.type, 
 p.is_disabled, 
 p.default_database_name, 
 p.default_language_name,
 l.hasaccess, 
 l.denylogin 
FROM 
 sys.server_principals p 
LEFT JOIN 
 sys.syslogins l ON ( l.name = p.name ) 
WHERE 
 p.type IN ( 'S', 'G', 'U' ) AND 
 p.name > 'sa'

OPEN login_curs

FETCH NEXT FROM login_curs INTO @Principal_id, @SID_varbinary, @name, @type, @is_disabled, @defaultdb, @language, @hasaccess, @denylogin
IF (@@fetch_status = -1)
BEGIN
 PRINT 'No login(s) found.'
 CLOSE login_curs
 DEALLOCATE login_curs
 RETURN
END
SET @tmpstr = '** Generated ' + CONVERT (varchar, GETDATE()) + ' on ' + @@SERVERNAME + ' */'
PRINT @tmpstr
PRINT ''
WHILE (@@fetch_status > -1)
BEGIN
 IF (@@fetch_status > -2)
 BEGIN
 PRINT ''
 SET @tmpstr = '-- Login: ' + @name
 PRINT @tmpstr
 IF (@type IN ( 'G', 'U'))
 BEGIN -- NT authenticated account/group
  SET @tmpstr = 'CREATE LOGIN ' + QUOTENAME( @name ) + ' FROM WINDOWS WITH DEFAULT_DATABASE = [' + @defaultdb + '], DEFAULT_LANGUAGE = [' + @language + ']'
 END
 ELSE 
 BEGIN -- SQL Server authentication
  -- obtain password and sid
  SET @PWD_varbinary = CAST( LOGINPROPERTY( @name, 'PasswordHash' ) AS varbinary (256) )
  EXEC #sp_hexadecimal @PWD_varbinary, @PWD_string OUT
  EXEC #sp_hexadecimal @SID_varbinary,@SID_string OUT

  -- obtain password policy state
  SELECT @is_policy_checked = CASE is_policy_checked WHEN 1 THEN 'ON' WHEN 0 THEN 'OFF' ELSE NULL END FROM sys.sql_logins WHERE name = @name
  SELECT @is_expiration_checked = CASE is_expiration_checked WHEN 1 THEN 'ON' WHEN 0 THEN 'OFF' ELSE NULL END FROM sys.sql_logins WHERE name = @name

  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 )
  BEGIN
  SET @tmpstr = @tmpstr + ', CHECK_POLICY = ' + @is_policy_checked
  END
  IF ( @is_expiration_checked IS NOT NULL )
  BEGIN
  SET @tmpstr = @tmpstr + ', CHECK_EXPIRATION = ' + @is_expiration_checked
  END
 END
 IF (@denylogin = 1)
 BEGIN -- login is denied access
  SET @tmpstr = @tmpstr + '; DENY CONNECT SQL TO ' + QUOTENAME( @name )
 END
 ELSE IF (@hasaccess = 0)
 BEGIN -- login exists but does not have access
  SET @tmpstr = @tmpstr + '; REVOKE CONNECT SQL TO ' + QUOTENAME( @name )
 END
 IF (@is_disabled = 1)
 BEGIN -- login is disabled
  SET @tmpstr = @tmpstr + '; ALTER LOGIN ' + QUOTENAME( @name ) + ' DISABLE'
 END
 PRINT @tmpstr
 PRINT 'GO'
 DECLARE server_role_members_curs CURSOR FOR 
  SELECT 
  (SELECT [name] FROM sys.server_principals WHERE principal_id = role_principal_id) AS rolename
  FROM 
  sys.server_role_members 
  WHERE 
  member_principal_id = @Principal_id
 OPEN server_role_members_curs

 FETCH NEXT FROM server_role_members_curs INTO @rolename
 WHILE (@@fetch_status > -1)
 BEGIN
  SELECT @tmpstr = 'EXEC master..sp_addsrvrolemember @loginame = N''' + @name + ''', @rolename = N''' + @rolename + ''''
  PRINT @tmpstr
  PRINT 'GO'
  FETCH NEXT FROM server_role_members_curs INTO @rolename
 END
 CLOSE server_role_members_curs
 DEALLOCATE server_role_members_curs 
 END
 FETCH NEXT FROM login_curs INTO @Principal_id, @SID_varbinary, @name, @type, @is_disabled, @defaultdb, @language, @hasaccess, @denylogin
END
CLOSE login_curs
DEALLOCATE login_curs
GO

DROP PROCEDURE #sp_hexadecimal
GO

 4.找到查詢出的腳本,在輔助節點運行(其中主要的就是SID)

進階問題請大家點擊原文閱讀。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • MySQL server has gone away 問題的解決方法
  • MySQL提示:The server quit without updating PID file問題的解決辦法
  • SQL Server 2008 阻止保存要求重新創建表的更改問題的設置方法
  • MySQL遠程連接丟失問題解決方法(Lost connection to MySQL server)
  • win2008 r2 安裝sqlserver 2000問題的解決方法
  • SQLServer 數據庫變成單個用戶后無法訪問問題的解決方法
  • sql server中的decimal或者numeric的精度問題
  • winXP系統安裝SQLServer2005開發版具體過程與注意問題
  • SqlServer數據庫提示 “tempdb” 的日志已滿 問題解決方案
  • SQL Server"錯誤 21002: [SQL-DMO]用戶 * 已經存在問題解決

標簽:東營 黃山 池州 新鄉 來賓 文山 大同 濱州

巨人網絡通訊聲明:本文標題《SQL Server常見問題及解決方法分享》,本文關鍵詞  SQL,Server,常見問題,及,解決,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL Server常見問題及解決方法分享》相關的同類信息!
  • 本頁收集關于SQL Server常見問題及解決方法分享的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲影视在线观看| 中文字幕欧美区| 色域天天综合网| 成人激情视频网站| 成人app网站| 国产成人自拍网| 波多野结衣欧美| av一区二区三区四区| 色综合色狠狠天天综合色| caoporn国产一区二区| 91在线一区二区三区| 欧美在线影院一区二区| 欧美人牲a欧美精品| 欧美本精品男人aⅴ天堂| xvideos.蜜桃一区二区| 欧美国产禁国产网站cc| 亚洲成人综合在线| 久久精品国产亚洲a| 国产在线精品一区二区夜色| 成人久久久精品乱码一区二区三区| k8久久久一区二区三区| 欧美三级三级三级爽爽爽| 欧美一级艳片视频免费观看| 国产精品国产三级国产| 亚洲午夜在线电影| 成人在线视频一区| 欧美一级久久久久久久大片| 久久亚洲私人国产精品va媚药| 亚洲欧洲日产国码二区| 蜜臀av一级做a爰片久久| 中文字幕亚洲精品在线观看| 日韩午夜激情免费电影| 一区二区三区欧美| 成人手机电影网| 久久久美女毛片| 日韩成人一区二区三区在线观看| 成人av在线资源网站| 在线不卡a资源高清| 亚洲精品乱码久久久久久久久 | 国产成人免费av在线| 日韩三级视频在线观看| 午夜精品久久久久久久久久 | 亚洲一区二区三区四区在线观看| 丁香婷婷综合色啪| 久久久美女艺术照精彩视频福利播放| 亚洲电影激情视频网站| 欧美色区777第一页| 一区二区三区在线观看网站| 色美美综合视频| 亚洲影视在线观看| 欧美精品久久99久久在免费线| 日韩精品亚洲专区| 欧美一区二区三区系列电影| 国产呦精品一区二区三区网站| 欧美精品一区二| 91影视在线播放| 天堂蜜桃一区二区三区| 日韩欧美高清一区| 99久久99久久免费精品蜜臀| 亚洲自拍偷拍av| 欧美一区二区在线视频| 国内外成人在线视频| 国产精品久久久久影院老司| 日本高清无吗v一区| 韩国中文字幕2020精品| 亚洲精品成a人| 欧美大肚乱孕交hd孕妇| 日本乱人伦aⅴ精品| 国产一区不卡精品| 日韩在线卡一卡二| 国产精品久久久久桃色tv| 91精品国产品国语在线不卡| 国产一区二区三区不卡在线观看| 亚洲欧洲在线观看av| 久久综合久久综合亚洲| 91精品国产91热久久久做人人| 91亚洲精品乱码久久久久久蜜桃 | 欧美亚洲国产一卡| 成人av在线电影| 韩国毛片一区二区三区| 亚洲福利视频导航| 亚洲综合av网| 玉足女爽爽91| 亚洲国产精品人人做人人爽| 中文字幕一区二区三区在线播放| 日韩视频中午一区| 日韩视频一区二区三区在线播放| 欧美丝袜丝交足nylons图片| 在线观看成人小视频| 久久久精品2019中文字幕之3| 日韩欧美亚洲国产另类| 欧美一区二区三区在线| 欧美刺激脚交jootjob| 欧美岛国在线观看| 亚洲国产成人自拍| 亚洲丝袜制服诱惑| 天天操天天干天天综合网| 天天做天天摸天天爽国产一区| 丝袜诱惑制服诱惑色一区在线观看| 亚洲成人一二三| 久久99日本精品| 波多野结衣一区二区三区 | 国产精品免费免费| 亚洲精选视频在线| 久久99热这里只有精品| 成人av在线看| 成人精品免费网站| 国产91丝袜在线播放0| 日韩成人免费看| 99在线热播精品免费| 在线精品视频免费观看| 欧美xxxx在线观看| 一区二区三区在线观看网站| 激情六月婷婷综合| 欧美日韩免费一区二区三区视频 | 一区免费观看视频| 久久69国产一区二区蜜臀| 在线欧美日韩国产| 国产精品无码永久免费888| 三级影片在线观看欧美日韩一区二区 | 亚洲品质自拍视频| 国产一区 二区| 日韩视频永久免费| 日韩av在线播放中文字幕| 91国在线观看| 亚洲男人天堂av| 91蝌蚪porny成人天涯| 国产欧美日韩不卡| 色哟哟国产精品| 中文字幕中文在线不卡住| 国产中文一区二区三区| 久久视频一区二区| 激情综合网av| 国产精品三级视频| 色中色一区二区| 午夜精品久久久久久久99樱桃| 欧美日韩视频在线第一区| 亚洲第一主播视频| 日韩欧美区一区二| 成人涩涩免费视频| 一区二区三区日韩精品视频| 欧美性受xxxx黑人xyx| 日韩国产高清在线| 国产精品久久久爽爽爽麻豆色哟哟| 成人动漫一区二区| 日韩va亚洲va欧美va久久| 欧美v亚洲v综合ⅴ国产v| 99视频精品全部免费在线| 一区二区三区欧美亚洲| 久久久午夜电影| 91福利视频久久久久| 捆绑变态av一区二区三区| 中文字幕高清不卡| 日韩女同互慰一区二区| 成a人片亚洲日本久久| 亚洲成精国产精品女| 久久久久久日产精品| 欧美性三三影院| 成人免费黄色大片| 国产一区二区精品久久| 亚洲妇女屁股眼交7| 亚洲精品欧美综合四区| 精品国产麻豆免费人成网站| 色噜噜久久综合| 不卡av在线免费观看| 国产成人在线网站| 久久不见久久见中文字幕免费| 一区二区成人在线视频| 国产精品美女久久久久久| 久久综合久久综合久久| 日韩精品一区二区三区视频播放 | 美女一区二区在线观看| 亚洲综合一二区| 亚洲一区二区黄色| 亚洲一级二级在线| 国产一区二区三区四区五区入口| 日本不卡不码高清免费观看| 亚洲国产日韩av| 人人超碰91尤物精品国产| 天天av天天翘天天综合网色鬼国产 | 久久成人18免费观看| 精品一二三四区| av不卡一区二区三区| 91国偷自产一区二区开放时间| 成人小视频在线| 欧美亚洲国产一区在线观看网站| 欧美日韩中文字幕一区二区| 91精品婷婷国产综合久久性色 | 成人精品视频一区| 欧美性色黄大片| 2020国产精品| 一区二区三区四区国产精品| 午夜精品久久久久影视| 国产成人av电影| 91久久免费观看| bt7086福利一区国产| 国产高清不卡二三区| 成人精品视频一区二区三区| 欧美日韩成人一区| 亚洲国产高清在线|