sql .Split

 USE [QPRS]
GO
/****** Object:  UserDefinedFunction [dbo].[Split]    Script Date: 10/18/2011 11:16:00 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author:  sound
-- Create date: 2011/11/05
-- Description: 分割成In能用的數據如 in('1','3','5','7')
-- =============================================
-- Change History
-- ---------------------------------------------
-- Modifier: <Modifier 1,,> Date: <Modify Date 1,,>
-- Description:
-- Modifier: <Modifier 2,,> Date: <Modify Date 2,,>
-- Description:
-- =============================================
ALTER   FUNCTION [dbo].[Split]  
(  
@c VARCHAR(MAX) ,  
@split VARCHAR(50)  
)  
RETURNS @t TABLE ( col VARCHAR(50) )  
AS 
BEGIN
SET @c=Replace(@c,'''','') 
    WHILE ( CHARINDEX(@split, @c) <> 0 )  
    BEGIN 
            INSERT  @t( col )  
            VALUES  ( SUBSTRING(@c, 1, CHARINDEX(@split, @c) - 1) )  
            SET @c = STUFF(@c, 1, CHARINDEX(@split, @c), '')  
        END 
    INSERT  @t( col ) VALUES  ( @c )  
    RETURN 
END 
优化代码 def align_annotations(formatted_sql): lines = formatted_sql.split('\n') fields = [] ass=[] comments = [] for line in lines: if line.strip(): line=line.replace('\t',' ') if line.lower().startswith(("where", "left", "on","from","and","group")): fields.append(line) ass.append('') comments.append('') elif ' as ' in line.lower() and '--' in line : parts=line.replace(' as ',' -- ').replace(' AS ',' -- ').split('--') fields.append(parts[0]) ass.append(parts[1]) comments.append(parts[2]) elif ' as ' in line.lower() and '--' not in line : parts=line.replace(' as ',' AS ').split(' AS ') fields.append(parts[0]) ass.append(parts[1]) comments.append('') elif ' as ' not in line.lower() and '--' in line : parts=line.split('--') fields.append(parts[0]) ass.append('') comments.append(parts[1]) else: fields.append(line) ass.append('') comments.append('') # 计算每列的最大长度 max_field_length = max(len(field.strip()) for field in fields if not field.lower().strip().startswith(("where", "left", "on","from","and","group","inner"))) max_as_s_length = max(len(as_s.strip()) for as_s in ass) # 格式化字段、字段类型和注释,并生成新的建表语句 formatted_lines = [] for field,as_s, comment in zip(fields,ass, comments): formatted_field = f"{field.strip()}".ljust(max_field_length) if as_s.strip(): formatted_as_s = f"AS {as_s.strip()}".ljust(max_as_s_length+3) else: formatted_as_s=''.ljust(max_as_s_length+3 ) if comment.strip(): formatted_comment = f"-- {comment}" else: formatted_comment='' formatted_line = f" {formatted_field} {formatted_as_s} {formatted_comment}" formatted_lines.append(formatted_line) formatted_select_statement = "\n".join(formatted_lines) return formatted_select_statement
05-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值