亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? clientprojects.cls

?? 完整的三層數據庫應用程序
?? CLS
字號:
VERSION 1.0 CLASS
Begin
  MultiUse = -1  'True
  Persistable = 0  'NotPersistable
  DataBindingBehavior = 0  'vbNone  
  DataSourceBehavior = 0   'vbNone
  MTSTransactionMode = 0   'NotAnMTSObject
End
Attribute VB_Name = "ClientProjects"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = False
Attribute VB_Exposed = True
Attribute VB_Ext_KEY = "SavedWithClassBuilder", "Yes"
Attribute VB_Ext_KEY = "SavedWithClassBuilder6", "Yes"
Attribute VB_Ext_KEY = "SavedWithCOMExpress", "Yes"
Attribute VB_Ext_KEY = "Collection" ,"ClientProject"
Attribute VB_Ext_KEY = "Member0" ,"ClientProject"
Attribute VB_Ext_KEY = "Top_Level", "No"
Option Explicit  
Implements COMEXDataSource
Private m_Fields() 
Private mcol As Collection

Public Event OnRecordInsert(ByRef vClientProject As ClientProject)

Public Property Get Item(vntIndexKey As Variant) As ClientProject
Attribute Item.VB_UserMemId = 0
  On Error Resume Next
  Set Item = mCol(vntIndexKey)
  If Err.Number <> 0 Then
    Set Item = Nothing
  End If
End Property

Public Function Key(ByRef vClientProject As ClientProject) As String
  Key = ":" & vClientProject.ProjectID 
End Function

Public Property Get Count() As Long
  Count = mCol.Count
End Property

Public Property Get NewEnum() As IUnknown
Attribute NewEnum.VB_UserMemId = -4
Attribute NewEnum.VB_MemberFlags = "40"
  Set NewEnum = mCol.[_NewEnum]
End Property

Private Sub Class_Initialize()
  Set mCol = New Collection 
  m_Fields = Array("ClientID", "EmployeeID", "ProjectDescription", "ProjectEndDate", "ProjectID", "ProjectName", "ProjectTotalBillingEstimate", "PurchaseOrderNumber", "ProjectBeginDate")
End Sub

Private Sub Class_Terminate()
  Set mCol = Nothing
End Sub

Public Sub Remove(vntIndexKey As Variant)
  mCol.Remove vntIndexKey
End Sub

Public Sub Clear()
  Set mCol = Nothing
  Set mCol = New Collection
End Sub

Public Function AddExisting(vClientProject As ClientProject, Optional sKey As String = vbNullString) As Boolean
  On Error GoTo Err_AddExisting
  If Len(sKey) = 0 Then
    mCol.Add vClientProject
  Else
    mCol.Add vClientProject, sKey
  End If
  AddExisting = True
  RaiseEvent OnRecordInsert(vClientProject)
  Exit Function
Err_AddExisting:
  AddExisting = False
End Function

Public Function Add(m_ClientID As Long, m_EmployeeID As Long, m_ProjectDescription As String, m_ProjectEndDate As Variant, m_ProjectID As Long, m_ProjectName As String, m_ProjectTotalBillingEstimate As Currency, m_PurchaseOrderNumber As String, m_ProjectBeginDate As Date, m_ProjTimeCardHours As ProjTimeCardHours, m_ProjTimeCardExpenses As ProjTimeCardExpenses, m_Payments As Payments, Optional sKey As String = vbNullString) As ClientProject
  Dim objNewMember As ClientProject
  Set objNewMember = New ClientProject
  objNewMember.ClientID = m_ClientID
  objNewMember.EmployeeID = m_EmployeeID
  objNewMember.ProjectDescription = m_ProjectDescription
  objNewMember.ProjectEndDate = m_ProjectEndDate
  objNewMember.ProjectID = m_ProjectID
  objNewMember.ProjectName = m_ProjectName
  objNewMember.ProjectTotalBillingEstimate = m_ProjectTotalBillingEstimate
  objNewMember.PurchaseOrderNumber = m_PurchaseOrderNumber
  objNewMember.ProjectBeginDate = m_ProjectBeginDate
  Set objNewMember.ProjTimeCardHours = m_ProjTimeCardHours
  Set objNewMember.ProjTimeCardExpenses = m_ProjTimeCardExpenses
  Set objNewMember.Payments = m_Payments

  If Len(sKey) = 0 Then
    mCol.Add objNewMember
  Else
    mCol.Add objNewMember, sKey
  End If
  Set Add = objNewMember
  RaiseEvent OnRecordInsert(objNewMember)
  Set objNewMember = Nothing
End Function


Public Function LoadRelated(ClientID As Long, Optional ByVal SQLWhereClause As String = "") As Boolean
  Dim adoRS As New ADODB.Recordset
  Dim strSQL As String
  Dim uClientProject As New ClientProject
  On Error GoTo Err_LoadRelated

  Screen.MousePointer = vbHourglass

  Clear

  strSQL = "Select a.ClientID,b.CompanyName As CompanyName,a.EmployeeID,c.FirstName As FirstName,c.LastName As LastName,a.ProjectDescription,a.ProjectEndDate,a.ProjectID,a.ProjectName,a.ProjectTotalBillingEstimate,a.PurchaseOrderNumber,a.ProjectBeginDate From (Projects a LEFT JOIN Clients b ON a.ClientID = b.ClientID) LEFT JOIN Employees c ON a.EmployeeID = c.EmployeeID WHERE a.ClientID = " & ClientID & ""
  If SQLWhereClause <> "" Then
    If UCase(Trim(Left$(SQLWhereClause, 5))) = "WHERE" Then
      SQLWhereClause = Replace(UCase(SQLWhereClause), "WHERE ", "AND ")
    Else
      If UCase(Trim(Left$(SQLWhereClause, 3))) <> "AND" Then
        SQLWhereClause = "AND " & SQLWhereClause
      End If
    End If
  End If
  strSQL = strSQL & " " & SQLWhereClause

  adoRS.CacheSize = 250
  adoRS.Open strSQL, Conn, adOpenForwardOnly, adLockReadOnly
  With adoRS
    Do While Not .EOF
      Set uClientProject = Nothing
      Set uClientProject = New ClientProject
      uClientProject.ClientID= IIF(IsNull(adoRS("ClientID")), 0, adoRS("ClientID"))
      uClientProject.CompanyName= IIF(IsNull(adoRS("CompanyName")), "", adoRS("CompanyName"))
      uClientProject.EmployeeID= IIF(IsNull(adoRS("EmployeeID")), 0, adoRS("EmployeeID"))
      uClientProject.FirstName= IIF(IsNull(adoRS("FirstName")), "", adoRS("FirstName"))
      uClientProject.LastName= IIF(IsNull(adoRS("LastName")), "", adoRS("LastName"))
      uClientProject.ProjectDescription= IIF(IsNull(adoRS("ProjectDescription")), "", adoRS("ProjectDescription"))
      uClientProject.ProjectEndDate = adoRS("ProjectEndDate")
      uClientProject.ProjectID= IIF(IsNull(adoRS("ProjectID")), 0, adoRS("ProjectID"))
      uClientProject.ProjectName= IIF(IsNull(adoRS("ProjectName")), "", adoRS("ProjectName"))
      uClientProject.ProjectTotalBillingEstimate= IIF(IsNull(adoRS("ProjectTotalBillingEstimate")), 0, adoRS("ProjectTotalBillingEstimate"))
      uClientProject.PurchaseOrderNumber= IIF(IsNull(adoRS("PurchaseOrderNumber")), "", adoRS("PurchaseOrderNumber"))
      uClientProject.ProjectBeginDate= IIF(IsNull(adoRS("ProjectBeginDate")), "12:00:00AM", adoRS("ProjectBeginDate"))
      uClientProject.OldProjectID = uClientProject.ProjectID

      uClientProject.ProjTimeCardHours.LoadRelated uClientProject.ProjectID

      uClientProject.ProjTimeCardExpenses.LoadRelated uClientProject.ProjectID

      uClientProject.Payments.LoadRelated uClientProject.ProjectID

      uClientProject.IsDirty = False
      mcol.Add uClientProject, ":" & uClientProject.ProjectID 

      .MoveNext
    Loop
    .Close
  End With
    
  LoadRelated = True
Done_LoadRelated:
  Screen.MousePointer = vbDefault
  Exit Function

Err_LoadRelated:
  ErrNum = Err.Number
  ErrMsg = Err.Description
  Call ErrHandler(ErrNum, ErrMsg,"ClientProjects","GetMultiRecords")
  Resume Done_LoadRelated 
End Function

Friend Sub Delete()
	Dim uClientProject As ClientProject
  For Each uClientProject In mCol
    uClientProject.Delete
  Next
End Sub
 

Private Function COMEXDataSource_GetData(ByVal Field As Long, ByVal Record As Long) As Variant 
  If Record > 0 And Record <= mcol.Count Then
    Dim vItem As COMEXDataSourceSingle
    Set vItem = mcol.Item(Record)
    COMEXDataSource_GetData = vItem.GetData(Field)
  Else
    COMEXDataSource_GetData = Null
  End If
End Function

Private Function COMEXDataSource_GetFieldCount() As Long
  COMEXDataSource_GetFieldCount =  UBound(m_Fields) + 1
End Function

Private Function COMEXDataSource_GetFieldName(ByVal Field As Long) As String
  If Field > 0 AND Field <= UBound(m_Fields) + 1 Then 
    COMEXDataSource_GetFieldName = m_Fields(Field - 1)
  End If
End Function

Private Function COMEXDataSource_GetRecordCount() As Long
  COMEXDataSource_GetRecordCount = mcol.Count
End Function

Private Sub COMEXDataSource_SetData(ByVal Field As Long, ByVal Record As Long, ByVal newData As Variant)
  Dim vItem As COMEXDataSourceSingle
  If Record > 0 And Record <= mcol.Count  Then    
    Set vItem = mcol.Item(Record)
    vItem.SetData Field, newData 
  ElseIf Record = mcol.count + 1 Then
    Set vItem = New ClientProject
    vItem.SetData Field, newData 
    mcol.Add vItem    
  End If
End Sub 

Private Sub COMEXDataSource_Delete(ByVal Record As Long)
  If Record > 0 And Record <= mcol.Count Then mcol.Item(Record).Delete  
End Sub

Private Function COMEXDataSource_Save() As Boolean
  Dim vItem As ClientProject, i As long, bolRet As Boolean  
  i = 1
  Do While i <= mcol.count
    Set vItem = mcol.Item(i)    
    If Not (vItem.IsNew and vItem.IsDeleted) Then 
      bolRet = vItem.Save
      If Not bolRet Then 
        COMEXDataSource_Save = False
        Exit Function
      End If                
      i = i + 1
    Else
      mcol.remove i
    End If
  Loop
  COMEXDataSource_Save = True  
End Function 

Private Property Get COMEXDataSource_IsDeleted(ByVal Record As Long) As Boolean
  If Record > 0 And Record <= mcol.Count Then  _
    COMEXDataSource_IsDeleted = Item(Record).IsDeleted
End Property

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99精品久久久久久动态图| 制服丝袜成人动漫| 欧美日韩国产三级| 欧美激情一区三区| 亚洲永久精品大片| 丁香婷婷综合激情五月色| 91电影在线观看| 国产精品久久久久久一区二区三区 | 国产精品白丝在线| 久久国产免费看| 欧美性色黄大片手机版| 日韩毛片一二三区| 国产v日产∨综合v精品视频| 日韩三级中文字幕| 婷婷激情综合网| 91网站最新地址| 国产精品电影一区二区| 国产精品一区二区免费不卡| 欧美成人一区二区三区在线观看 | 亚洲精品在线免费观看视频| 亚洲国产精品影院| 欧美中文字幕一区| 亚洲精品免费在线| 在线观看日韩电影| 亚洲一区二区三区三| 色拍拍在线精品视频8848| 亚洲婷婷综合色高清在线| 不卡视频在线观看| 国产精品成人在线观看| 99久久伊人久久99| 中文字幕日韩一区| 91亚洲精华国产精华精华液| 亚洲人成网站精品片在线观看| aa级大片欧美| 夜夜亚洲天天久久| 欧美日韩亚洲综合一区二区三区| 亚洲电影一区二区| 正在播放一区二区| 美脚の诱脚舐め脚责91| 久久亚洲精品小早川怜子| 国产精品夜夜爽| 国产精品久久久久影院老司| 91丨porny丨最新| 亚洲福利一二三区| 欧美一级理论性理论a| 久久99国产精品尤物| 久久久久久久久久久黄色| 国产成人精品免费视频网站| 中文字幕欧美一| 欧美日韩国产精品自在自线| 久久精品国产一区二区| 久久久久久久综合狠狠综合| av色综合久久天堂av综合| 亚洲一区在线观看免费| 日韩一二在线观看| 国产成人亚洲综合a∨婷婷| 中文字幕亚洲区| 欧美人成免费网站| 国产不卡一区视频| 亚洲一级片在线观看| 欧美videos大乳护士334| 国产99久久久国产精品潘金| 一区二区三区**美女毛片| 欧美大片日本大片免费观看| 成人动漫精品一区二区| 午夜成人免费视频| 久久久国产精品麻豆| 在线免费av一区| 国产一区不卡在线| 亚洲成人一区二区在线观看| 国产色爱av资源综合区| 欧美色倩网站大全免费| 国产福利91精品一区二区三区| 亚洲午夜免费电影| 国产欧美日本一区二区三区| 欧美日韩精品一区二区| 成人性色生活片| 日韩专区中文字幕一区二区| 久久久久久久网| 欧美丰满高潮xxxx喷水动漫| 不卡视频在线看| 韩日欧美一区二区三区| 亚洲国产精品久久久久秋霞影院| 国产亚洲一区二区三区四区| 在线观看日韩av先锋影音电影院| 国产精品99精品久久免费| 婷婷中文字幕综合| 亚洲日本在线观看| 国产日韩欧美制服另类| 日韩欧美在线123| 精品视频全国免费看| 99久久精品免费看国产免费软件| 激情久久久久久久久久久久久久久久| 一区二区三区国产| 亚洲同性同志一二三专区| 久久这里只有精品视频网| 在线成人免费观看| 欧美综合在线视频| 91在线观看成人| 成人爱爱电影网址| 成人的网站免费观看| 国产成人免费视频网站| 国产中文字幕精品| 久久国产精品免费| 免费高清在线一区| 青青草97国产精品免费观看无弹窗版 | 精品日韩一区二区| 91精品在线一区二区| 欧美精品九九99久久| 欧美性受xxxx黑人xyx性爽| 色综合激情五月| 色菇凉天天综合网| 在线影视一区二区三区| 色欧美片视频在线观看在线视频| 99在线精品免费| 不卡av在线免费观看| 99久久综合色| av激情综合网| 日本国产一区二区| 日本精品一区二区三区高清| 日本二三区不卡| 91国产免费观看| 欧美性生活久久| 欧美高清视频www夜色资源网| 欧美精品v国产精品v日韩精品| 欧美日本在线看| 欧美电影精品一区二区| 久久久久久9999| 中文字幕一区三区| 亚洲一区二区三区美女| 性做久久久久久免费观看欧美| 亚洲成av人片一区二区三区| 青青草原综合久久大伊人精品 | 欧美一区二区三区四区久久| 欧美疯狂做受xxxx富婆| 久久久噜噜噜久噜久久综合| 中文天堂在线一区| 亚洲精品大片www| 美腿丝袜一区二区三区| 国产精品影视天天线| 色欧美片视频在线观看在线视频| 欧美三级三级三级爽爽爽| 精品欧美乱码久久久久久1区2区| 久久久精品2019中文字幕之3| 亚洲视频香蕉人妖| 免费观看30秒视频久久| 波多野结衣中文一区| 欧美日韩欧美一区二区| 国产亚洲精品资源在线26u| 亚洲精品中文在线| 狠狠色伊人亚洲综合成人| 色诱视频网站一区| 精品国产青草久久久久福利| 中文字幕一区二区三区四区| 日本不卡一区二区| 99国产欧美另类久久久精品| 91精品国产色综合久久| 中文字幕亚洲一区二区av在线 | 亚洲精品老司机| 日本欧美一区二区三区| caoporm超碰国产精品| 91精品国产综合久久久久| 国产欧美久久久精品影院| 亚洲成人精品一区二区| av激情成人网| 2020日本不卡一区二区视频| 亚洲国产精品久久不卡毛片| 国产成人免费视频一区| 日韩你懂的电影在线观看| 一区二区在线观看免费| 国产99久久精品| 精品免费日韩av| 亚洲成av人片在线| 91丨九色丨尤物| 国产精品日日摸夜夜摸av| 蜜桃久久精品一区二区| 欧美日韩三级在线| 亚洲综合偷拍欧美一区色| 国产精品亚洲第一区在线暖暖韩国| 欧美美女激情18p| 一区二区三区日韩欧美精品| 成人精品电影在线观看| 久久精品一区蜜桃臀影院| 日韩1区2区日韩1区2区| 欧美日韩国产电影| 亚洲电影欧美电影有声小说| 色综合天天性综合| 中文字幕中文字幕在线一区| 丁香天五香天堂综合| 久久久国产一区二区三区四区小说 | 7777精品伊人久久久大香线蕉完整版 | 午夜在线成人av| 日本道色综合久久| 亚洲人成影院在线观看| 91香蕉视频在线| 一区二区高清在线| 91高清视频在线| 亚洲欧美激情在线| 欧洲精品一区二区| 午夜影院久久久|