C语言跟数据库有什么关系吗

C语言跟数据库有什么关系吗,第1张

C语言是一门编程语言,而数据库则是数据的集合。

1、C语言是一门通用计算机编程语言,应用广泛,用它可以开发数据库管理软件,也可以通过C语言借助于SQL语句来 *** 作数据库。

2、数据库指的是以一定方式储存在一起、能为多个用户共享、具有尽可能小的冗余度的特点、是与应用程序彼此独立的数据集合。一般来数据库都需要数据库管理软件,比如acess、oracle等等,这些大型并且对执行效率要求较高的软件,往往都是C语言开发的。

都是可以的

C/C++与数据库交互,像 mssql / mysql / oracle 等,一般都有成熟的第三方库,这些库里面无非就是封装了与数据库通讯的方式和通讯协议

搜一下你要用的数据库相关的 API 文档,会说得很清楚

任何文件都是二进制数据,关键是数据存储的组织方式

通用扩展名的文件,像gif/doc/jpg/wav,格式都是固定的

读出数据来以后按照一定的规律去解析就能可以正确解读

这个规律,就是文件存储格式,也可以搜到相关的文档

给个例子给你看下:

_CommandPtr m_cmdptr;

m_cmdptrCreateInstance(__uuidof( Command ) );

_ParameterPtr inParam2=NULL;

_ParameterPtr inParam3=NULL;

_ParameterPtr inParam4=NULL;

_ParameterPtr outParam1=NULL;

_ParameterPtr outParam2=NULL;

_ParameterPtr outParam3=NULL;

inParam2CreateInstance(__uuidof(Parameter));

inParam3CreateInstance(__uuidof(Parameter));

inParam4CreateInstance(__uuidof(Parameter));

outParam1CreateInstance(__uuidof(Parameter));

outParam2CreateInstance(__uuidof(Parameter));

outParam3CreateInstance(__uuidof(Parameter));

m_cmdptr->ActiveConnection=m_pConnection;

m_cmdptr->CommandType=adCmdStoredProc;

m_cmdptr->CommandText=_bstr_t("proc_XXX");//存储过程的名称

//输入参数

inParam2=m_cmdptr->CreateParameter(_bstr_t("@P1"),adVarChar,adParamInput,32,_bstr_t(P1));

m_cmdptr->Parameters->Append(inParam2);

inParam3=m_cmdptr->CreateParameter(_bstr_t("@P2"),adVarChar,adParamInput,20,_bstr_t(P2));

m_cmdptr->Parameters->Append(inParam3);

//输出参数

outParam1=m_cmdptr->CreateParameter("@P4",adInteger,adParamOutput,sizeof(int));

m_cmdptr->Parameters->Append(outParam1);

outParam2=m_cmdptr->CreateParameter("@P5",adInteger,adParamOutput,sizeof(int));

m_cmdptr->Parameters->Append(outParam2);

outParam3=m_cmdptr->CreateParameter(_bstr_t("@P6"),adVarChar,adParamOutput,20,_bstr_t(P6));

m_cmdptr->Parameters->Append(outParam3);

//执行

m_cmdptr->Execute(NULL,NULL,adCmdStoredProc);

//取返回值

long p1=m_cmdptr->Parameters->GetItem("@P4")->Value;

long p2=m_cmdptr->Parameters->GetItem("@P5")->Value;

VARIANT vtP6 =m_cmdptr->Parameters->GetItem("@P6")->Value;

if (vtP6vt != VT_NULL)

strcpy(tp,(_bstr_t)vtP6);

m_cmdptrDetach;

一个万能的DBHelper就可以解决都事情,直接对数据库中的存储过程进行调用,只需要传入参数就可以和你调用的存储过程就可以。有关万能DBHelper的参考代码如下:using System;

using SystemCollectionsGeneric;

using SystemLinq;

using SystemText;

using SystemData;

using SystemDataSqlClient;

namespace Clock

{

public static class DBHelper

{

private static SqlConnection connection;//这里的SqlConnection 自己写//对数据进行查询时候调用的

public static SqlConnection Connection

{

get

{

string connectionString = "Data Source=PC-Ahsun;Initial Catalog=Clock; uid=sa;pwd=striveahsun";

if (connection == null)

{

connection = new SqlConnection(connectionString);

connectionOpen();

}

else if (connectionState == SystemDataConnectionStateClosed)

{

connectionOpen();

}

else if (connectionState == SystemDataConnectionStateBroken)

{

connectionClose();

connectionOpen();

}

return connection;

}

}//对数据进行增删改时候调用的

public static int ExecuteCommand(string sql)

{

SqlCommand cmd = new SqlCommand(sql,connection);

int resualt = cmdExecuteNonQuery();

return resualt;

}

}

}

建议用ado连接,网上的ado封装好的库有很多,随便下一个就行。

包含了头文件和cpp文件后,可以这样

CADORecordset pRs = new CADORecordset((static_cast<CFrenchApp >(AfxGetApp()))->g_pDb);

Sql1="select word,wordtype,meaning,tag,id from word "+Where;

int i=0;

if(pRs->Open((LPCTSTR)Sql1))

{

while(!pRs->IsEof())

{

pRs->GetFieldValue(0,word[i]word);

pRs->GetFieldValue(3,word[i]tag);

pRs->GetFieldValue(1,word[i]wordtype);

pRs->GetFieldValue(2,word[i]meaning);

pRs->GetFieldValue(4,word[i]id);

pRs->MoveNext();

i++;

}

pRs->Close();

}

m_max=i;

m_cur=0;

delete pRs;

这样就可以得到数据库里的东西

1、C/C++与数据库交互,像 mssql/ mysql / oracle 等,一般都有成熟的第三方库,这些库里面无非就是封装了与数据库通讯的方式和通讯协议搜一下要用的数据库相关的 API 文档,会说得很清楚任何文件都是二进制数据,关键是数据存储的组织方式通用扩展名的文件,像gif/doc/jpg/wav,格式都是固定的。

2、举个例子,连接SQL:

// 打开数据库

strDBClassFormat(_T("Provider=MicrosoftJetOLEDB40;Data Source=%s;Jet OLEDB:Database Password=%s"), m_strUnEntryptMdbFilePath,m_strMDBPassword);

// 创建连接

HRESULT hr = m_pConnectionCreateInstance(_uuidof(Connection));

_ConnectionPtr m_pConnection->Open(m_strDBClass,_T(""),_T(""),adConnectUnspecified);

// 声明表单指针

_RecordsetPtr pBandRecordset;

pBandRecordsetCreateInstance(__uuidof(Recordset));

// 执行语句

CString strSQL(L"SELECT  FROM [Band]");

m_pConnection->Execute((LPCTSTR)strSQL,NULL,0);

// 提取某一项 例如BandInfo

int iBandInfo = wcscmp(colum, L"BandInfo");

while(!recordsetPtr->adoEOF)

{

var = recordsetPtr->GetCollect(colum);

if(varvt != VT_NULL)

strName = (LPCSTR)_bstr_t(var);

recordsetPtr->MoveNext();

}

C语言是一门编程语言,而数据库则是数据的集合。C语言是一门通用计算机编程语言,应用广泛,用它可以开发数据库管理软件,也可以通过C语言借助于SQL语句来 *** 作数据库。数据库指的是以一定方式储存在一起、能为多个用户共享、具有尽可能小的冗余度的特点、是与应用程序彼此独立的数据集合。一般来数据库都需要数据库管理软件,比如acess、oracle等等,这些大型并且对执行效率要求较高的软件,往往都是C语言开发的。

数据库会提供访问方式, 例如ODBC和API。在C语言中将SQL语句封装后传给ODBC或API由他们完成对数据库的 *** 作。SQL语句不是直接“嵌入”到C语言里的。

具体方法要查看不同数据库的开发文档。

以上就是关于C语言跟数据库有什么关系吗全部的内容,包括:C语言跟数据库有什么关系吗、c语言 *** 作数据库、如何通过c或c++调用存储过程等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9354447.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存