SQL Server 按照分類輸出Excel
--聲明需要的變量
declare @sql varchar(600),@TypeID varchar(6),@MyName varchar(10)
--每個業務員要有一個序號(數字型)
select @TypeID=min(ID) from A_CUST
select @MyName =EMPLOYEE_NAME from A_CUST where ID=@TypeID
--當存在滿足序號的記錄時進行處理
while exists(select 1 from A_CUST where ID=@TypeID)
--拼湊需要執行的語句
set @sql=‘bcp "select * from (select‘+‘‘‘CUSTOMER_CODE‘‘‘+‘ AS 客戶編碼,‘+‘‘‘CUSTOMER_NAME‘‘‘+‘ AS 客戶名稱,‘+‘‘‘CUSTOMER_FULL_NAME‘‘‘+‘ AS 客戶全稱,‘
+‘‘‘EMPLOYEE_CODE‘‘‘+‘ AS 工號,‘+‘‘‘EMPLOYEE_NAME‘‘‘+‘ AS 姓名,‘+‘‘‘ADDRESS‘‘‘+‘ AS 地址,‘+‘‘‘TELEPHONE‘‘‘+‘ AS 電話,‘+‘‘‘CONTACT‘‘‘+‘ AS 聯系人‘--在xls文件中顯示列名
exec master..xp_cmdshell @sql
--獲得下一個業務員的序號(序號是不連續的)
select @TypeID=isnull(min(ID),@TypeID+1) from A_CUST where ID>=@TypeID+1
select @MyName =EMPLOYEE_NAME from A_CUST where ID=@TypeID
end
下面的程序是根據各表關聯生成的視圖
drop view A_CUST
create view A_CUST as select CUSTOMER_CODE,CUSTOMER_NAME,CUSTOMER_FULL_NAME,EMPLOYEE_CODE,EMPLOYEE_NAME,d.ADDRESS,d.TELEPHONE,e.CONTACT,A_C.ID from CUSTOMER a
left join CUSTOMER_SALES b ON a.CUSTOMER_BUSINESS_ID = b.CUSTOMER_ID
left join EMPLOYEE c ON b.Owner_Emp = c.EMPLOYEE_ID
left join A_C ON c.EMPLOYEE_CODE = A_C.GH
left join CUSTOMER_ADDRESS d ON b.CUSTOMER_BUSINESS_ID = d.CUSTOMER_BUSINESS_ID
left join CUSTOMER_CONTACT e ON b.CUSTOMER_BUSINESS_ID = e.CUSTOMER_BUSINESS_ID
where a.ApproveStatus = ‘Y‘
insert into A_C(GH) select EMPLOYEE_CODE from EMPLOYEE
select * from A_C
select from A_CUST where ADDRESS is not null
select from CUSTOMER where CUSTOMER_CODE = ‘0080‘
select *from CUSTOMER_SALES where CUSTOMER_ID = ‘F16DD932-0155-4A9A-4FE9-13BF5CF9277D‘
SQL Server 按照分類輸出Excel