⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄

📁 VB开发的ERP系统
💻
📖 第 1 页 / 共 2 页
字号:
            EndProperty
            BeginProperty ListImage26 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":2398C
               Key             =   "dz"
            EndProperty
            BeginProperty ListImage27 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":23D26
               Key             =   "ph"
            EndProperty
            BeginProperty ListImage28 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":240C0
               Key             =   "fz"
            EndProperty
            BeginProperty ListImage29 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":2445A
               Key             =   "Locate"
            EndProperty
            BeginProperty ListImage30 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":247F4
               Key             =   "hf"
            EndProperty
            BeginProperty ListImage31 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":24B8E
               Key             =   "pz"
            EndProperty
            BeginProperty ListImage32 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":24F28
               Key             =   "check"
            EndProperty
            BeginProperty ListImage33 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":252C2
               Key             =   "Sum"
            EndProperty
            BeginProperty ListImage34 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":2565C
               Key             =   "Total"
            EndProperty
            BeginProperty ListImage35 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":259F6
               Key             =   "Detail"
            EndProperty
            BeginProperty ListImage36 {2C247F27-8591-11D1-B16A-00C0F0283628} 
               Picture         =   "查询_人事档案列表.frx":25D90
               Key             =   "Order"
            EndProperty
         EndProperty
      End
   End
End
Attribute VB_Name = "Qr_RsArFrm"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = True
Attribute VB_Exposed = False
'**************************************************************************
'*    模 块 名 称 :人事信息查询
'*    功 能 描 述 :
'*    程序员姓名  :苗鹏
'*    最后修改人  :苗鹏
'*    最后修改时间:2002/01/02
'*    备        注:程序中所有依实际情况自定义部分均用[>>  <<]括起
'**************************************************************************
Dim ReportTitle As String                '报表主标题
Public sSqlWhere As String
Dim sSqlFrom As String
Public sArSort As String
Public sArSortName As String
Dim sSqlOrder As String
Dim sCode() As New CCode

'以下为固定使用变量
Dim Dyymctbl As New DY_Dyymsz            '打印页面窗体变量
Dim GridCode As String                   '显示网格网格代码
Dim GridInf() As Variant                 '整个网格设置信息
Dim Tsxx As String                       '系统提示信息
Dim Qslz As Long                         '网格隐藏(非操作显示)列数
Dim Sjhgd As Double                      '网格数据行高度
Dim Sfxshjwg As Boolean                  '是否显示合计网格
Dim GridBoolean() As Boolean             '网格列信息(布尔型)
Dim GridStr()  As String                 '网格列信息(字符型)
Dim GridInt() As Integer                 '网格列信息(整型)
Dim Szzls As Integer                     '数组总列数(网格列数-1)

Private Sub CxbbGrid_AfterSort(ByVal Col As Long, Order As Integer)
    Dim i As Long
    With Me.CxbbGrid
        For i = .FixedRows To .Rows - 1
            .TextMatrix(i, Qslz) = i - .FixedRows + 1
        Next i
    End With
    
End Sub

Private Sub CxbbGrid_DblClick()
    With Me.CxbbGrid
        If .Rows = .FixedRows Then
            Exit Sub
        End If
        '调用人事修改窗体
        Ed_EmpCorArFrm.int_if = 0
        Ed_EmpCorArFrm.Lbl_ArName.Tag = sArSort
        Ed_EmpCorArFrm.EmpId = .TextMatrix(.Row, 1)
        Ed_EmpCorArFrm.Lbl_ArName.Caption = "档案类别:  " & Me.sArSortName
        Ed_EmpCorArFrm.Lbl_EmpNo.Caption = "职工号:" & .TextMatrix(.Row, Sydz("001", GridStr(), Szzls))
        Ed_EmpCorArFrm.Lbl_EmpName.Caption = "姓名:" & .TextMatrix(.Row, Sydz("002", GridStr(), Szzls))
        Ed_EmpCorArFrm.Ini_Grid
        Ed_EmpCorArFrm.Show 1
        ShowRecord sSqlWhere
    End With
End Sub

Private Sub Form_Resize()                '根据窗体大小来调整网格,标题栏大小(Fixed)
    On Error Resume Next
    With CxbbGrid
        .Width = Me.Width - 160
        .Height = Me.Height - .Top - 400
    End With
    With Pic_Title
        .Width = Me.Width - 160
    End With
    
    GsToolbar.Left = Me.Width - GsToolbar.Width - 140
    With Me.PB_Proc
        .Left = (Me.Width - .Width) / 2
        .Top = Me.Height / 2
    End With
    
End Sub

Private Sub Form_Load()                                                   '窗体装入
    
    '调入打印页面设置窗体
    ReportTitle = sArSortName + "档案信息"
    XtReportCode = "Rs_ArFrm"
    Load Dyymctbl
    Me.Caption = ReportTitle
    Me.Lab_Title = ReportTitle
    '调整标题栏及网格、格式工具条位置(Fixed)
    Pic_Title.Left = 40
    Pic_Title.Top = SzToolbar.Top + SzToolbar.Height - 10
    CxbbGrid.Left = Pic_Title.Left
    CxbbGrid.Top = Pic_Title.Top + Pic_Title.Height + 20
    
    '调 入 网 格(Fixed)
    If GridCode = "" Then
        GridCode = "Rs_ArFrm"
    End If
    Call BzWgcsh(CxbbGrid, GridCode, GridInf(), GridBoolean(), GridInt(), GridStr())

    Qslz = GridInf(1)
    Sjhgd = GridInf(2)
    Sfxshjwg = GridInf(7)
    Szzls = CxbbGrid.Cols - 1
    iBeginCol = Val(GridInf(1))
    '初始化变量
    sSqlOrder = " order by Rs_BasicInfo.EmpNo " & Chr(10)
    sSqlFrom = "From Rs_ArMain inner join Rs_BasicInfo on Rs_BasicInfo.EmpID=Rs_ArMain.EmpID" & Chr(10)

End Sub

Private Sub Form_Unload(Cancel As Integer)                                  '窗体卸载
        
    '卸载打印页面设置窗体
    Unload Dyymctbl
    Security_Log "Rs_Qr_RsAr", Xtczybm, 2, False  '用户退出时写上机日志

End Sub


Private Sub GsToolbar_ButtonClick(ByVal Button As MSComctlLib.Button)                '网格格式调整(Fixed)
    
    Select Case Button.Key
    Case "bcgs"                                          '保存表格格式
        Call Bcwggs(CxbbGrid, GridCode, GridStr())
    Case "hfmrgs"                                        '恢复默认格式
        Call Hfmrgs(CxbbGrid, GridCode, GridStr())
    Case "szxsxm"                                        '设置显示项目
        Call Szxsxm(CxbbGrid, GridCode)
    End Select
    
End Sub


Private Sub SzToolbar_ButtonClick(ByVal Button As MSComctlLib.Button)
    
    Select Case Button.Key
    Case "ymsz"                                          '页面设置
        Dyymctbl.Show 1
    Case "yl"                                            '预 览
        If NoRec Then Exit Sub
        bbyl (True)
    Case "dy"                                            '打 印
        If NoRec Then Exit Sub
        bbyl (False)
    Case "cx"                                            '查 询
        Qr_RsArCndFrm.Show 1
    Case "edit"                                          '编辑
          CxbbGrid_DblClick
    Case "Refresh"                                       '刷新
        ShowRecord sSqlWhere
    Case "bz"                                            '帮 助
        Call F1bz
    Case "fh"                                            '退 出
        Unload Me
    End Select
    
    
End Sub

Private Function NoRec() As Boolean
'判断网格是否有记录
Dim i As Integer
NoRec = True
With Me.CxbbGrid
If .Rows = .FixedRows Then
    Exit Function
End If
For i = 0 To .Rows - 1
    If .RowHidden(i) = False Then
        NoRec = False
        Exit For
    End If
Next i
End With
End Function

Private Function DelRecords() As Boolean
'删除选中的记录,支持一次多条
Dim i As Integer
Dim sSql As String
DelRecords = False
If Xtxxts("请确认是否删除当前记录?", 2, 2) = vbCancel Then Exit Function
With CxbbGrid
    For i = 1 To .Rows - 1
        If .IsSelected(i) Then sSql = sSql & " DELETE FROM Rs_ArMain WHERE ArSort = '" & Me.sArSort & "' AND Sno = '" & .TextMatrix(i, 2) & "' AND EmpId = '" & .TextMatrix(i, 1) & "'"
    Next i
    If .Row > .RowSel Then
        For i = .RowSel To .Row
            sSql = sSql & " DELETE FROM Rs_ArMain WHERE ArSort = '" & Me.sArSort & "' AND Sno = '" & .TextMatrix(i, 2) & "' AND EmpId = '" & .TextMatrix(i, 1) & "'"
        Next
    Else
        For i = .Row To .RowSel
            sSql = sSql & " DELETE FROM Rs_ArMain WHERE ArSort = '" & Me.sArSort & "' AND Sno = '" & .TextMatrix(i, 2) & "' AND EmpId = '" & .TextMatrix(i, 1) & "'"
        Next
    End If
End With
On Error GoTo ErrDeal
If Trim(sSql) = "" Then Exit Function
Cw_DataEnvi.DataConnect.Execute sSql
DelRecords = True
Exit Function

ErrDeal:
    Call Xtxxts("出现未知情况,该编码不能被删除!", 0, 1)
    
End Function

Private Function Nothing2Edit() As Boolean
'如果该档案的项目只有职工号和姓名2项,认为没有东西可以修改

Dim tmpRs As New ADODB.Recordset

Nothing2Edit = True
Set tmpRs = Cw_DataEnvi.DataConnect.Execute("SELECT ColIndex FROM Xt_Grid WHERE Grid_Code = '" & Me.sArSort & "' AND ColIndex > '002'")
If Not tmpRs.EOF Then
    Nothing2Edit = False
End If

End Function


Public Function ShowRecord(sWhere As String)                                    '生成查询结果(Define)
    '显示数据
    On Error GoTo ErrCtrl
    
    Dim rs As New ADODB.Recordset
    Dim s As String
    Dim i As Long
    Dim j As Long
    Dim m As Long
    Dim n As Long
    
    If Trim(sSqlWhere) = "" Or Trim(sSqlFrom) = "" Then
        Exit Function
    End If
    Me.MousePointer = 11
    GridCode = Me.sArSort
    Call Form_Load
    '取得数据
    s = "select FieldsName as FieldName  from XT_Grid where Grid_Code='" & Me.sArSort & "' and ColIndex<>'000'"
    Set rs = Cw_DataEnvi.DataConnect.Execute(s)
    s = "Select Rs_ArMain.EmpID as EmpID,Rs_ArMain.sNo as sNo " & Chr(10)
    With rs
        Do While Not .EOF()
            s = s & "," & Trim(!FieldName & "") & Chr(10)
            .MoveNext
        Loop
    End With
    rs.Close
        
    With Me.CxbbGrid
        sExec = s & sSqlFrom & Me.sSqlWhere & sSqlOrder
        Set rs = Cw_DataEnvi.DataConnect.Execute(sExec)
        .Rows = .FixedRows + rs.RecordCount

        '初始化进度条
        Me.PB_Proc.Min = .FixedRows
        Me.PB_Proc.Max = .Rows + 1
        Me.PB_Proc.Value = Me.PB_Proc.Min
        Me.PB_Proc.Visible = True
        '填充数据
        s = ""
        .ColHidden(Qslz - 1) = False
        .ColWidth(Qslz - 1) = 800
        .TextMatrix(.FixedRows - 1, Qslz - 1) = "编号"
        .FixedAlignment(Qslz - 1) = flexAlignCenterCenter
        n = 1
        For i = .FixedRows To .Rows - 1
            .RowHeight(i) = Sjhgd
            Me.PB_Proc.Value = i
            If m <> rs.Fields("EmpID") Then
                n = 1
                m = rs.Fields("EmpID")
            Else
                n = n + 1
            End If
            .TextMatrix(i, Qslz - 1) = n
            For j = Qslz To .Cols - 1
                .TextMatrix(i, j) = Trim(rs.Fields(GridStr(j, 4)) & "")
            Next j
            .TextMatrix(i, 1) = rs.Fields("EmpID")
            .TextMatrix(i, 2) = rs.Fields("sNo")
            rs.MoveNext
        Next i
        rs.Close
        
        
        Me.PB_Proc.Visible = False
        .Redraw = True
    End With
    Set rs = Nothing
    Me.MousePointer = 0
    Exit Function
    
ErrCtrl:
    If rs.State = 1 Then
        rs.Close
    End If
    Set rs = Nothing
    Me.PB_Proc.Visible = False
    Me.CxbbGrid.Redraw = True
    Me.MousePointer = 0
    
End Function

Private Sub bbyl(bbylte As Boolean)                    '报表打印预览
    
    Dim Bbzbt$, Bbxbt() As String, bbxbtzzxs() As Integer, Bbxbtgs As Integer
    Dim Bbbwh() As String, Bbbwhzzxs() As Integer, Bbbwhgs As Integer
    Bbxbtgs = 1                                         '报 表 小 标 题 行 数
    Bbbwhgs = 0                                          '报 表 表 尾 行 数
    ReDim Bbxbt(1 To Bbxbtgs)
    ReDim bbxbtzzxs(1 To Bbxbtgs)
    If Bbbwhgs <> 0 Then
        ReDim Bbbwh(1 To Bbbwhgs)
        ReDim Bbbwhzzxs(1 To Bbbwhgs)
    End If
    Bbzbt = ReportTitle
    
    bbxbtzzxs(1) = 0                                     '报表行组织形式(0-居左 1-居中 2-居右)
    Call Scyxsjb(CxbbGrid)                               '生成报表数据
    Call Scdybb(Dyymctbl, Bbzbt, Bbxbt(), bbxbtzzxs(), Bbxbtgs, Bbbwh(), Bbbwhzzxs(), Bbbwhgs, bbylte)
    If Not bbylte Then
        Unload DY_Tybbyldy
    End If
    
End Sub

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -