设为首页 收藏本站
查看: 1068|回复: 0

[经验分享] VB.net连接SAP实例(vb.net写法)

[复制链接]

尚未签到

发表于 2015-9-19 07:15:28 | 显示全部楼层 |阅读模式
  上一篇简单写了vb6.0中访问SAP, 本篇用vb.net实现同样的功能,只是把读取出来的内容存放在数据库中,然后利用GridView显示出来。 当然可以直接存入DataTable或DataSet中直接显示出来。
  
  以下见代码示例:
  
  Imports System
Imports System.Collections.Generic
Imports System.ComponentModel
Imports System.Data
Imports System.Drawing
Imports System.Text
Imports System.Windows.Forms
Imports System.Data.OleDb
Imports System.Xml

  
Public Class SAPConn
    Public oFunction As Object      ' SAP Functions
    Public oConnection As Object    ' SAP oConnection
  Dim cmd As OleDbCommand
    Dim SqlAd As OleDbDataAdapter
    Dim sql As String
  '测试连接的代码
  Private Sub BtnConnn_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles BtnConnn.Click
        Try
            oFunction = CreateObject("SAP.Functions.unicode")
            oConnection = oFunction.Connection
            oConnection.User = "CRMDEV69"
            oConnection.Password = "654321"
            oConnection.System = "CD2"
            oConnection.ApplicationServer = "172.18.95.173"
            oConnection.SystemNumber = 7
            oConnection.Client = "164"
            oConnection.Language = "ZH"
  If oConnection.Logon(0, True) = True Then
                MsgBox("连接成功!")
            Else
                MsgBox("连接失败!")
            End If
        Catch ex As Exception
            MsgBox(ex.ToString(), MsgBoxStyle.Information, "提示")
            Return
        End Try
    End Sub
  Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        Dim GetCustomers As Object
        Dim Customers As Object
        Dim i As Integer
        Dim sqlstr As String = ""
        ' 通过RFC接口远程运行SAP内部函数ZCSMS_GET_HRINFO
        ' 赋要调用的SAP内建函数名
        Try
            GetCustomers = oFunction.Add("ZCSMS_GET_HRINFO")
  '设置输入参数并赋值
            GetCustomers.Exports("BEGDAFROM") = ""
            GetCustomers.Exports("BEGDATO") = ""
            GetCustomers.Exports("MILL") = "7960"
            GetCustomers.Exports("NUMBERFROM") = "0061500001"
            GetCustomers.Exports("NUMBERTO") = "0061500200"
            Customers = GetCustomers.Tables("THR")
  If GetCustomers.Call Then
  '循环插入到数据库表中
                For i = 1 To Customers.RowCount
                    sqlstr = "Insert into ghy_employee(MILL, PERNR, NAME1, STEXT) values ('" & Customers(i, "MILL") & "','" & Customers(i, "PERNR") & "','" & Customers(i, "NAME1") & "','" & Customers(i, "STEXT") & "' )"
  Config.ExecAccess(sqlstr)
                Next i
                MsgBox("获取数据成功")
            Else
                MsgBox(" 搜索出错! 出错信息: " + GetCustomers.exception)
            End If
        Catch ex As Exception
            MsgBox(ex.ToString)
            Return
        End Try
      
    End Sub
  '通过GridView显示数据
  Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
        sql = "select * from ghy_employee "
        SqlAd = New OleDbDataAdapter(sql, oConn)
        DS.Clear()
  If DS.Tables.Contains("ghy_employee") Then
            DS.Tables.Remove("ghy_employee")
        End If
        SqlAd.Fill(DS, "ghy_employee")
        DvInvoice.DataSource = DS.Tables("ghy_employee").DefaultView
        DvInvoice.Refresh()
        DvInvoice.ClearSelection()
        DvInvoice.Columns("MILL").HeaderText = "工厂"
        DvInvoice.Columns("PERNR").HeaderText = "员工编号"
        DvInvoice.Columns("NAME1").HeaderText = "员工姓名"
        DvInvoice.Columns("STEXT").HeaderText = "员工部门"
    End Sub
End Class
  
  以上两种写法都是利用创建组件OCX的方式进行, 通过调用类的方法进行也可以实现。 缺点是中文无法正常显示。
  下一篇文章将贴出C#的例子以研究。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-115552-1-1.html 上篇帖子: SAP内向交货详解 Details on SAP inbound delivery 下篇帖子: [转]SAP方丈语录之三十- 如何转入SAP
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表