温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

VBA使用SQL查询表数据

发布时间:2020-07-23 07:11:51 来源:网络 阅读:914 作者:AlunE 栏目:开发技术

一、VBA使用SQL查询表,统计数据

Sub 统计数据()

    Dim CNN  As Object
    Dim sql As String

     ThisWorkbook.Sheets("统计表").Activate
    With ThisWorkbook.Sheets("统计表")
        Cells.Clear
        Cells(1, 1) = "部门名称"
        Cells(1, 2) = "名单总人数"
    End With

    Set CNN = CreateObject("ADODB.Connection")
    With CNN
        .Provider = "Microsoft.Jet.OLEDB.4.0"
        .ConnectionString = "Extended Properties=Excel 8.0;Data Source=" & ThisWorkbook.FullName
        .Open
    End With

    sql = "select 部门名称,count(工号) as 名单总人数 from [violate$A2:D65536]  where trim(工号)<>''  group by 部门名称"
    ThisWorkbook.Sheets("ViolateSum").Range("A2").CopyFromRecordset CNN.Execute(sql)

    CNN.Close
    Set CNN = Nothing

End Sub

二、用Left Join 连接两个以上的表

Sub 统计职工休假()
    Dim CNN  As Object
    Dim sql As String

    ThisWorkbook.Sheets("统计表").Activate
     With ThisWorkbook.Sheets("统计表")
        Cells(1, 15) = "部门"
        Cells(1, 16) = "总人数"
        Cells(1, 17) = "四天人数"
        Cells(1, 18) = "四天百分比"
        Cells(1, 19) = "三天人数"
        Cells(1, 20) = "三天百分比"

        Cells(1, 21) = "两天人数"
        Cells(1, 22) = "两天百分比"
        Cells(1, 23) = "零天人数"
        Cells(1, 24) = "零天百分比"
    End With

    sql = "Select A.部门名称,A.名单总人数,B.四天人数,四天人数/名单总人数,C.三天人数,三天人数/名单总人数 From " + _
          "([HolidaySum$A:B] A Left Join [统计表$C:D] B On A.部门名称=B.部门名称4" + _
          ") Left Join [统计表$F:G] C On A.部门名称=C.部门名称3"
    Sheets("统计表").Range("O2").CopyFromRecordset CNN.Execute(sql)

    sql = "Select B.两天人数,两天人数/名单总人数,C.未请假人数,未请假人数/名单总人数 From " + _
          "([统计表$A:B] A Left Join [统计表$I:J] B On A.部门名称=B.部门名称2" + _
          ") Left Join [统计表$L:M] C On A.部门名称=C.部门名称0"
    Sheets("统计表").Range("U2").CopyFromRecordset CNN.Execute(sql)

    Sheets("统计表").Range("A:N").Delete

    CNN.Close
    Set CNN = Nothing

End Sub
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI