Aqui les dejo una serie de scripts que son de gran utilidad cuando de administrar bases de datos en SQL Server hablamos, divididos en 8 secciones:
- Log de transacciones
- Seguridad (USUARIOS, LOGGINS, PASSWORD, ESQUEMAS, ROLES, PERMISOS)
- Data files y files groups
- MSSQL Agent
- Backup and restore
- Indices
- Reporting services
- Utilidades y trucos
———————————-
——- LOG DE TRANSACCIONES —–
———————————-
—-VERIFICAR USO DEL LOG DE TRANSACCIONES ESPACIOS DISPONIBLES
DBCC SQLPERF( LOGSPACE )
—-TRUNCAR EL LOG DE TRANSACCIONES EN SQL SERVER 2000 Y 2005
use DB
CHECKPOINT
GO
BACKUP LOG Exercise WITH
TRUNCATE_ONLY
DBCC SHRINKFILE(‘Exercise_log’, 10) –Dejamos el archivo de log con un tamaño de 10 Mb
DBCC sqlperf(logspace)
—-TRUNCAR EL LOG DE TRANSACCION EN SQL SERVER 2008—
USE DB;
GO
ALTER DATABASE AdventureWorks2008R2
SET RECOVERY SIMPLE;
GO
— Deja el log en 1 MB.
DBCC SHRINKFILE(AdventureWorks2008R2_Log, 1);
GO
— Regresar el
modelo de recuperacion a FULL.
ALTER DATABASE DB
SET RECOVERY FULL;
GO
–******************************———————–
—-AÑADIR ARCHIVOS LOG A UNA BASE DE DATOS
USE master;
GO
ALTER DATABASE DB
ADD LOG FILE
(
NAME = DB_test1log2,
FILENAME = ‘RUTA\DB2log.ldf’,
SIZE = 5MB,
MAXSIZE = 100MB,
FILEGROWTH = 5MB
),
(
NAME = DB_test1log3,
FILENAME = ‘RUTA\DB3log.ldf’,
SIZE = 5MB,
MAXSIZE = 100MB,
FILEGROWTH =
5MB
);
GO
—-VERIFICAR EL ESTATUS DEL LOG DE TRANSACCIONES CUANDO ESTE LLENO
Select name as base_datos,
log_reuse_wait, log_reuse_wait_desc,
case
log_reuse_wait
when 0 then ‘Hay actualmente uno o
más archivos de registro virtual reutilizables.’
when 1 then ‘No se ha producido
ningún punto de comprobación desde el ÚLTIMO AVISO! para Ganar $$$$Se Buscan
Personas para Trabajar desde sus Casas por Internet – +Infoúltimo truncamiento
o el encabezado del registro no se ha movido más allá de un archivo de registro
virtual (todos los modelos de recuperación). Éste es un motivo habitual para
retrasar el truncamiento.’
when 2 then ‘Se necesita una copia
de seguridad del registro para hacer avanzar el encabezado del registro
(modelos de recuperación completos o registrados de forma masiva sólo). Cuando
se completa la copia de seguridad del registro, se avanza el encabezado del
registro y algún espacio del registro podría convertirse en reutilizable.’
when 3 then ‘Existe una recuperación
o copia de seguridad de datos en curso (todos los modelos de recuperación).
La copia de seguridad
de datos funciona como una transacción activa y, cuando se ejecuta, la copia de
seguridad impide el truncamiento.’
when 4 then ‘Podría existir una
transacción de larga duración en el inicio de la copia de seguridad del
registro. En este caso, para liberar espacio se podría requerir otra copia de
seguridad del registro.
Se difiere una
transacción. Una transacción diferida es efectivamente una transacción activa
cuya reversión se bloquea debido a algún recurso no disponible.’
when 5 then ‘Se realiza una pausa en
la creación de reflejo de la base de datos o, en el modo de alto rendimiento,
la base de datos reflejada está notablemente detrás de la base de datos de la
entidad de seguridad (sólo para el modelo de recuperación completa).’
when 6 then ‘Durante las
replicaciones transaccionales, las transacciones relevante para las
publicaciones no se han entregado aún a la base de datos de distribución (sólo
para el modelo de recuperación completa).’
when 7 then ‘Se está creando una
instantánea de base de datos (todos los modelos de recuperación). Éste es un
motivo habitual, por lo general breve, para retrasar el truncamiento del
registro.’
when 8 then ‘Se está produciendo un
recorrido del registro (todos los modelos de recuperación). Éste es un motivo
habitual, por lo general breve, para retrasar el truncamiento del registro.’
when 9 then ‘No se utiliza este
valor actualmente.’
end as columna,
recovery_model_desc as
modo_recuperacion_log, page_verify_option_desc as page_verify_bbdd,
user_access_desc as user_access,
state_desc as estado_bbdd from sys.databases
—————————————————————————
——- Seguridad (USUARIOS, LOGGINS, PASSWORD, ESQUEMAS, ROLES, PERMISOS–
—————————————————————————
—-DESCRIPCION DE LOS ROLES DE SERVIDOR
sp_helpsrvrole
—-MIEMBROS QUE PERTENECEN A UN ROL DE SERVIDOR
sp_helpsrvrolemember
—-ROLES DEFINIDOS EN LA BASE DE DATOS
sp_helprole
—-MIEMBROS DE LOS ROLES DE BASES DE DATOS
sp_helprolemember
—-FIXED DATABASE ROLES
sp_helpdbfixedrole
—-LISTA DE LOGINS POR BASE DE DATOS
sp_helplogins
sp_srvrolepermission — permisos que tiene cada rol en el servidor
sp_addsrvrolemember — agrega un inicio de sesion a un rol
sp_dropsrvrolemember — quita usuario, inicio de sesion o grupo del rol del servidor
sp_helpuser — informacion de usuarios en el servidor actual
sp_helpntgroup — Grupos
xp_cmdshell ‘whoami.exe’ —para saber quien tiene permisos de ejecutar xp_cmdshell
—-ASIGNAR PERMISOS A USUARIOS SOBRE OBJETOS
grant
tipo_de_permiso on objeto to rol
—- CREAR ROLES
CREATE ROLE role_name [ AUTHORIZATION owner_name ]
—- INFORMACION DE LOS ROLES
select * from sys.database_role_members
—- INFORMACION DE LOS ROLES
select * from sys.database_principals
—- INFORMACION DE LOS ESQUEMAS
select * from sys.schemas
—- INFORMACION DE LOGGINS
SELECT * FROM sys.server_principals
—- NOMBRE DE USUARIO ACTUAL
SELECT CURRENT_USER
—- NOMBRE DE SYSTEM_USER
SELECT SYSTEM_USER
—- USUARIOS HUERFANOS SIN INICIO DE SESION
EXEC sp_change_users_login‘Update_One’, ‘ExistingUser’, ‘NewLogin’
use master select sid, name from master..syslogins — *** Ver los Inicios de Sesión de la Instancia de SQL
Server ***
use DB select uid, name, sid from sysusers where
islogin=1 — *** Ver los Usuarios de la Base de Datos actual de SQL Server ***
—CAMBIAR DUEÑO DE UN OBJETO
EXEC sp_changeobjectowner‘CurrentOwner.TableName’,
‘newOwner’
—-CHECAR QUIEN ES DUEÑO DE OBJETOS
select s.name, u.name from sysusers u, sysobjects s
where s.uid=u.uid and s.uid!=1
—-LIGAR LOGGIN CON USUARIO
sp_change_users_login ‘AUTO_FIX’,‘usr_reports’
—-CAMBIAR PASSWORD SQL SERVER 2000
sp_password @old = null, @new = ‘pasword’, @loginame = user
—-CAMBIAR PASSWORD SQL SERVER 2005 y 2008
ALTER LOGIN user WITH PASSWORD = ‘pasword’
—- LISTAR PERMISOS DE LOS USUARIOS
select dp.NAME usuario, dp.type_desc AS tipo, o.NAME AS nombre_de_objeto,
p.permission_name nombre_de_permiso,
p.state_desc AS permisos from sys.database_permissions p
left OUTER JOIN sys.all_objects o on p.major_id = o.OBJECT_ID
inner JOIN sys.database_principals dp on p.grantee_principal_id
= dp.principal_id
order by
usuario
—- Estadísticas de inicio de sesión sql server 2008
select * from sys.dm_exec_sessions
—- número de sesiones de cada usuario sql server 2008
SELECT login_name
,COUNT(session_id) AS session_count
FROM sys.dm_exec_sessions
GROUP BY login_name;
—- Buscar sesiones inactivas que tienen transacciones abiertas sql server 2008
SELECT s.*
FROM sys.dm_exec_sessions AS
s
WHERE EXISTS
(
SELECT *
FROM sys.dm_tran_session_transactions
AS t
WHERE t.session_id = s.session_id
)
AND NOT EXISTS
(
SELECT *
FROM sys.dm_exec_requests AS r
WHERE r.session_id = s.session_id
);
—- NUMERO DE CONEXIONES A LA INSTANCIA POR APLICACION
SELECT
CPU = SUM(cpu_time)
,WaitTime
= SUM(total_scheduled_time)
,ElapsedTime
= SUM(total_elapsed_time)
,Reads
= SUM(num_reads)
,Writes
= SUM(num_writes)
,Connections
= COUNT(1)
,Program
= program_name
FROM sys.dm_exec_connections con
LEFT JOIN sys.dm_exec_sessions
ses
ON ses.session_id = con.session_id
GROUP BY program_name
—- NUMERO DE CONEXIONES A LA INSTANCIA POR USUARIO
SELECT
CPU = SUM(cpu_time)
,WaitTime
= SUM(total_scheduled_time)
,ElapsedTime
= SUM(total_elapsed_time)
,Reads
= SUM(num_reads)
,Writes
= SUM(num_writes)
,Connections
= COUNT(1)
,[login]
= original_login_name
from sys.dm_exec_connections con
LEFT JOIN sys.dm_exec_sessions
ses
ON ses.session_id = con.session_id
GROUP BY original_login_name
—————————–
–DATA FILES Y FILES GROUPS–
—————————–
sp_helpfilegroup — MOSTRAR FILES Y FILES GROUPS
sp_helpfile — MOSTRAR INFORMACION DE LOS FILES DE LA BASE DE DATOS ACTUAL
sp_helpdb CICLISMO —MOSTRAR INFORMACION DE LAS BASES DE DATOS
DBCC
SHRINKDATABASE(DB, 25)— REDUCIR BASE DE DATOS
—- Mostrar informacion de los archivos log y mdf de la base de datos actual
select * from sys.database_files
—- Añadir datafiles
use master
go
Alter database tempdb add file (name = tempdev1,
filename = ‘G:\MSSQL.2\MSSQL\Data\tempdb1.ndf’)
—- ESPACIO DISPONIBLE EN DATAFILES SQL SERVER 2000
use db
select a.FILEID,
[FILE_SIZE_MB] = convert(decimal(12,2),round(a.size/128.000,2)),
[SPACE_USED_MB] = convert(decimal(12,2),round(fileproperty(a.name,‘SpaceUsed’)/128.000,2)),
[FREE_SPACE_MB] = convert(decimal(12,2),round((a.size–fileproperty(a.name,‘SpaceUsed’))/128.000,2)) ,
NAME = left(a.NAME,15), FILENAME = left(a.FILENAME,30)
from dbo.sysfiles a
— ESPACIO DISPONIBLE EN LOS DATA FILES SQL SERVER 2005 – 2008
SELECT name
Nombre_Archivo ,size/128.0
– CAST(FILEPROPERTY(name, ‘SpaceUsed’) AS int)/128.0 AS
EspaciodisponibleMB FROM sys.database_files;
—————-
— MSSQL Agent–
—————-
sp_help_job —lista de jobs en msdb
—- LISTA DE JOBS FALLIDOS EN SU ULTIMO INTENTO
SELECT name AS [JOBS FALLIDOS] FROM
msdb.dbo.sysjobs
A, msdb.dbo.sysjobservers B
WHERE A.job_id = B.job_id AND B.last_run_outcome = 0
—- INFORMACION DE LOS SCHEDULES DE UN JOB
USe msdb;
GO
EXEC dbo.sp_help_jobschedule
@job_name = N’FTM: ActualizaStatusConvenio’,
@schedule_name =
N’JobActualizaStatusConvenio’ ,
@Include_description = 1;
GO
—- Ver un listado de Jobs Deshabilitados:
SELECT name FROM msdb.dbo.sysjobs
WHERE enabled = 0 ORDER BY name
—- Permisos necesarios para crear jobs
USE [msdb]
GO
CREATE USER
[MyUser] FOR LOGIN
[MyUser]
GO
USE [msdb]
GO
EXEC sp_addrolemember‘SQLAgentUserRole’, ‘MyUser’
GO
————————–
— BACKUP AND RESTORE —
————————–
—- LISTA DE BACKUPS REALIZADOS EN LA INSTANCIA
Select
database_name,server_Name,Machine_Name,b.[name]as Backup_Name,Backup_Start_Date,Backup_Finish_Date
,Physical_Device_Name
from master.sys.databases a
Inner Join msdb..backupset
b on
a.Name = b.Database_Name
Inner Join msdb..backupmediafamily
c on c.media_set_id
= b.media_set_id
—- LISTA DE ULTIMOS RESTORES HECHOS A LA BASE DE DATOS
USE MSDB
GO
SELECT TOP 5 *
FROM
RESTOREHISTORY WITH (nolock)
WHERE (DESTINATION_DATABASE_NAME =
‘NOMBREBD’)
ORDER BY RESTORE_DATE DESC
—- ULTIMO RESPALDO HECHO A LA BASE DE DATOS
select
database_name,max(backup_finish_date) as backup_finish_date from
msdb..backupset
where
database_name=‘your_database’
group by database_name
—- ULTIMA RESTAURACION HECHA A LA BASE DE DATOS
select
destination_database_name,max(restore_date) as restore_date from msdb..restorehistory
where
destination_database_name=‘your_database’
group by destination_database_name
———–
–INDICES–
———–
DBCC DBREINDEX(«HumanResources.Employee», PK_Employee_EmployeeID,80); —COMO RECONSTRUIR UN INDICE
sp_rename @objname = ‘ciclista.PK_ciclista’
, @newname = ‘PK_ciclistarenombrado’,
@objtype = ‘INDEX’ —COMO RENOMBRAR UN INDICE
sp_helpindex Ejemplo — VER INDICES SOBRE LA TABLA
sp_help Ejemplo — MOSTRAR INFORMACION SOBRE EL OBJETO
—- DEFRAGMENTAR INDICES EN LINEA SQLSERVER 2000
DBCC
INDEXDEFRAG(CS_PACC, «DBO.sotbl_MultPro», PK_MultPro)
—- COMPROBAR NIVEL DE FRAGMENTACION SQLSERVER 2000
USE CS_PACC
GO
DBCC SHOWCONTIG(‘DBO.sotbl_MultPro’)
GO
————————–
— Reporting services —
————————–
—- LISTADO DE LAS SUSCRIPCIONES EXISTENTES
select ‘SubnDesc’ = s.Description,‘ReportPath’= c.Path,
‘SubnOwner’ = us.UserName,‘LastStatus’= s.LastStatus,
‘LastRun’= s.LastRunTime,‘ReportModifiedBy’= uc.UserName,
‘ScheduleId’= rs.ScheduleId,‘SubscriptionId’= s.SubscriptionID
from
ReportServer.dbo.Subscriptions
s
join
ReportServer.dbo.Catalog c on c.ItemID = s.Report_OID
join
ReportServer.dbo.ReportSchedule
rs on rs.SubscriptionID
= s.SubscriptionID
join
ReportServer.dbo.Users
uc on uc.UserID
= c.ModifiedByID
join
ReportServer.dbo.Users
us on us.UserID
= s.OwnerId
join msdb.dbo.sysjobs j on j.name = CONVERT(nvarchar(128),rs.ScheduleId)
—- INFORMACION DE LAS SUSCRIPCIONES EN TIEMPO DE EJECUCIÓN
select
‘Report’= c.Path, ‘Subscription’ = s.Description,
‘SubscriptionOwner’= uo.UserName,‘SubscriptionModBy’=
um.UserName,
‘SubscriptionModDate’= s.ModifiedDate,‘ProcessStart’= dateadd(hh,DATEDIFF(hh,Getutcdate(),Getdate()),n.ProcessStart),
‘NotificationEntered’= dateadd(hh,DATEDIFF(hh,Getutcdate(),Getdate()),n.NotificationEntered),
‘ProcessAfter’= dateadd(hh,DATEDIFF(hh,Getutcdate(),Getdate()),n.ProcessAfter), n.Attempt,
‘SubscriptionLastRunTime’= dateadd(hh,DATEDIFF(hh,Getutcdate(),Getdate()),n.SubscriptionLastRunTime),
n.IsDataDriven, ‘ProcessHeartbeat’= dateadd(hh,DATEDIFF(hh,Getutcdate(),Getdate()),n.ProcessHeartbeat), n.Version,n.SubscriptionID
from
Notifications n
join
Subscriptions s on n.SubscriptionID
= s.SubscriptionID
join Catalog c on c.ItemID = n.ReportID
join Users uo on uo.UserID = s.OwnerID
join Users um on um.UserID = s.ModifiedByID
—- INFORME DE LOS REPORTES QUE MAS SE UTILIZAN EN REPORTING SERVICES
SELECT
ex.UserName, ex.Format, ex.TimeStart, cat.Name, ex.Parameters, CONVERT(nvarchar(10), ex.TimeStart, 101) AS rundate
FROM
ExecutionLog AS ex INNER
JOIN
Catalog AS cat ON ex.ReportID = cat.ItemID
ORDER BY ex.TimeStart DESC
–log de report server
Select * from ExecutionLog3
————————–
— UTILIDADES Y TRUCOS —
————————–
sp_spaceused —ESPACIO USADO POR UN OBJETO
/* importantando datos desde Excel*/
GO
SELECT orderId, orderDate,
customerId, employeeId INTO
orders FROM OPENDATASOURCE(‘Microsoft.Jet.OLEDB.4.0’,
‘Data Source=C:\datos.xls;Extended Properties=Excel
8.0’)…[Sheet2$]
go
/* importantando
los datos para la tabla [ orders ]*/
GO
INSERT INTO EXPERIMENTO select
ID, NOMBRE,
MATERIA FROM
OPENDATASOURCE(‘Microsoft.Jet.OLEDB.4.0’,
‘Data Source=C:\Libroimportar.xls;Extended Properties=Excel
8.0’)…[IMPORTAR$] where ID NOT IN
(select ID from EXPERIMENTO)
go
—- COMO RENOMBRAR SERVIDOR/INSTANCIA SQL SERVER
SELECT @@SERVERNAME
sp_dropserver ‘OLD_SERVER’
go sp_addserver ‘NEW_SERVER’, ‘local’ go — POR ULTIMO REINICIAR SERVIDOR
—- HABILIDAR XP_CMDSHELL
EXEC sp_configure‘show advanced options’,
1 –Permitir
que las opciones avanzadas puedan ser cambiadas.
GO
RECONFIGURE
GO
EXEC sp_configure‘xp_cmdshell’, 1 –Permitir el uso de SP XP_CMDSHELL.
GO
RECONFIGURE
GO
—- Espacio en cada disco para la instancia SQL SERVER
EXEC master..xp_fixeddrives
—- Ver que comandos estan corriendo actualmente
select session_id, Text
from
sys.dm_exec_requests r
cross
apply sys.dm_exec_sql_text(sql_handle) t
— COMPROBAR ESTADO DE SERVICIOS
exec master.dbo.xp_servicecontrol‘QUERYSTATE’, ‘MSSQLServer’
exec master.dbo.xp_servicecontrol‘QUERYSTATE’, ‘SQLServerAgent’
exec master.dbo.xp_servicecontrol‘QUERYSTATE’, ‘SQLBrowser’
exec master.dbo.xp_servicecontrol‘QUERYSTATE’, ‘ReportServer$CSPDBA’
—- Ver Información de las transacciones abiertas
select * from sys.dm_tran_database_transactions
—- Como resetear la semilla de un identity
DBCC CHECKIDENT(‘dbo.Customers’,
RESEED, 1);
—- INSERTAR RESULTADO DE UN STORED PROCEDURE EN TABLA TEMPORAL Y EVITAR NESTED
CREATE TABLE #MYTEMPO(spid int, ecid int,[status] varchar(200), loginame varchar(200), hostname varchar(200),blk int,
dbname varchar(200),cmd varchar(200))
INSERT INTO #MYTEMPO
SELECT * FROM OPENQUERY(LOCALSERVER, ‘SET FMTONLY OFF EXEC
msdb..sp_help_job’)
select * from #MYTEMPO
—- CREAR LINKED SERVER
EXEC sp_addlinkedserver@server
= ‘LOCALSERVER’, @srvproduct = »,
@provider = ‘SQLOLEDB’, @datasrc = @@servername
—- BUSCAR POR NOMBRE DE COLUMNA EN UNA BASE DE DATOS
SELECT TABLE_NAME,*
FROM INFORMATION_SCHEMA.COLUMNS
WHERE
COLUMN_NAME LIKE ‘%a%’
—- BUSCAR TEXTO EN STORED PROCEDURE
SELECT
ROUTINE_NAME, ROUTINE_DEFINITION, *
FROM INFORMATION_SCHEMA.ROUTINES
WHERE
ROUTINE_DEFINITION LIKE ‘%BranchConvenio%’
AND
ROUTINE_TYPE=‘PROCEDURE’
Estimados muy buenos tipsn ultimamente tengo un problema con el log transaction esta alcanzando un tamaño elevado y esto me bota las conexiones de los usuarios, quiero ver si existe aparte de un profiler un metodo para detectar cual es el procedimiento que esta quedando sin commit que me lo esta poniendo full?
Bueno primero que nada te recomiendo que tengas una estrategia de respaldos donde incluyas backups del transaction log, en ambientes de alta disponibilidad se hacen estrategias de respaldos donde se incluye por ejemplpo un respaldo full diario, y cada 15 minutos respaldo del log de transacciones, esto no solo te ayuda a tener un plan de recuperación con minimos tiempos de perdidas de datos en caso de desastre, el realizar un respaldo constantedel loog mediante un mantenimiento tambien mantiene el tamaño del log en un tamaño razonable ya que hace implicitamente el truncado de este, si tu log esta creciendo checa si existe algun patron en cuanto a los tiempos? tal vez tengas algun mantenimiento llamese plan o job que este corriendo procesos pesados como mantenimiento de indices o algo que te este incremendatando en demasia el log(revisa tus jobs y planes), tambien te aconsejo monitorees constantemente el creciemiento de tu archivo log para que detectes en que momento(s) ocurre el crecimiento, al mismo tiempo podrias casar la operación que podria causarlo, uno de los procesos que pdoria aumentar el log de gran tamaño son las inserciones masivas con bulk insert,
Muy buen aporte, aunque tengo una duda…como puedo verificar si la BD es la que deja colgado a mi aplicación??, ya que es una aplicación que tiene más de 20 años y no había tenido problemas…hasta hoy; ya que al momento de dar un INSERT o un UPDATE se inhibe la aplicación y a veces a los demás usuarios que estan usando la aplicación (haciendo ellos distintas tareas dentro de la misma), hago un respaldo en línea cada 2 horas de la BD y es casi en el mismo tiempo que se produce la inhibición de la aplicación y lo que hago es reiniciar el servidor para poder continuar usar el aplicativo, estoy considerando borrar el log pero no se si esa sea la solución.
Espero que me puedan ayudar.
Saludos
Bueno, te cuento que en 20 años la variación en la capacidad tanto de la aplicación como de la base de datos varia muy significativamente. habria q analizar todas las variables; por ejemplo, puede que la configuración de tu servidor de aplicaciones(apache, tompact, iis) ya no sea suficiente para el numero de sesiones, o que le falte mantenimiento a la base de datos, o algún indice faltante o bloqueos, o que en la red hubiese algún cambio como mas saltos antes de llegar al servidor… De la base de datos te diré que debe faltarle un buen mantenimiento de indices, truncados de los mdf y ldf, y muy seguramente tendras bloqueos por tabla desde la aplicación q impedirán trabajar a los usuarios.
Muy buenos los tips, al momento estamos teniendo problemas con el sql en nuestra empresa, se migro de sql2000, windows2000 a sql2005 x32, windows2008 x64, y dwesde entonces el servidor deja de responder cada cierto tiempo hasta que hay que reiniciarlo.
Bueno a mi me parece que es un trabajo mas de revisar errores y event viewer, ya que siento que va por el lado del servidor, aunque aqui un punto es las versiones de sql de 32 bits no se llevan bien con versiones de SO de 64, si hiban a hacer la migracion lo hubieran hecho al parejo los dos en 32 bits o los dos en 64 bits, suele haber muchos issues a resolver cuando tienes so y version de sql en diferentes estados
Que buena ayuda, esto es algo que por lo general lo encontramos separado y en esta ocacion nos hiciste un gran favor poniendolo todo junto, definitivamente de gran ayuda.
buen aporte gracias
Exelente aporte, muchas gracias!!!
excelente, gracias
dos palabras… Muchas Gracias
ta bueno, excelente
Estaba navegando y encontre tu blog, Gracias por el aporte, hay unos scripts muy inclusives!!! el order y su funcionalidad esta muy clara!!! gracias…
Muchas gracias chicos! excelente!
Pregunta.. se Puede Cambiar el Pass del Usuario sa? desde la consola cuando yo lo hago me dice lo siguiente
Mensaje 15007, Nivel 16, Estado 1, Servidor miserver, Procedimiento sp_p
assword, Línea 29
‘public’ no es un inicio de sesión válido o el usuario no tiene permiso.
y lo hago mas o menos de este modo
osql -Smiserver -E -d master -Q «exec dbo.sp_password null, ‘12345’, ‘sa'»
agradesco respuesta Gracias…
Bueno el aporte
Excelente, muchas gracias.
Muy buen aporte, oye y de casaulidad te sabes algun sp para ver el rendimiento de el CPU (% usado) y Memoria Ram (Gb usados y libres). gracias de antemano…
MUIY BUENO EL TIP PARA VALIDAR INCONVENIENTES O BIEN PARA OBTENCIÓN DE INFORMACIÓN PARA LA TOMA DE DECISIONES
Excelente aportación
muy buen aporte,
Excelentes.. me sirven de mucho
GClaudia
soy nuevo en esto solo pido su ayuda para ver como ejecutar estos scripts en sql 2008 maganament
saludos
hola, quisiera saber si es posible asignar permisos de solo lectura a un usuario pero con un script para aplicarlo sobre varias BD
claro que es posible hacerlo,
crear el script para dar permisos es un grant común y corriente con permisos de datareader y los separas con un use por DB para que otorgue el permiso(s) en las diferentes DB’s
Excelente Aporte, me es de gran ayuda. Muchisimas gracias 🙂
Gracias por el aporte, esta muy bueno.
una consulta, como puedo calcular aprox. el numero de transacciones que se realizan en el servidor, en un tiempo determinado, por decir en una hora.
Mil Gracias
BUeno cualquir dosita tampbientengo algunos procedimientos juan_pablo0125@hotmail.com
excelente documento
Excelente!!!
Muy Bueno, mas tarde lo analizare con calma
EXCELENTE!!!
excelente aporte man muy bueno.
tengo una duda tienes algún script que me permita eliminar todos los usuarios de una instancia. esto para el ambiente de contingencia el cual la base de datos se carga manualmente pero cada vez que se crea un usuario este no puede ingresar si se Verifica en contingencia y los existentes tiene que ingresar con las claves que tuvieron según la fecha de creación de la instancia.
gracias
[…] Scripts de utilidad para administradores de bases de datos […]
Excelentes consultas para todos los que trabajan con dbas.