mssql sqlserver update delete表外号用法简介

2019-11-14 17:32栏目:网站首页

转自:http://www.maomao365.com/?p=6973 

C 和C#编写调用COM组件

摘要:
在sql脚本编写中,假使急需在update delete 中采纳表外号的办法,必需依照一定的准则编写,不然将会产出相应的不行音讯,如下所示:
试验境遇:sqlserver 二零零六 中华V2

下载源代码


摘要:今后COM组件的利用进一层遍布,在依次程序中调用COM组件作者想大家都蒙受过,那篇文章正是关于COM组件的编纂和调用的,首要含有了利用VC6.0编写和调用COM组件,VS2006中使用C#编纂和调用COM组件,甚至在VC6.0和VS二〇〇六里边互相调用COM组件。

 

第一字:VC6.0编写调用COM VS二零零六中C#编写和调用COM VC6.0和VS2007中间相互调用COM

---update 表别名的写法
update [别名] set [别名].[字段] =[字段值] from [表名] as [表别名] where [条件]
---delete 表别名的写法
delete [别名] set [别名].[字段] =[字段值] from [表名] as [表别名] where [条件]

正文:

 

前阵子在工作中做项目标时候,遭逢了COM组件的调用和动用难点,那时研讨和好风流倜傥阵,才把高级中学级的环节打通,未来写出来为大家提供方便,这里带有了八个种类:

1、在VS2005中,C#编写DLL并使用C 调用

2、在VS2005中C#编写的COM组件,使用VC6.0调用

3、在VC6.0中编写COM组件,使用VS2005 C#调用

4、在VC6.0中编写COM组件,使用VC6.0调用

内部各个门类都写了两个程序,四个为COM组件程序,八个为调用程序

程序实现:

1、在VS2005中,C#编写DLL并使用C 调用

(1)C#编写DLL程序

建立C#编纂的DLL程序AddDll,项目项目为:类库

程序代码:

using System;using System.Collections.Generic;using System.Text;namespace AddDll{    public class Add    {        public int iadd(int a, int b)        {            int c = a   b;            return c;        }    }}      

(2卡塔 尔(阿拉伯语:قطر‎C 编写调用程序

树立C 的Win32调控台应用程序UseDll,项目系列为:Win32调节台应用程序

计划:右键点击施工方案财富微电脑中的UseDll,选拔“属性”,将集身体语言言运维库辅助设置为“公共语言运转库扶持(/clr)”

图片 1
图意气风发 公共语言运转库设置

程序代码:

#include "stdafx.h"#include "stdio.h"#using "..debugAddDll.dll"using namespace AddDll;int _tmain(int argc, _TCHAR* argv[]){        int result;        Add ^add = gcnew Add();        result = add->iadd(10,90);        printf("%d",result);        scanf("%s");        return 0;}      

2、在VS2005中C#编写的COM组件,使用VC6.0调用

(1)VS2005中使用C#编写COM组件

建立C#编写的COM组件,项目体系为类库

布局:右键点击建设方案能源微型机中的AddCom,选取“属性”,选择“生成”,选取“为COM Interop注册(_P)”

打开AssemblyInfo.cs文件,设置[assembly: ComVisible(true)]

那用就能够生成AddCom.tlb文件

图片 2
图二 COM生成设置

程序代码:

using System;using System.Collections.Generic;using System.Text;using System.Runtime.InteropServices;namespace AddCom{    //可以通过//菜单的 “工具/guid生成”。    //注意要选择Define Guid{….}格式,并全//部保存下来,保存到哪都行,记事本呀什么的。    //因为在做VC程序/////////的时候要用到的。    [Guid("298D881C-E2A3-4638-B872-73EADE25511C")]      public interface AddComInterface    {        [DispId(1)]        int iadd(int a, int b);        [DispId(2)]        float ladd(float a, float b);    }    [Guid("2C5B7580-4038-4d90-BABD-8B83FCE5A467")]    [ClassInterface(ClassInterfaceType.None)]    public class AddComService : AddComInterface    {        public AddComService()        {        }        public int iadd(int a, int b)        {            int c = 0;            c = a   b;            return c;        }        public float ladd(float a, float b)        {            float c = 0;            c = a   b;            return c;        }    }}      

(2卡塔尔VC6.0编写调用程序

使用VC6.0编写创建MFC应用程序UseCom,项目项目为MFC AppWizard(exe)

在stdafx.h添加:

#import "AddCom.tlb"using namespace AddCom;      

程序代码:

void CUseComDlg::OnButtonUse() {        // TODO: Add your control notification handler code here        int dresult;        float fresult;        CString strResult;        CoInitialize(NULL);//NULL换成0也可以        AddCom::AddComInterfacePtr p_Add(__uuidof(AddComService));        dresult = p_Add->iadd(1,2);        fresult = p_Add->fadd(1.2,2.3);        strResult.Format("int:%d nfloat:%f",dresult,fresult);        MessageBox(strResult,"计算结果",MB_OK);        CoUninitialize();           }      

3、在VC6.0中编写COM组件,使用VS2005 C#调用

(1)VC6.0编写COM

行使VC6.0建设构造COM组件,工程项目:ATL COM AppWizard

程序代码:

接口:

interface IAdd : IDispatch        {                [id(1), helpstring("method iadd")] HRESULT iadd([in]int a, [in]int b, [out]int * c);                [id(2), helpstring("method fadd")] HRESULT fadd([in]float a, [in]float b, [out]float * c);                [id(3), helpstring("method isub")] HRESULT isub([in]int a, [in]int b, [out]int * c);        };      

实现:

STDMETHODIMP CAdd::iadd(int a, int b, int *c){        // TODO: Add your implementation code here        *c = a   b;        return S_OK;}STDMETHODIMP CAdd::fadd(float a, float b, float *c){        // TODO: Add your implementation code here        *c = a   b;        return S_OK;}STDMETHODIMP CAdd::isub(int a, int b, int *c){        // TODO: Add your implementation code here        *c = a - b;        return S_OK;}      

(2)VS2005使用C#编写制定调用程序(网址前后相继卡塔尔国

运用VS二〇〇七创制网址UseCom

安排:在建设方案能源微机中的主目录点击右键,采纳丰硕援引,接纳COM,加多赶巧确立的AddCom 1.0 Type Library

在先后中要using编写的COM组件:using ADDCOMLib;

图片 3
图三 引用COM

程序代码:

using System;using System.Data;using System.Configuration;using System.Web;using System.Web.Security;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.WebControls.WebParts;using System.Web.UI.HtmlControls;using ADDCOMLib;public partial class _Default : System.Web.UI.Page {    protected void Page_Load(object sender, EventArgs e)    {    }    protected void ButtonCom_Click(object sender, EventArgs e)    {        Add add = new Add();        int iresult;        float fresult;        int sresult;        add.IAdd(10, 20, out iresult);        add.fadd((float)1.2,(float)2.3, out fresult);        add.isub(100, 10, out sresult);        TextBoxResult.Text = iresult.ToString();        TextBoxRe2.Text = fresult.ToString();        TextBoxRe3.Text = sresult.ToString();    }}      

4、在VC6.0中编写COM组件,使用VC6.0调用

(1)VC6.0编写COM组件

应用VC6.0创建COM组件,工程项目:ATL COM AppWizard

程序代码:

接口:

interface IAdd : IDispatch        {                [id(1), helpstring("method iadd")] HRESULT iadd([in]int a, [in]int b, [out]int * c);                [id(2), helpstring("method fadd")] HRESULT fadd([in]float a, [in]float b, [out]float * c);                [id(3), helpstring("method isub")] HRESULT isub([in]int a, [in]int b, [out]int * c);        };      

实现:

STDMETHODIMP CAdd::iadd(int a, int b, int *c){        // TODO: Add your implementation code here        *c = a   b;        return S_OK;}STDMETHODIMP CAdd::fadd(float a, float b, float *c){        // TODO: Add your implementation code here        *c = a   b;        return S_OK;}STDMETHODIMP CAdd::isub(int a, int b, int *c){        // TODO: Add your implementation code here        *c = a - b;        return S_OK;}      

(2卡塔 尔(英语:State of Qatar)VC6.0编写调用程序

使用VC6.0创立MFC应用程序UseCOM,调用刚刚确立的COM组件

将地方程序AddCom生成的AddCom.dll放入本程序的工程目录和次序生成目录中

在StdAfx.h中加入:

#import "AddCom.dll" no_namespace

程序代码:

void CUseComDlg::OnBUTTONUse() {        // TODO: Add your control notification handler code here        CString strResult;        CoInitialize(NULL);//NULL换成0也可以        IAddPtr m_add = NULL;        HRESULT hr = S_OK;        hr = m_add.CreateInstance(__uuidof(Add));        int d_a = 90;        int d_b = 10;        int d_c;        int d_d;        float f_a = 1;        float f_b = 2;        float f_c;         m_add->_IAdd(d_a,d_b,&d_c);        m_add->fadd(f_a,f_b,&f_c);        m_add->isub(d_a,d_b,&d_d);        strResult.Format("返回结果:%d; %f; %d",d_c,f_c,d_d);        MessageBox(strResult,"结果",MB_OK);        m_add.Release();        m_add = NULL;        CoUninitialize();           }      

截至语:希望能对大家有帮扶!

版权声明:本文由威尼斯人app发布于网站首页,转载请注明出处:mssql sqlserver update delete表外号用法简介