VBA使用SQL查询表数据
admin
2023-01-28 20:33:20
0

一、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

相关内容

热门资讯

【第一财经】“红豆炸/金/花可... 有 亲,根据资深记者爆料红豆炸/金/花是可以开挂的,确实有挂(咨询软件无...
泽连斯基签署总统令,调整乌克兰... △乌克兰总统泽连斯基(资料图)当地时间1月9日,乌克兰总统泽连斯基签署总统令,对最高统帅部人员组成进...
【第一消息】“小闲川南棋牌到底... 有 亲,根据资深记者爆料小闲川南棋牌是可以开挂的,确实有挂(咨询软件无需...
终于明白“新超凡牛牛怎么装挂?... 有 亲,根据资深记者爆料新超凡牛牛是可以开挂的,确实有挂(咨询软件无需打...
江波龙:提供多样化存储产品服务... 证券之星消息,江波龙(301308)01月09日在投资者关系平台上答复投资者关心的问题。 投资者:请...
玩家分享攻略“丫丫古诗怎么装挂... 有 亲,根据资深记者爆料丫丫古诗是可以开挂的,确实有挂(咨询软件无需打开...
终于懂了“新战皇炸/金/花是不... 您好:新战皇炸/金/花这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在...
【第一消息】“熊猫麻将到底是不... 网上科普关于“熊猫麻将有没有挂”话题很是火热,小编也是针对熊猫麻将作*弊开挂的方法以及开挂对应的知识...
今日重大通报“普通扑克雷达感应... 您好:普通扑克雷达感应分析仪这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多...
最新引进“中至吉安麻将有挂吗?... 有 亲,根据资深记者爆料中至吉安麻将是可以开挂的,确实有挂(咨询软件无需...