2019-12-08

Spotlight on SQL Server Uygulamasının SQL Scriptleri Nerede Tutuluyor?

SQL Server veritabanı sisteminin sağlık durumu izlemek için kullanılan araçlardan birisi olan Spotlight on SQL Server uygulamasının kullandığı scriptleri aşağıdaki dizinde bulabilirsiniz. Script konusunda uzmanlığınız varsa kendinize göre mevcut scriptleri iyileştirebilir yada özelleştirebilirsiniz.

C:\Program Files (x86)\Quest Software\Diagnostic Server\Agent\conf\Package\sqlserver_spotlight

2019-12-06

Tüm Login ve Tüm Windows Group Altındaki Tüm Loginlerin Listesini Alma

/*
Bir instance altındaki tüm login'leri ve Windows group altındaki tüm kullanıcıların listesini aşağıdaki T-SQL bulabilirsiniz
*/

declare  @tmploginlist table(
LoginName    nvarchar(256),
[type]     varchar(8),
[privilege]    varchar(8),
[mapped login name]  nvarchar(256),
WindowsGroupName    nvarchar(256)
)

 declare @WindowsGroupName nvarchar(256)

 --SQL/Windows Logins
 insert into @tmploginlist
select  name,'user','user',name,''
from sys.server_principals
where  type in ('S','U')
 declare c1 cursor for

 --Windows groups
   select name
   from sys.server_principals
   where type =  'G' 
  open c1
  fetch next from c1 into @WindowsGroupName
  while @@fetch_status <> -1
    begin
     insert into @tmploginlist(LoginName,[type],[privilege],[mapped login name],WindowsGroupName)
        exec xp_logininfo @acctname = @WindowsGroupName,@option = 'members'    
    fetch next from c1 into @WindowsGroupName
    end
  close c1
  deallocate c1
select LoginName,WindowsGroupName
from @tmploginlist

2019-11-28

Bir Kullanıcıyı Tüm Veritabanlarından Silmek

/*
Bir kullanıcıyı bir instance altındaki tüm veritabanlarından silmek için aşağıdaki T-SQL script'i kullanabilirsiniz:
*/

declare @LoginName sysname ='Login Name'
declare @strSQL varchar(8000)=
'use [?]
if exists(select * from sys.database_principals
where name =''' + @LoginName + ''')
begin
drop schema [' + @LoginName + ']
drop user [' + @LoginName + ']
end
'
exec sp_MSforeachdb @strSQL
if exists(select * from sys.server_principals
where name =@LoginName)
begin
exec ('drop login [' +  @LoginName + ']')
end

/*
SSMS'da Central Management Servers yada Local Server Groups yardımıyla tanımlı server gruplar yardımıyla tüm veritabanı sistemlerinizdeki tüm veritabanlarında tek seferde silmek için kullanabilirsiniz. */

2019-11-07

Çalıştırılan Komut İçeriğinden Job Adını Bulma

Çalıştırılan komut içeriğinden SQL Server job adını aşağıdaki kod ile bulabilirsiniz:

select j.name
from msdb.dbo.sysjobs j
inner join msdb.dbo.sysjobsteps js on  j.job_id=js.job_id
where js.command like '%Aranılacak içerik%'

2019-07-31

SQL Server en son ne zaman start oldu?

SQL Server servisinin en son ne zaman başladığını aşağıdaki sorgu ile bulabilirsiniz:

SELECT sqlserver_start_time
FROM sys.dm_os_sys_info

2019-04-02

Tüm Kullanıcı Veritabanlarındaki Tüm Tabloların Boyutunu Bulma

Tüm kullanıcı veritabanlarındaki tüm tabloların KB olarak boyutunu  aşağıdaki T-SQL kod ile bulabilirsiniz:

create table #tmptable(DatabaseName sysname,SchemaName sysname, TableName sysname, RowCounts bigint, TotalSpaceKB bigint, UsedSpaceKB bigint, UnusedSpaceKB bigint)

exec sp_msforeachdb 'if db_id(''?'')>4 begin use [?]
insert into #tmptable
select
 db_name() as DatabaseName,
    s.Name as SchemaName,
    t.name as TableName,
    sum((CASE WHEN a.type =1  THEN p.rows  ELSE 0 END)) as RowCounts,
 sum(a.total_pages)*8,
 (sum(CASE WHEN a.type <> 1 THEN a.used_pages WHEN p.index_id < 2 THEN a.data_pages ELSE 0 END))*8 as TotalSpaceKB
from sys.tables t inner join sys.indexes i ON t.object_id = i.object_id
 inner join sys.partitions p ON i.object_id = p.object_id AND i.index_id = p.index_id
 inner join sys.allocation_units a ON p.partition_id = a.container_id
 inner join sys.schemas s ON t.schema_id = s.schema_id
where i.index_id in(0,1)
group by  s.Name,t.Name
end'

select top 100 * from #tmptable
order by TotalSpaceKB desc

drop table #tmptable

.::YASAL UYARI::.

©2004-2020 Mehmet GÜZEL, http://www.mehmetguzel.net/ & http://www.mehmetguzel.com/

Site içeriği kaynak gösterilmek koşuluyla yayınlanabilir. Yazılan yazı ve yorumlar sadece yazı ve yorum sahiplerini bağlar.