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 / 问题

问题[t-sql](dba)

Martin Hope
adriano
Asked: 2024-10-26 04:20:34 +0800 CST

从 T-SQL 查询输出中删除 NULL

  • 7

在网上找到了这个漂亮的查询(不记得要感谢谁了),并尝试修改它,以便没有值的 backup_finish_date 不会输出为 NULL,但一直没能弄明白。这个查询完全符合我的要求(我自己也学会了),唯一的例外是输出 NULL。我还想把它格式化为 dd-mm-yyyy hh:mm

SELECT  name ,
        recovery_model_desc as 'Recovery Model' ,
        state_desc as 'State',
        d AS 'Last Full Backup' ,
        i AS 'Last Differential Backup' ,
        l AS 'Last log Backup'
FROM    ( SELECT    db.name ,
                    db.state_desc ,
                    db.recovery_model_desc ,
                    type ,
                    backup_finish_date
          FROM      master.sys.databases db
                    LEFT OUTER JOIN msdb.dbo.backupset a ON a.database_name = db.name
        ) AS Sourcetable
    PIVOT
        ( MAX(backup_finish_date)  FOR type IN ( D, I, L ) ) AS MostRecentBackup
   WHERE (name NOT IN ('master','msdb','model','tempdb'))
t-sql
  • 1 个回答
  • 68 Views
Martin Hope
user2370668
Asked: 2024-04-20 01:08:07 +0800 CST

根据分隔符从字符串列中提取数据

  • 5

我有一个具有这样价值的专栏。

Declare @Table TABLE (ID int, Val varchar(100))

Insert into @Table
Select 1, 'happy_Summer_Holiday_by_Jan_2024.xlsx'

我想动态提取 Jan 作为月份,2024 年作为年份。

t-sql
  • 1 个回答
  • 14 Views
Martin Hope
Yatish
Asked: 2024-03-05 19:47:18 +0800 CST

不同分区上的列中的不同组合

  • 5

这是一个简单的表格

用户身份 角色ID
1 1
1 2
1 3
1 4
2 1
2 2
2 3
2 4
3 1
3 2
3 3

我试图在不同用户的 RoleId 列中找到不同的组合。在此示例中,我可以看到有 3 个用户,但有两个不同的角色组合。

用户 1 和 2 具有 [1,2,3,4] 角色,用户 3 具有 [1,2,3] 角色。我无法理解 T-Sql 中是否可以使用 PARTITION 函数返回这些不同的组合。

t-sql
  • 2 个回答
  • 37 Views
Martin Hope
J. Mini
Asked: 2023-12-28 06:49:52 +0800 CST

除了显式刷新缓存或要求重新编译之外,什么会重新编译 SQL Server 2019 中的完整存储过程?

  • 5

我最近读完 《SQL Server 2008 中的计划缓存》 ,我感到很困惑。看起来,除了完全刷新计划缓存或明确要求重新编译存储过程之外,从 SQL Server 2008 开始,存储过程的重新编译都是在语句级别而不是存储过程级别完成的。

那么,除了显式刷新缓存或要求重新编译(例如WITH RECOMPILE)之外,什么可以在 SQL Server 2019 中重新编译完整的存储过程,而不仅仅是重新编译单个语句呢?

举一个我感到困惑的例子,请考虑以下过程。

CREATE PROCEDURE FOO AS
BEGIN
   SELECT * INTO #temp1 FROM table1
   INSERT BAR1 SELECT * FROM #temp1
   INSERT BAR2 SELECT * FROM #temp1
END

我可以想到很多可能导致SELECT * INTO #temp1 FROM table1重新编译的事情,但是如果没有下一行也重新编译,那么重新编译会很奇怪。这让我觉得 SQL Server 中一定有一些东西会导致整个存储过程重新编译。

t-sql
  • 2 个回答
  • 101 Views
Martin Hope
The amateur programmer
Asked: 2023-12-22 19:03:07 +0800 CST

了解 MS SQL TSQL 事务中的表锁定

  • 6

我想让旧的后续查询在并行运行时免受数据竞争的影响。该查询使用特定条件检查表中是否存在一行,如果不存在该行,则会插入包含新数据的新行。旧查询粘贴如下:

BEGIN
    DECLARE @txtPer VARCHAR(MAX) = @nro;
    DECLARE @txtCmin VARCHAR(MAX) = @min;
    DECLARE @txtCmax VARCHAR(MAX) = @max;
    IF NOT EXISTS (SELECT 1 FROM SEND WHERE MSG LIKE (@txtPer + '%') AND STATE < 2 AND ID = 1)
    BEGIN
        ----Time of check is not time of use
        ----Someone could possibly do another insert before this == data race
        INSERT INTO SEND (SNDID, ID, MSGCODE, MSG, STATE, INFO, INFO_TEXT, CHANGEDATE, CREATEDATE)
        SELECT MAX(SNDID)+10,1,1,(@txtPer + @txtCmin + '           ' + @txtCmax),0,0,' ',getdate(),getdate() FROM SEND
    END
END

我想出了一个稍微干净一点的新版本,并使用独占表锁:

BEGIN TRANSACTION;
DECLARE @txtPer VARCHAR(MAX) = @nro;
DECLARE @txtCmin VARCHAR(MAX) = @min;
DECLARE @txtCmax VARCHAR(MAX) = @max;

DECLARE @IdMax INT
--Get MAX and simultaneously acquire lock for the table to prevent modifications during this transaction?
SELECT @IdMax=MAX(SNDID) FROM SEND WITH(TABLOCKX)

IF NOT EXISTS(SELECT 1 FROM SEND WHERE MSG LIKE (@txtPer + '%') AND STATE < 2 AND ID = 1)
BEGIN
    INSERT INTO SEND (SNDID, ID, MSGCODE, MSG, STATE, INFO, INFO_TEXT, CHANGEDATE, CREATEDATE)
    VALUES((@IdMax + 10),1,1,(@txtPer + @txtCmin + '           ' + @txtCmax),0,0,' ',getdate(),getdate())
END
COMMIT; --writes potential change and releases table lock?

我的理解是否正确,即在操作期间获取的表锁SELECT MAX()(可能还有同一事务中的其他表锁)一直保留到整个事务完成该COMMIT语句?DB 是旧的 MS SQL Server 2005。

t-sql
  • 2 个回答
  • 73 Views
Martin Hope
adam.g
Asked: 2023-08-28 23:28:53 +0800 CST

我可以为包含禁用更改跟踪/截断/分区开关的动态 SQL 执行事务吗

  • 5

我想创建交易,它将:

  1. 如果存在则禁用更改跟踪。
  2. 表的 TRUNCATE 分区。
  3. 将分区从不同的表切换到主表。
  4. ENABLE 更改跟踪 IF 之前被禁用。

想要创建带有参数的脚本,所以我将使用动态 SQL。主意:

/* OPS parameters */
DECLARE @schemaName sysname = 'dbo';
DECLARE @tableName sysname = 'TABLE';
DECLARE @partition INT = 90;  

/* DEV parameters */
DECLARE @tableNameSRP sysname = CONCAT(@tableName, '_SRP');
DECLARE @tableNameWithSchema sysname = CONCAT(QUOTENAME(@schemaName), '.', QUOTENAME(@tableName));
DECLARE @tableNameWithSchemaSRP sysname = CONCAT(QUOTENAME(@schemaName), '.', QUOTENAME(@tableNameSRP));
DECLARE @isCtReEnabled BIT = 0;
DECLARE @isDebug BIT = 1;


SET TRAN ISOLATION LEVEL READ UNCOMMITTED;
SET XACT_ABORT ON;
BEGIN TRAN;
BEGIN TRY
    IF EXISTS (
        SELECT
            1
        FROM sys.change_tracking_tables
        WHERE object_id = OBJECT_ID(@tableNameWithSchema)
    )
    BEGIN

        SET @statement = N'ALTER TABLE ' + @tableNameWithSchema + N' DISABLE CHANGE_TRACKING;';
        IF (@isDebug = 0)
        BEGIN
            EXEC sp_executesql @stmt = @statement;
        END;
        IF (@isDebug = 1)
        BEGIN
            RAISERROR('[INFO] SQL: %s', 0, 1, @statement) WITH NOWAIT;
        END;
        SET @isCtReEnabled = 1;
    END;

    SET @statement
        = N'TRUNCATE TABLE ' + @tableNameWithSchema + N' WITH (PARTITIONS (' + CAST(@partition AS NVARCHAR(5)) + N')) 
ALTER TABLE '        + @tableNameWithSchemaSRP + N' SWITCH PARTITION ' + CAST(@partition AS NVARCHAR(5)) + N' TO ' + @tableNameWithSchema + N' PARTITION '
          + CAST(@partition AS NVARCHAR(5));
    IF (@isDebug = 0)
    BEGIN
        EXEC sp_executesql @stmt = @statement;
    END;
    IF (@isDebug = 1)
    BEGIN
        RAISERROR('[INFO] SQL: %s', 0, 1, @statement) WITH NOWAIT;
    END;

    IF (@isCtReEnabled = 1)
    BEGIN
        SET @statement = N'ALTER TABLE ' + @tableNameWithSchema + N' ENABLE CHANGE_TRACKING;';
        IF (@isDebug = 0)
        BEGIN
            EXEC sp_executesql @stmt = @statement;
        END;
        IF (@isDebug = 1)
        BEGIN
            RAISERROR('[INFO] SQL: %s', 0, 1, @statement) WITH NOWAIT;
        END;
    END;
    COMMIT;

END TRY
BEGIN CATCH
    SET @errorMessage = ERROR_MESSAGE();
    RAISERROR('ERROR MESSAGE: %s', 0, 1, @errorMessage) WITH NOWAIT;
    IF @@TRANCOUNT > 0
        ROLLBACK TRANSACTION;
END CATCH;

我的问题:

  1. 启用/禁用更改跟踪、截断和分区切换等操作是否可以在一个事务中进行?(想要执行全部或不执行)
  2. 在这种情况下动态sql有问题吗?
t-sql
  • 1 个回答
  • 21 Views
Martin Hope
RaGe
Asked: 2023-07-20 22:04:58 +0800 CST

TSQL使用数字表计算2个不同的列

  • 6

我尝试使用数字表按月间隔计算 2 个不同的日期列:

数字表:

编号
0
1
2
3

原始表(示例):

性别 订阅_日期 取消日期
男性 2023-01-01 2023-05-01
男性 2023-01-05 2023-01-08
男性 2023-01-05 2023-03-09
男性 2023-02-01 2023-04-08
女性 2023-01-05 2023-04-08
女性 2023-01-07 无效的

最终输出应该是这样的:

报告月 性别 订阅 取消
2023-01-01 男性 3 1
2023-01-01 女性 2 0
2023-02-01 男性 1 0
2023-02-01 女性 0 0
2023-03-01 男性 0 1
2023-03-01 女性 0 0
2023-04-01 男性 0 1
2023-04-01 女性 0 1
2023-05-01 男性 0 0
2023-05-01 女性 1 0

第一次尝试:

-- first day of the current month, one year ago
DECLARE @StartDate date = DATEADD(year,-1,DATEADD(month,datediff(month,0,getdate()),0)) 
-- Start from StartDate, showing results for Subscriptions for each month
SELECT
   @StartDate AS StartDate, Numbers.Num, DATEADD(month, Numbers.Num, @StartDate) AS ReportMonth
   ,S.Gender
   ,COUNT(S.SubscriptionDate) AS Subscriptions
FROM Numbers
JOIN
OriginatingTable AS S ON DATEADD(month, Numbers.Num, @StartDate) = DATEADD(MONTH, DATEDIFF(MONTH, 0, S.SubscriptionDate), 0)
WHERE (Numbers.Num <= DATEDIFF(month, @StartDate, GETDATE())) 
GROUP BY Numbers.Num, DATEADD(month, Numbers.Num, @StartDate), DATEADD(MONTH, DATEDIFF(MONTH, 0, S.Subscription_Date), 0), S.Gender
ORDER BY Numbers.Num

这可行,但我无法整合第二列“取消”。

感谢您的帮助,

拉尔夫.

t-sql
  • 2 个回答
  • 32 Views
Martin Hope
gregoryp
Asked: 2023-06-06 02:03:53 +0800 CST

ROW_NUMBER() 与 OUTER APPLY

  • 5

我有一个查询,通过使用枚举 的分组(分区)中的行来返回Pricea 的最低值,按升序排序(MIN 函数在将列添加到 SELECT 后返回多行)。ProductVariationROW_NUMBER()ProductIdPrice

SELECT 
   pv.Id AS VariationId, 
   pv.ProductId, 
   pv.[Description], 
   pv.Price, 
   pv.Stock,
   ROW_NUMBER() OVER (PARTITION BY pv.ProductId ORDER BY pv.Price, pv.Stock DESC) AS SortId
FROM ProductVariation pv
INNER JOIN Product p ON p.Id = pv.ProductId
WHERE p.CompanyId = @CompanyId

一种Product可以有多种变体。下面是我的ProductVariation桌子。

在此输入图像描述

该查询运行完美并返回以下结果:

变体ID 产品编号 描述 价格 库存 排序编号
149 97 黄色水果 139.99 0.00 1
150 97 红色水果 139.99 5.00 2
151 97 青苹果 139.99 20:00 3
152 98 桃芒果 219.99 0.00 1
153 99 疯狂柠檬 169.99 1.00 1
154 99 北极冰 169.99 3.00 2
155 99 天堂冲床 169.99 3.00 3

然而,现在我们有另一个表,ProductValueConsultor顾问可以在ProductVariation其中单独更新价格。

在此输入图像描述

在里面ProductValueConsultor我们有一行将ProductVariationid 149 的价格更新为 149.00 美元。

商店ID 价格 产品变体 ID
13 149.90 149

所以现在,我更新了查询并添加了OUTER APPLY运算符来识别ProductValueConsultor表中可能的值并显示更新的价格。

SELECT 
   pv.Id AS VariationId, 
   pv.ProductId, 
   pv.[Description], 
   ISNULL(pValue.Price, pv.Price) Price, 
   pv.Stock,
   ROW_NUMBER() OVER (PARTITION BY pv.ProductId ORDER BY pv.Price) AS SortId
FROM ProductVariation pv
OUTER APPLY (
   SELECT TOP 1 * FROM ProductValueConsultor pvc
   WHERE pv.Id = pvc.ProductVariationId AND pvc.StoreId = @StoreId
) pValue
INNER JOIN Product p ON p.Id = pv.ProductId
WHERE p.CompanyId = @CompanyId

操作OUTER APPLY员工作完美,显示了 id 149 的更新价格。ProductVariation但是,该ROW_NUMBER()函数出现故障,显示原始价格的排序顺序。

变体ID 产品编号 描述 价格 库存 排序编号
149 97 黄色水果 149.99 0.00 1
150 97 红色水果 139.99 5.00 2
151 97 青苹果 139.99 20:00 3
152 98 桃芒果 219.99 0.00 1
153 99 疯狂柠檬 169.99 1.00 1
154 99 北极冰 169.99 3.00 2
155 99 天堂冲床 169.99 3.00 3

如何修复此查询以将ROW_NUMBER()函数应用于更新的值OUTER APPLY?

t-sql
  • 1 个回答
  • 44 Views
Martin Hope
scarr030
Asked: 2023-04-28 02:42:20 +0800 CST

无顺序、不同、分组的不同排序运算符

  • 7

我有两个查询,它们大多是同一个 where 表达式。它们联合在一起以获得完整的结果集。查询中没有分组,也没有排序,也没有区别。但是,直接在最终连接/选择运算符之前和任何连接之后有两种不同的类型。鉴于上述信息,我对这些不同的类型感到有点困惑。

任何人都可以深入了解为什么这个运营商在这个计划中吗?

FWIW,我重写了这个查询,只是想填补知识空白/纠正误解。

谢谢

https://www.brentozar.com/pastetheplan/?id=Sy2RJrd7h

t-sql
  • 1 个回答
  • 21 Views
Martin Hope
theHydra
Asked: 2023-04-18 22:40:49 +0800 CST

从 SQL 查询导出数据

  • 5

我有一个 SQL CmdExec 作业设置来运行查询,但是输出数据包含标题、作业信息和返回行的总数作为输出文件的一部分,我试图弄清楚如何排除它,这个项目只需要要返回的原始数据。

根据其他建议,我尝试在查询之前添加“sqlcmd -Q set nocount on;”,并在查询末尾添加“-S localhost -D master -o” ,但额外的数据仍保留在结果中。

非常感谢任何建议。

sqlcmd -Q set nocount on;   
SELECT
cast(coalesce(ARMASTER.CUSTNO, ' ') as char(20)) as [CUSTNO],
cast(coalesce(ARMASTER.INVOICE, ' ') as char(20)) as [INVNO],
cast(coalesce(ITEM.PARTNO, ' ') as char(16)) as [ITEM],
cast(coalesce(ITEM.DESCRIPT, ' ') as char(65)) as [DESCRIP],
cast(coalesce(ITEM.DISRATE, ' ') as char(7)) as [DISC],
cast(coalesce(ITEM.PRICE, ' ') as char(20)) as [PRICE],
cast(coalesce(ITEM.SHIPQTY, ' ') as char(12)) as [QTYSHP],
cast(coalesce(ITEM.TOTPRICE, ' ') as char(20)) as [EXTPRICE],
cast(coalesce(ITEM.CUSERLINE, ' ') as char(10)) as [SEQNUM]

FROM ITEM
JOIN 
armaster ON ITEM.invoice = ARMASTER.invoice

ORDER BY ARMASTER.INVOICE
-S localhost -D master -o
t-sql
  • 2 个回答
  • 48 Views

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