Sql 继续VBA代码到新行
我在Sql 继续VBA代码到新行,sql,vba,excel,Sql,Vba,Excel,我在Excel中的CommandButton后面编写了VBA代码,但似乎CommandText只能容纳一定数量的字符 这是我的代码(在一行上): 我需要上面的代码分为2或3行 这就是我尝试过的: .CommandText = "SELECT ID, " & Resp & _ "Employee, " & Resp & _ "WT, " & Resp & _ "[Amount Per Kilometer
Excel
中的CommandButton
后面编写了VBA
代码,但似乎CommandText
只能容纳一定数量的字符
这是我的代码(在一行上):
我需要上面的代码分为2或3行
这就是我尝试过的:
.CommandText = "SELECT ID, " & Resp & _
"Employee, " & Resp & _
"WT, " & Resp & _
"[Amount Per Kilometer], " & Resp & _
"Currency, " & Resp & _
"SUM([Number (Amount of km)]) AS [Number (Amount of km)], " & Resp & _
"SUM([Total (per record)]) AS [Total (per record)] " & Resp & _
"FROM ( " & Resp & _
"SELECT S.ID, " & Resp & _
"S.FirstName + ' ' + S.LastName AS [Employee], " & Resp & _
"C.Customer_Name, " & Resp & _
"NULL AS [WT], " & Resp & _
"EC.AA_Rate AS [Amount Per Kilometer], " & Resp & _
"NULL AS [Currency], " & Resp & _
"TS.Travel AS [Number (Amount of km)], " & Resp & _
"TS.Travel * CONVERT(float,EC.AA_Rate) AS [Total (per record)] " & Resp & _
"FROM [Timesheets].[dbo].[timesheets] TS " & Resp & _
"INNER JOIN [Timesheets].[dbo].[staff] S ON TS.Staff_Code = S.Staff_Code " & Resp & _
"INNER JOIN [Timesheets].[dbo].[enginecapacity] EC ON TS.EngineCapacityCode = EC.EngineCapacityCode " & Resp & _
"INNER JOIN [Timesheets].[dbo].[customers] C ON TS.Cust_Code = C.Cust_Code " & Resp & _
"WHERE TS.DateWorked BETWEEN " & Resp & _
"LEFT('"& FromDate &"', 4) + SUBSTRING('"& FromDate &"',CHARINDEX('/','"& FromDate &"')+1,LEN('"& FromDate &"') - CHARINDEX('/','2014/12/31') - CHARINDEX('/',REVERSE('2014/12/31'))) + RIGHT('"& FromDate &"',2) " & Resp & _
"AND LEFT('"& ToDate &"', 4) + SUBSTRING('"& ToDate &"',CHARINDEX('/','"& ToDate"')+1,LEN('"& ToDate &"') - CHARINDEX('/','"& ToDate &"') - CHARINDEX('/',REVERSE('"& ToDate &"'))) + RIGHT('"& ToDate &"',2)) " & Resp & _
"as A GROUP BY ID,Employee,WT,[Amount Per Kilometer],Currency"
当运行上述命令时,我得到一个语法错误
任何帮助都将不胜感激。问题是在最后第二行的第三个日期之后缺少&
。可能的重复查看此问题的第二个答案link@G_hi3,谢谢你的链接。我已经看到了答案,但在执行时仍然有错误。Joehanna停止了丢失的&
。实际上我读错了文本,我认为在&
运算符之后不允许换行
.CommandText = "SELECT ID, " & Resp & _
"Employee, " & Resp & _
"WT, " & Resp & _
"[Amount Per Kilometer], " & Resp & _
"Currency, " & Resp & _
"SUM([Number (Amount of km)]) AS [Number (Amount of km)], " & Resp & _
"SUM([Total (per record)]) AS [Total (per record)] " & Resp & _
"FROM ( " & Resp & _
"SELECT S.ID, " & Resp & _
"S.FirstName + ' ' + S.LastName AS [Employee], " & Resp & _
"C.Customer_Name, " & Resp & _
"NULL AS [WT], " & Resp & _
"EC.AA_Rate AS [Amount Per Kilometer], " & Resp & _
"NULL AS [Currency], " & Resp & _
"TS.Travel AS [Number (Amount of km)], " & Resp & _
"TS.Travel * CONVERT(float,EC.AA_Rate) AS [Total (per record)] " & Resp & _
"FROM [Timesheets].[dbo].[timesheets] TS " & Resp & _
"INNER JOIN [Timesheets].[dbo].[staff] S ON TS.Staff_Code = S.Staff_Code " & Resp & _
"INNER JOIN [Timesheets].[dbo].[enginecapacity] EC ON TS.EngineCapacityCode = EC.EngineCapacityCode " & Resp & _
"INNER JOIN [Timesheets].[dbo].[customers] C ON TS.Cust_Code = C.Cust_Code " & Resp & _
"WHERE TS.DateWorked BETWEEN " & Resp & _
"LEFT('"& FromDate &"', 4) + SUBSTRING('"& FromDate &"',CHARINDEX('/','"& FromDate &"')+1,LEN('"& FromDate &"') - CHARINDEX('/','2014/12/31') - CHARINDEX('/',REVERSE('2014/12/31'))) + RIGHT('"& FromDate &"',2) " & Resp & _
"AND LEFT('"& ToDate &"', 4) + SUBSTRING('"& ToDate &"',CHARINDEX('/','"& ToDate"')+1,LEN('"& ToDate &"') - CHARINDEX('/','"& ToDate &"') - CHARINDEX('/',REVERSE('"& ToDate &"'))) + RIGHT('"& ToDate &"',2)) " & Resp & _
"as A GROUP BY ID,Employee,WT,[Amount Per Kilometer],Currency"