当前位置:首页 » 编程语言 » tsql创建日志
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

tsql创建日志

发布时间: 2022-07-28 22:27:41

Ⅰ 如何创建sql SERVER2005事务日志并且能每天自动建立。

方法1:
第一步:
backup
log
database_name
with
no_log
或者
backup
log
database_name
with
truncate_only
--no_log和truncate_only是在这里是同义的,随便执行哪一句都可以
第二步:
1.收缩特定数据库的所有数据和日志文件,执行
dbcc
shrinkdatabase
(database_name,[,target_percent])--database_name是要收缩的数据库名称;target_percent是数据库收缩后的数据库文件中所要的剩余可用空间百分比
2.收缩一次一个特定数据库中的数据或日志文件,执行
dbcc
shrinkfile(file_id,[,target_size])
--file_id是要收缩的文件的标识
(id)
号,若要获得文件
id,请使用
file_id
函数或在当前数据库中搜索
sysfiles;target_size是用兆字节表示的所要的文件大小(用整数表示)。如果没有指定,dbcc
shrinkfile
将文件大小减少到默认文件大小
两个dbcc都可以带上参数notruncate或truncateonly,具体意思看帮助。
方法2
(这个方法在sqlserver2000的环境下做一般能成功,在sqlserver7及以下版本就不一定了):
第一步:
先备份整个数据库以备不测
第二步:
备份结束后,在query
analyzer中执行如下的语句:
exec
sp_detach_db
yourdbname,true
--卸除这个db在mssql中的注册信息
第三步:
到日志的物理文件所在的目录中去删除该日志文件或者将该日志文件移出该目录
第四步:
在query
analyzer中执行如下的语句:
exec
sp_attach_single_file_db
yourdbname,'d:\mssql7\data\yourdbname_data.mdf'
--以单文件的方式注册该db,如果成功则mssql将自动为这个db生成一个500k的日志文件。
以上方法在清除log日志中均有效。
但,能否让sql
server
不产生log日志呢?以上方法好像均无效。
我这儿正好有个case:
我客户的sql
server每天都会产生4,500m的log日志,每天都清除一下,非常不便。有没有办法实现不产生log日志呢?
我分析了一下客户产生log日志的原因,并且做了相应测试。
客户是每天将数据库清空,从总系统中将数据导入到sql
server里。我感决sqlserver在插入时产生log不大,在delete整个库时产生log极大。
比如:
select
*
into
test_2
from
b_bgxx
共45000条记录,产生十几m
log,如果
delete
from
test_2
产生80多m
log
,这明显存在问题。
虽然可以换成:
truncate
table
test_2
但我还是希望能找到不产生log的方法。就如oracle不产生归档一样。

Ⅱ 使用T-SQL创建人事管理数据库

CREATE DATABASE [HrSys]
ON PRIMARY
( NAME = N'HrSys', FILENAME = N'D:\人事管理数据\HrSys.mdf' , SIZE = 3072KB , FILEGROWTH = 10%)
LOG ON
( NAME = N'HrSys_log', FILENAME = N'E:\人事管理日志\HrSys_log.ldf' , SIZE = 1024KB , FILEGROWTH = 10%)
GO
Drop Database [HrSys]

Ⅲ 如何用SQL语言在已有数据库日志文件中再添加一个数据库日志文件

use masteralter database 你的数据库名(建立数据库时的名称)add log file
(
name=tt_log2,filename='F:\tt_log2.ldf',
size=2MB,
maxsize=2MB,
filegrowth=10%
)
go这样就行了

Ⅳ 1)使用T-SQL语句管理数据库 (1) 使用CREATE DATABASE创建studb数据库,然后通过系统存储过程sp_helpdb查

if exists (select 1 from sysobject where name = 'sp_helpdb') is not null --判断是否存在同名的存储过程,如果有就删除
drop procere sp_helpdb
go

create procere sp_helpdb --创建名为sp_helpdb存储过程
as
create database studb --在存储过程里创建数据库
on primary
(
--创建主文件
name = studb_mdf,
filename = '存储路径\studba_mdf,mdf',
size = 3mb,
maxsize = 100mb,
filegrowth = 1mb
)
on log
(
--创建日志文件
name = studb_ldf,
filename = '存储路径\studba_ldf,ldf',
size = 3mb,
maxsize = 200mb,
filegrowth = 1mb
)
go

Ⅳ SQL作业 使用T-SQL语句创建下面数据库:

楼上回答很好,我只是加了注释,希望能帮到你
--判断数据库文件是否存在
if exists(select * from sysdatabases where name='ssh')
drop database ssh
--建立数据
create database 09网络1
on primary--文件所在的文件组
(
NAME='09网络1_data', --数据库主文件的名称
FILENAME='C:\09网络1_data.mdf', --数据库文件的存放位置
size=55mb, --数据库的初始化大小
maxsize=100mb, --数据库的最大的存储大小
FILEGROWTH=10% --增长率
)
--建立日志文件
LOG ON
(
NAME='09网络1_log', --数据库日志文件的名称
FILENAME='C:\09网络1_log.ldf', --数据库日志文件的存放位置
size=12mb, --数据库日志文件的初始化大小
maxsize=25mb, --数据库日志文件的最大的存储大小
FILEGROWTH=3 --增长率
)

Ⅵ Sql语句创建数据文件,和日志文件问题

你看你,怎么这么不小心啊,首先你的语法是没有错误的,但是你看你的日志文件名字怎么和主数据库文件名一样啊,把你的日志文件名改成hufang_log就行了啊!!!呵呵!!
Log on
(
/*--日志文件具体描述同上--*/
name='hufang_log',
Filename='F:\project\hufang_log.ldf',
Size=2MB,
MaxSize=10MB,
FIleGrowth=15%

)
go

Ⅶ 1、用T-SQL语句创建一个如下要求的数据库。

create database XSCJ
on primary -- 默认就属于primary文件组,可省略
(
/*--数据文件的具体描述--*/
name='xscj_data', -- 主数据文件的逻辑名称
filename='D:\sqlwork\txscj_data.mdf'-- 主数据文件的物理名称
size=5mb, --主数据文件的初始大小
maxsize=50mb, -- 主数据文件增长的最大值
filegrowth=10%--主数据文件的增长率
)
log on
(
/*--日志文件的具体描述,各参数含义同上--*/
name='xscj_log',
filename='D:\sqlwork\xscj_log.ldf',
size=3mb,
maxsize=30mb,
filegrowth=10%
)

IF EXISTS (SELECT name FROM sys.databases WHERE name = N'xscj_data2')
DROP DATABASE [xscj_data2]
GO

Ⅷ 用T-SQL语句完成创建与管理数据库操作:

用T-SQL语句完成创建与管理数据库操作方法:

createdatabase网络1on
primary
(
name=网络1_data,
filename='c:网络1_data.mdf',
size=55mb,
maxsize=100mb,
filegrowth=10%
)
logon
(
name=网络1_log,
filename='c:网络1_log.ldf',
size=12mb,
maxsize=25mb,
filegrowth=3mb
)