AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / dba / 问题 / 189048
Accepted
Nisar Afridi
Nisar Afridi
Asked: 2017-10-23 02:05:49 +0800 CST2017-10-23 02:05:49 +0800 CST 2017-10-23 02:05:49 +0800 CST

SQL Server Express 2012 数据库大小限制

  • 772

我检查了论坛还有其他类似的主题,但我的情况不同。对于数据库属性下的 myDatabase -> 常规选项卡,它显示:

Size : 25285.31 MB
Space Available: 3989.13 MB

并在磁盘上

myDB.mdf = 10.0 GB (10,745,806,848 bytes)
myDB_log.ldf = 14.6 GB (15,767,764,992 bytes)

根据我的理解,Expres 版本只允许 10GB,但这里似乎更多。数据库属性中的可用空间参数是什么。

sql-server-express
  • 3 3 个回答
  • 13953 Views

3 个回答

  • Voted
  1. Best Answer
    Dan
    2017-10-23T16:50:40+08:002017-10-23T16:50:40+08:00

    SQL Server Express 仅对数据文件施加文件大小限制,日志文件可以增长到任意大小。数据库属性窗口中显示的大小是数据和日志文件的组合大小。

    不过有些令人困惑的是,此窗口上显示的可用空间值仅与数据文件有关。如果您想更详细地了解这一点,我建议您查询系统表,而不是依赖 SSMS GUI(它并不总是会给您想要/需要的信息)。以下脚本将显示有关数据文件大小/增长设置的一些更详细信息:

    SELECT 
        [TYPE] = DF.TYPE_DESC
        ,[FILE_Name] = DF.name
        --,[FILEGROUP_NAME] = FG.name
        ,[File_Location] = DF.PHYSICAL_NAME
        ,[FILESIZE_MB] = CONVERT(DECIMAL(10,2),DF.SIZE/128.0)
        ,[USEDSPACE_MB] = CONVERT(DECIMAL(10,2),DF.SIZE/128.0 - ((SIZE/128.0) - CAST(FILEPROPERTY(DF.NAME, 'SPACEUSED') AS INT)/128.0))
        ,[FREESPACE_MB] = CONVERT(DECIMAL(10,2),DF.SIZE/128.0 - CAST(FILEPROPERTY(DF.NAME, 'SPACEUSED') AS INT)/128.0)
        ,[FREESPACE_%] = CONVERT(DECIMAL(10,2),((DF.SIZE/128.0 - CAST(FILEPROPERTY(DF.NAME, 'SPACEUSED') AS INT)/128.0)/(DF.SIZE/128.0))*100)
        ,[AutoGrow] = 'By ' + CASE is_percent_growth WHEN 0 THEN CAST(growth/128 AS VARCHAR(10)) + ' MB -' 
            WHEN 1 THEN CAST(growth AS VARCHAR(10)) + '% -' ELSE '' END 
            + CASE max_size WHEN 0 THEN 'DISABLED' WHEN -1 THEN ' Unrestricted' 
                ELSE ' Restricted to ' + CAST(max_size/(128*1024) AS VARCHAR(10)) + ' GB' END 
            + CASE is_percent_growth WHEN 1 THEN ' [WARNING: Autogrowth by percent]' ELSE '' END
    FROM sys.database_files DF
    LEFT JOIN sys.filegroups FG
    ON DF.data_space_id = FG.data_space_id 
    order by DF.TYPE desc, DF.NAME; 
    

    顺便说一句:由于您的数据文件已经是 10GB,未来的增长操作将失败(并且任何触发增长的事务都会生成主文件组已满错误)。由于该文件被精确设置为 10GB,我怀疑它已经故意增长到这个数量以利用 SQL Express 提供的全部空间。

    • 5
  2. Slime recipe
    2017-10-23T02:35:50+08:002017-10-23T02:35:50+08:00

    随着数据库的增长,SQL Server 将分配更多的磁盘空间。您可以从 1GB 开始,但随着时间的推移它会增长到 3GB。由于为每条记录重新分配效率低下,它会增长 x% 或 xMB(您可以定义这些)。可用空间是在下一次增长之前您可以使用多少空磁盘空间。

    如果由于某种原因您相信您的数据库已经增长到不切实际的大小,您可以使用DBCC SHRINKDATABASE(<YourDatabaseName>)

    至于快递限额,我不确定它是如何计算的。但是您的大部分数据库大小可能都是日志文件,尤其是在您进行了大量更新和删除并且没有进行任何备份的情况下。

    您可以检查日志文件大小:

    DBCC SQLPERF (LOGSPACE)
    

    如果您发现日志文件确实过大并且您不需要时间点恢复选项,您可以将恢复模式更改为简单,这将显着减少它的增长

    恢复模型: https ://learn.microsoft.com/en-us/sql/relational-databases/backup-restore/recovery-models-sql-server

    • 1
  3. Ubercoder
    2018-01-17T08:47:07+08:002018-01-17T08:47:07+08:00

    您询问的“数据库属性中的可用空间参数”是数据文件(mdf)和事务日志文件(ldf)中的未分配空间。mdf 文件大小并不总是准确的,因为它包含未分配的数据页,并且(通常)在不再需要数据页时不会缩小。

    准确查找已用空间的一种快速方法是运行 SQL 命令:

    exec sp_helpdb 'myDatabase';
    

    这显示了两个结果集。在第二个结果集中,第一行显示“大小”列中数据页的分配大小,这是您最准确的估计。

    编辑:“maxsize”列显示允许文件增长到的最大大小,或者可以是“无限制”以允许文件增长以使用整个磁盘。将“maxsize”设置为一个实际数字很有用,然后如果您在一个磁盘上有多个数据库,您可以设置大小以防止一个数据库用完所有磁盘空间。

    但是:SQL Server Express 的 10GB 限制具有优先权,因此即使您有 maxsize = Unlimited(或 maxsize = 20GB 或其他),您也会发现实际数据库大小不会超过 10GB。

    • 1

相关问题

  • 从默认位置移动 SQL Server LocalDB 实例的文件夹

  • 哪个 SQL Server Express 版本适合我?

  • 在与普通 SQL Server 2008 安装相同的机器上安装 SQL Server 2008 Express?

  • sql server 中的数据类型,相似数据类型之间的区别,数字,金钱,小数,浮点数

  • 在没有管理权限的情况下安装 SQL Server Express

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目

    • 12 个回答
  • Marko Smith

    如何让sqlplus的输出出现在一行中?

    • 3 个回答
  • Marko Smith

    选择具有最大日期或最晚日期的日期

    • 3 个回答
  • Marko Smith

    如何列出 PostgreSQL 中的所有模式?

    • 4 个回答
  • Marko Smith

    列出指定表的所有列

    • 5 个回答
  • Marko Smith

    如何在不修改我自己的 tnsnames.ora 的情况下使用 sqlplus 连接到位于另一台主机上的 Oracle 数据库

    • 4 个回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Martin Hope
    Jin 连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane 如何列出 PostgreSQL 中的所有模式? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh 为什么事务日志不断增长或空间不足? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland 列出指定表的所有列 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney MySQL 能否合理地对数十亿行执行查询? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx 如何监控大型 .sql 文件的导入进度? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve