当前位置:  数据库>sqlserver
本页文章导读:
    ▪查询所有数据库文件的可用空间      有时候会查询一下实例下所有数据库文件的可用空间,SSMS上没有汇总的地方,仪表盘又只日志文件的可用空间,于是写了一个SP自己用./** author:Joe.TJ date:20130328 desc:get the free space of database file**.........
    ▪SQL Service自定义数据类型      直接在 SQLQuery 执行下就好了。CREATE TYPE [dbo].[D_bigint(8)] FROM [bigint] NULLCREATE TYPE [dbo].[D_bit] FROM [bit] NULLCREATE TYPE [dbo].[D_datetime(8)] FROM [datetime] NULLCREATE TYPE [dbo].[D_int(4)] FROM [int] NULLCREATE TYPE [dbo].[D_te.........
    ▪MSSQL与MYSQL区别      1 mysql支持enum,和set类型,sql server不支持2 mysql不支持nchar,nvarchar,ntext类型3 mysql的递增语句是AUTO_INCREMENT,而mssql是identity(1,1)4 msms默认到处表创建语句的默认值表示是((0)),而在mysql里面是不允许带.........

[1]查询所有数据库文件的可用空间
    来源:    发布时间: 2013-10-15

有时候会查询一下实例下所有数据库文件的可用空间,SSMS上没有汇总的地方,仪表盘又只日志文件的可用空间,于是写了一个SP自己用.

/**
author:Joe.TJ
date:20130328
desc:get the free space of database file
**/
create proc usp_GetFreeSpace
as
set nocount on;
declare csr cursor for select name from sys.databases where database_id>4;
declare @cmd varchar(2000);
declare @db varchar(50);
create table #res([db_name] varchar(50),[file_name] varchar(50),current_size_mb float,free_space_mb float);
open csr
fetch next from csr into @db;
while(@@FETCH_STATUS=0)
begin
set @cmd=
'use '+@db+
' select DB_NAME() as db_name,name as file_name,
size/128.0 as current_size_mb,(size-FILEPROPERTY(name,''SpaceUsed''))/128.0 as free_space_mb
from sys.database_files';
insert into #res
exec(@cmd);
fetch next from csr into @db;
end
close csr;
deallocate csr;
select * from #res;
drop table #res;
set nocount off;

本文链接


    
[2]SQL Service自定义数据类型
    来源:    发布时间: 2013-10-15
直接在 SQLQuery 执行下就好了。

CREATE TYPE [dbo].[D_bigint(8)] FROM [bigint] NULL

CREATE TYPE [dbo].[D_bit] FROM [bit] NULL

CREATE TYPE [dbo].[D_datetime(8)] FROM [datetime] NULL

CREATE TYPE [dbo].[D_int(4)] FROM [int] NULL

CREATE TYPE [dbo].[D_text] FROM [text] NULL

CREATE TYPE [dbo].[D_varchar(10)] FROM [varchar](10) NULL

CREATE TYPE [dbo].[D_varchar(50)] FROM [varchar](50) NULL

CREATE TYPE [dbo].[D_varchar(100)] FROM [varchar](100) NULL

CREATE TYPE [dbo].[D_varchar(225)] FROM [varchar](225) NULL

CREATE TYPE [dbo].[D_varchar(2000)] FROM [varchar](2000) NOT NULL

CREATE TYPE [dbo].[D_nvarchar(50)] FROM nvarchar(50) NOT NULL

CREATE TYPE [dbo].[D_nvarchar(100)] FROM nvarchar(100) NOT NULL

CREATE TYPE [dbo].[D_nvarchar(225)] FROM nvarchar(225) NOT NULL

CREATE TYPE [dbo].[D_nvarchar(2000)] FROM nvarchar(2000) NOT NULL

 

本文链接


    
[3]MSSQL与MYSQL区别
    来源:    发布时间: 2013-10-15

1 mysql支持enum,和set类型,sql server不支持

2 mysql不支持nchar,nvarchar,ntext类型

3 mysql的递增语句是AUTO_INCREMENT,而mssql是identity(1,1)

4 msms默认到处表创建语句的默认值表示是((0)),而在mysql里面是不允许带两括号的

5 mysql需要为表指定存储类型

6 mssql识别符是[],[type]表示他区别于关键字,但是mysql却是 `,也就是按键1左边的那个符号

7 mssql支持getdate()方法获取当前时间日期,但是mysql里面可以分日期类型和时间类型,获取当前日期是cur_date(),当前完整时间是 now()函数

8 mssql不支持replace into 语句,但是在最新的sql20008里面,也支持merge语法

9 mysql支持insert into table1 set t1 = ‘’, t2 = ‘’ ,但是mssql不支持这样写

10 mysql支持insert into tabl1 values (1,1), (1,1), (1,1), (1,1), (1,1), (1,1), (1,1)

11 mssql不支持limit语句,是非常遗憾的,只能用top 取代limt 0,N,row_number() over()函数取代limit N,M

12 mysql在创建表时要为每个表指定一个存储引擎类型,而mssql只支持一种存储引擎

13 mysql不支持默认值为当前时间的datetime类型(mssql很容易做到),在mysql里面是用timestamp类型

14 mssql里面检查是否有这个表再删除,需要这样:

if   exists   (select   *   from   dbo.sysobjects   where   id   =   object_id(N'uc_newpm')  and   OBJECTPROPERTY(id,   N'IsUserTable')   =   1) 

但是在mysql里面只需要 DROP TABLE IF EXISTS cdb_forums;

15 mysql支持无符号型的整数,那么比不支持无符号型的mssql就能多出一倍的最大数存储

16 mysql不支持在mssql里面使用非常方便的varchar(max)类型,这个类型在mssql里面既可做一般数据存储,也可以做blob数据存储

17 mysql创建非聚集索引只需要在创建表的时候指定为key就行,比如:KEY displayorder (fid,displayorder) 在mssql里面必须要:create unique nonclustered index index_uc_protectedmembers_username_appid ondbo.uc_protectedmembers

(username asc,appid asc)

 

18 mysql text字段类型不允许有默认值

19mysql的一个表的总共字段长度不超过65XXX。

20一个很表面的区别就是mysql的安装特别简单,而且文件大小才110M(非安装版),相比微软这个庞然大物,安装进度来说简直就是.....

21mysql的管理工具有几个比较好的,mysql_front,和官方那个套件,不过都没有SSMS的使用方便,这是mysql很大的一个缺点。

22mysql的存储过程只是出现在最新的版本中,稳定性和性能可能不如mssql。

23 同样的负载压力,mysql要消耗更少的CPU和内存,mssql的确是很耗资源。

24php连接mysql和mssql的方式都差不多,只需要将函数的mysql替换成mssql即可。 

25mysql支持date,time,year类型,mssql到2008才支持date和time。

本文链接


    
最新技术文章:
▪Sql Server里删除数据表中重复记录的例子
▪如何查看SQLSERVER中某个查询用了多少TempDB空间...
▪在SQL Server中使用ISNULL执行空值判断查询
▪揭秘SQL Server 2014有哪些新特性(1)-内存数据库
▪揭秘SQL Server 2014有哪些新特性(2)-固态硬盘 Buff...
▪揭秘SQL Server 2014有哪些新特性(3)-可更新列存...
▪揭秘SQL Server 2014有哪些新特性(4)-原生备份加...
▪解决SqlServer 各版本 sa帐户不能登录问题
▪浅析SQL Server中包含事务的存储过程
▪深入分析MSSQL数据库中事务隔离级别和锁机制
▪SQL优化技巧指南
▪人工智能自动sql优化工具--SQLTuning for SQL Server
▪使用 TOP 子句限制UPDATE 语句更新的数据
▪sql server动态存储过程按日期保存数据示例
▪SQLServer用存储过程实现插入更新数据示例
▪SqlServer中tempdb的日志机制原理解析及示例分享...
▪SqlServer数据库提示 “tempdb” 的日志已满 问题...
▪浅谈tempdb在SqlServer系统中的重要作用
▪SqlServer提示“列前缀tempdb.无效: 未指定表名”...
▪SQL命令优化需要记住的9点事项
▪教你如何看懂SQL Server查询计划
▪sql server 2000数据库备份还原的图文教程
▪SqlServer2012中First_Value函数简单分析
▪sql语句中单引号嵌套问题(一定要避免直接嵌...
▪谈谈sqlserver自定义函数与存储过程的区别
▪SQL SERVER使用REPLACE将某一列字段中的某个值替...
▪总结一周内学习的Sql经验(一)
▪sql存储过程详解
▪SQL Server UPDATE语句的用法详解
▪MSSQL事务的存储过程
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3