visualc資料庫開發
1. 怎麼在Visual studio里使用c語言對資料庫進行添加 修改 查詢
其實最好還是使用vs,c語言不適合做大型的應用程序,c程序適合做單片機程序和驅動程序。
windows程序最好還是使用vc6.0,網頁程序使用vs2008,單片機和驅動使用匯編語言。
Visual C++的Windows窗體應用程序可以成.exe文件,也就是應用程序,開發軟體可以創建這個項目;如果想寫C語言,Visual C++裡面自帶有編寫.cpp文件的C語言環境
目前vs已經升級到了2010版本。但是,讓人郁悶的是我們卻用不來VC2008或者2010,之前我也是一直困惑著,為什麼軟體升級之後,反而不能用了呢?其實vc它是適合很多編程學科使用的工具,必須對其進行設置後才能編寫語言。方法真的很簡單,我也是今天摸索出來的,之前在網上搜的時候。沒有一個能解決或徹底解決問題的,現在讓我來補上這個缺憾!
一、打開VC++2010
二、文件—》新建—》項目
三、在左邊的最近模塊選著「Win32」,在右邊對話框選著「Win32控制台應用程序 Visual C++」,再在下面輸入「名稱」和「位置」,點擊「確定」
四、在彈出來的對話框中選著「下一步」
五、在「附加選項」下選著「空項目」,其他的不動,點擊完成
六、回到主界面後,在左邊的「解決方案資源管理器」,右擊「源文件」—》「添加」—》「新建項」
七、在中間的對話框中選著「C++文件(.cpp)」,輸入文件「名稱」—》「添加」(注意要吧文件名改成「名稱」+「.c」,不然默認的是「.cpp」,仍然編譯不了)
八、寫入一個C語言程序,你就發現成功了
九、以後需要繼續編程的只需要將源文件下原來的.cpp文件右健移除(注意一次只能編寫一個文件,只是移除,目錄下仍存在,不必擔心),再按照第六步下來就行啦,是不是很神奇!!
2. C++和VisualC++有什麼區別
C ++與Visual C ++之間的主要區別
1、 C ++是面向對象的編程語言,而Visual C ++是集成開發環境(IDE)和C和C ++語言的編譯器。
2、在C ++中,編譯器將C ++程序代碼轉換為計算機可以理解和執行的機器代碼。而Visual C
++有助於編寫代碼,編譯和調試C ++源代碼。
3、C ++編程語言可以作為庫中的庫來移植,以便在C ++應用程序中使用。而Visual C ++也有一
些可以與Windows一起使用的專用庫,而當你在C ++應用程序中使用這些內置庫時,可能會遇到
Windows問題。
4、編寫代碼以開發單獨使用C ++的Microsoft DirectX API,Windows API和Microsoft .NET
Framework是很困難的。但是編程開發Microsoft DirectX API,Windows API和Microsoft .NET
Framework更容易。
5、C ++編程語言主要用於設計和編程硬體。由於Visual C ++是IDE,因此它用於編譯和執行它。
6、在性能方面,C ++贏得了Visual C ++的競爭。應用程序開發周期的初始部分性能很高,而
Visual C ++的性能在應用程序開發周期的初始階段很低。但是使用C ++維護後期開發階段非常困
難。
結論 - C ++與Visual C ++
C ++是C語言的增強和高級,它是面向對象編程語言的通用目的。而Visual C ++是該軟體的集成開
發環境(IDE)產品。這是為了編譯C,C ++和C ++ / CLI編程語言而開發的。
(2)visualc資料庫開發擴展閱讀:
C ++與C#之間的主要區別
1、C ++不是純粹的面向對象編程語言,而C#是純粹的面向對象編程語言。
2、C ++不支持對數組進行綁定檢查,而C#支持對數組進行綁定檢查。
3、在C ++中,程序員可以在程序中的任何地方使用指針,而在C#中,程序員只能在不安全模式下
使用指針。
4、在C ++中,switch語句,決策變數不能是字元串,而是在C#switch語句中,它可以是一個字元串。
5、C ++不支持自動垃圾收集,而C#支持自動垃圾收集器進行內存管理。
3. visual c++和c+哪個好有什麼區別
C++是指C++編程語言(遵循ISO C++標准);而Visual C++指的是微軟開發的集成開發環境,這個集成開發環境可以進行C語言、C++語言、C++\CLI、C++\CX語言的開發,並且包含的大量的開發工具和語言擴展。
Visual C++涉及的面比C++要廣很多(不單單只涉及C++),所以你如果完全掌握Visual C++的話,標准C++當然不在話下。 某些人說的「會VC++並不代表你會C++「 並不正確。
不過對於初學者,建議還是從標准C++開始學。Visual C++的東西很多很多。
4. visual studio怎麼做資料庫
publicclassStudentService
{
//從配置文件中讀取資料庫連接字元串
=ConfigurationManager.ConnectionStrings["accpConnectionString"].ToString();
=ConfigurationManager.ConnectionStrings["DataBaseOwner"].ToString();
AdoNetModels.Studentmodel=newStudent();
//conststringspName=".usp_DeleteStudent";
#region刪除數據1
publicintDeleteStudent(intstuID)
{
intresult=0;
//資料庫連接Connection對象
sqlConnectionconnection=newSqlConnection(connString);
//構建刪除的sql語句
stringsql=string.Format("DeleteFromStudentWherestuID={0}",stuID);
//定義command對象
SqlCommandcommand=newSqlCommand(sql,connection);
try
{
connection.Open();
result=command.ExecuteNonQuery();//執行命令
}
catch(Exceptionex)
{
Console.WriteLine(ex.Message);
}
finally
{
connection.Close();
}
returnresult;
}
#endregion
#region刪除數據2
publicintDeleteStudent2(intstuID)
{
intresult=0;
//構建刪除的sql語句使用參數
stringsql="DeleteFromStudentWherestuID=@stuID";
using(SqlConnectionconnection=newSqlConnection(connString))
{
SqlCommandobjCommand=newSqlCommand(sql,connection);
objCommand.Parameters.Add("@stuID",SqlDbType.Int).Value=stuID;
connection.Open();
result=objCommand.ExecuteNonQuery();
}
returnresult;
}
#endregion
publicintInsertStudent(Studentmodel)
{
intresult=0;
SqlConnectionconnection=newSqlConnection(connString);
//構建插入的sql語句
stringsql=string.Format("INSERTINTOStudent(stuName,age)values('{0}','{1}')",
model.StuName,model.Age);
//定義command對象
SqlCommandcommand=newSqlCommand(sql,connection);
try
{
connection.Open();
result=command.ExecuteNonQuery();//執行命令
}
catch(Exceptionex)
{
Console.WriteLine(ex.Message);
}
finally
{
connection.Close();
}
returnresult;
}
publicintInsertStudent2(Studentmodel)
{
intresult=0;
//構建插入的sql語句
stringsql="INSERTINTOStudent(age,stuName)values(@age,@stuName)";
using(SqlConnectionconnection=newSqlConnection(connString))
{
SqlCommandobjCommand=newSqlCommand(sql,connection);
objCommand.Parameters.Add("@age",SqlDbType.Int).Value=model.Age;
objCommand.Parameters.Add("@stuName",SqlDbType.NVarChar,50).Value=model.StuName;
connection.Open();
result=objCommand.ExecuteNonQuery();
}
returnresult;
}
publicintInsertStudent3(Studentmodel)
{
intresult=0;
using(SqlConnectionconnection=newSqlConnection(connString))
{
SqlCommandobjCommand=newSqlCommand(dboOwner+".usp_InsertStudent",connection);
objCommand.CommandType=CommandType.StoredProcere;
objCommand.Parameters.Add("@age",SqlDbType.Int).Value=model.Age;
objCommand.Parameters.Add("@stuName",SqlDbType.NVarChar,50).Value=model.StuName;
connection.Open();
result=objCommand.ExecuteNonQuery();
}
returnresult;
}
publicintInsertStudent5(Studentmodel)
{
intoutputResult=0;
intreturnvalue=0;
using(SqlConnectionconnection=newSqlConnection(connString))
{
SqlCommandobjCommand=newSqlCommand(dboOwner+".usp_InsertStudent",connection);
objCommand.CommandType=CommandType.StoredProcere;
objCommand.Parameters.Add("@age",SqlDbType.Int).Value=model.Age;
objCommand.Parameters.Add("@stuName",SqlDbType.NVarChar,50).Value=model.StuName;
//定義輸出參數
SqlParameterparameter=newSqlParameter("@stuID",SqlDbType.Int);
parameter.Direction=ParameterDirection.Output;
objCommand.Parameters.Add(parameter);
//定義ReturnValue參數
objCommand.Parameters.Add("ReturnValue",SqlDbType.Int);
objCommand.Parameters["ReturnValue"].Direction=ParameterDirection.ReturnValue;
connection.Open();
objCommand.ExecuteNonQuery();//執行命令
//獲取輸出參數的值在命令執行以後
outputResult=(int)objCommand.Parameters["@stuID"].Value;
//存儲過程中為定義return值默認為0
returnvalue=(int)objCommand.Parameters["ReturnValue"].Value;
}
returnreturnvalue;
}
publicIListGetAllStudents1()
{
IListdataList=newList();
DataSetdataSet=newDataSet(); //聲明並初始化DataSet
SqlDataAdapterdataAdapter; //聲明DataAdapter
using(SqlConnectionconn=newSqlConnection(connString))
{
//定義command對象
SqlCommandcommand=newSqlCommand(dboOwner+".usp_SelectStudentsAll",conn);
command.CommandType=CommandType.StoredProcere;
//Command定義帶參數的SQL語句的參數
//command.Parameters.Add("@stuID",SqlDbType.Int);
//給輸入參數賦值
//command.Parameters["@stuID"].Value=5;
conn.Open();
//初始化DataAdapter
dataAdapter=newSqlDataAdapter(command);
//填充DataSet
dataAdapter.Fill(dataSet,"dataSetName");
//處理數據集中的數據
foreach(DataRowrowindataSet.Tables[0].Rows)
{
Studentmodel=newStudent();
model.StuId=Convert.ToInt32(row["stuID"]);
model.StuName=Convert.ToString(row["stuName"]);
dataList.Add(model);
}
}
returndataList;
}
publicvoidMoreResult()
{
DataSetdataSet=newDataSet(); //聲明並初始化DataSet
SqlDataAdapterdataAdapter; //聲明DataAdapter
//定義查詢語句
stringsql=string.Format("SELECT*FROMstudentwherestuid>50;SELECT*FROMstudent");
SqlConnectionconnection=newSqlConnection(connString);
try
{
connection.Open();
//初始化DataAdapter
dataAdapter=newSqlDataAdapter(sql,connection);
//填充DataSet
dataAdapter.Fill(dataSet,"dataSetName");
//處理數據集中的數據
foreach(DataRowrowindataSet.Tables[0].Rows)
{
//intgradeId=(int)row["GradeID"];
}
}
catch(Exceptionex)
{
Console.WriteLine(ex.Message);
}
finally
{
connection.Close();
}
}
}
}
5. 在visual studio 2008里用c#開發一個簡單的C/S模式的管理信息系統
呵呵,問題還真多呢,做B/S模式開發C/S模式應該很容易理解的,建議找本書看看,新建一個項目只建一個form窗體就好,access資料庫一般放在data文件裡面,移植的話建議選好目錄,資料庫連接可以在config文件裡面寫,一般項目的話會寫一個DBhelp,發布vs2008自帶有部署文件的
6. visual stio 2010上visual c++開發windows窗體應用程序,如何連接自帶的sql server資料庫
在伺服器資源管理器中「右擊」數據連接,選擇添加數據連接。在就可以自己填伺服器名,連接方式,選資料庫名稱,就ok了
7. 求<<Visual C++.net資料庫開發經典案例解析>> 源代碼
既然是圖書館的書肯定有附光碟的,可以向圖書管理員問問,一般圖書館主頁上有下
當然你也可以在網上下,這里有
http://www.gougou.com/search?search=Visual%20C%2B%2B.net%E6%95%B0%E6%8D%AE%E5%BA%93%E5%BC%80%E5%8F%91%E7%BB%8F%E5%85%B8%E6%A1%88%E4%BE%8B%E8%A7%A3%E6%9E%90&id=1
8. 如何在Visual Studio中讓應用程序訪問資料庫
在Visual Studio中讓應用程序訪問資料庫的操作方法和步驟如下:
1、首先,打開vs2010並依次單擊工具欄的「文件」-->「新建」,新建相應的應用程序,如下圖所示。
9. Visual C和Visual S有什麼不同,各自擅長哪方面
說法不準確,你可以簡稱VC和VS。全稱是:
Visual C++
Visual Studio
這兩個是包含關系,VS是一個多種語言集合的開發工具包,其中包含了VC/VB/VJ/VF高版本中還包含了c#。
所以。。不能說擅長哪個方面,VC是開發非網路應用很強大的工具,雖然隨著網路應用的發展,已經逐步被邊緣化的趨勢,但還是開發驅動、服務和單機桌面程序的有數的幾個強大工具之一。開發網路應用也是可以的,但沒有JAVA C#那麼方便。
還有就是C++語言和VC編程相對比較復雜,不如VB/PB等開發簡單桌面和資料庫應用那麼容易入手,代碼量較大。
10. 跪求Visual C++程序連接資料庫的方法,十分火急!!!
C#的各種連接資料庫2007年11月01日 星期四 11:461.C#連接連接Access
程序代碼:
-------------------------------------------------------------------------------
using System.Data;
using System.Data.OleDb;
......
string strConnection="Provider=Microsoft.Jet.OleDb.4.0;";
strConnection+=@"Data Source=C:\BegASPNET\Northwind.mdb";
OleDbConnection objConnection=new OleDbConnection(strConnection);
......
objConnection.Open();
objConnection.Close();
......
--------------------------------------------------------------------------------
解釋:
連接Access資料庫需要導入額外的命名空間,所以有了最前面的兩條using命令,這是必不可少的!
strConnection這個變數里存放的是連接資料庫所需要的連接字元串,他指定了要使用的數據提供者和要使用的數據源.
"Provider=Microsoft.Jet.OleDb.4.0;"是指數據提供者,這里使用的是Microsoft Jet引擎,也就是Access中的數據引擎,asp.net就是靠這個和Access的資料庫連接的.
"Data Source=C:\BegASPNET\Northwind.mdb"是指明數據源的位置,他的標准形式是"Data Source=MyDrive:MyPath\MyFile.MDB".
PS:
1."+="後面的"@"符號是防止將後面字元串中的"\"解析為轉義字元.
2.如果要連接的資料庫文件和當前文件在同一個目錄下,還可以使用如下的方法連接:
strConnection+="Data Source=";
strConnection+=MapPath("Northwind.mdb");
這樣就可以省得你寫一大堆東西了!
3.要注意連接字元串中的參數之間要用分號來分隔.
"OleDbConnection objConnection=new OleDbConnection(strConnection);"這一句是利用定義好的連接字元串來建立了一個鏈接對象,以後對資料庫的操作我們都要和這個對象打交道.
"objConnection.Open();"這用來打開連接.至此,與Access資料庫的連接完成.
--------------------------------------------------------------------------------
2.C#連接SQL Server
程序代碼:
--------------------------------------------------------------------------------
using System.Data;
using System.Data.SqlClient;
...
string strConnection="user id=sa;password=;";
strConnection+="initial catalog=Northwind;Server=YourSQLServer;";
strConnection+="Connect Timeout=30";
SqlConnection objConnection=new SqlConnection(strConnection);
...
objConnection.Open();
objConnection.Close();
...
--------------------------------------------------------------------------------
解釋:
連接SQL Server資料庫的機制與連接Access的機制沒有什麼太大的區別,只是改變了Connection對象和連接字元串中的不同參數.
首先,連接SQL Server使用的命名空間不是"System.Data.OleDb",而是"System.Data.SqlClient".
其次就是他的連接字元串了,我們一個一個參數來介紹(注意:參數間用分號分隔):
"user id=sa":連接資料庫的驗證用戶名為sa.他還有一個別名"uid",所以這句我們還可以寫成"uid=sa".
"password=":連接資料庫的驗證密碼為空.他的別名為"pwd",所以我們可以寫為"pwd=".
這里注意,你的SQL Server必須已經設置了需要用戶名和密碼來登錄,否則不能用這樣的方式來登錄.如果你的SQL Server設置為Windows登錄,那麼在這里就不需要使用"user id"和"password"這樣的方式來登錄,而需要使用"Trusted_Connection=SSPI"來進行登錄.
"initial catalog=Northwind":使用的數據源為"Northwind"這個資料庫.他的別名為"Database",本句可以寫成"Database=Northwind".
"Server=YourSQLServer":使用名為"YourSQLServer"的伺服器.他的別名為"Data Source","Address","Addr".如果使用的是本地資料庫且定義了實例名,則可以寫為"Server=(local)\實例名";如果是遠程伺服器,則將"(local)"替換為遠程伺服器的名稱或IP地址.
"Connect Timeout=30":連接超時時間為30秒.
在這里,建立連接對象用的構造函數為:SqlConnection.
--------------------------------------------------------------------------------
3.C#連接Oracle
程序代碼:
--------------------------------------------------------------------------------
using System.Data.OracleClient;
using System.Data;
//在窗體上添加一個按鈕,叫Button1,雙擊Button1,輸入以下代碼
private void Button1_Click(object sender, System.EventArgs e)
{
string ConnectionString="Data Source=sky;user=system;password=manager;";//寫連接串
OracleConnection conn=new OracleConnection(ConnectionString);//創建一個新連接
try
{
conn.Open();
OracleCommand cmd=conn.CreateCommand();
cmd.CommandText="select * from MyTable";//在這兒寫sql語句
OracleDataReader odr=cmd.ExecuteReader();//創建一個OracleDateReader對象
while(odr.Read())//讀取數據,如果odr.Read()返回為false的話,就說明到記錄集的尾部了
{
Response.Write(odr.GetOracleString(1).ToString());//輸出欄位1,這個數是欄位索引,具體怎麼使用欄位名還有待研究
}
odr.Close();
}
catch(Exception ee)
{
Response.Write(ee.Message); //如果有錯誤,輸出錯誤信息
}
finally
{
conn.Close(); //關閉連接
}
}
--------------------------------------------------------------------------------
4.C#連接MySQL
程序代碼:
--------------------------------------------------------------------------------
using MySQLDriverCS;
// 建立資料庫連接
MySQLConnection DBConn;
DBConn = new MySQLConnection(new MySQLConnectionString("localhost","mysql","root","",3306).AsString);
DBConn.Open();
// 執行查詢語句
MySQLCommand DBComm;
DBComm = new MySQLCommand("select Host,User from user",DBConn);
// 讀取數據
MySQLDataReader DBReader = DBComm.ExecuteReaderEx();
// 顯示數據
try
{
while (DBReader.Read())
{
Console.WriteLine("Host = {0} and User = {1}", DBReader.GetString(0),DBReader.GetString(1));
}
}
finally
{
DBReader.Close();
DBConn.Close();
}
//關閉資料庫連接
DBConn.Close();
--------------------------------------------------------------------------------
5.C#連接IBM DB2
程序代碼:
--------------------------------------------------------------------------------
OleDbConnection1.Open();
//打開資料庫連接
OleDbDataAdapter1.Fill(dataSet1,"Address");
//將得來的數據填入dataSet
DataGrid1.DataBind();
//綁定數據
OleDbConnection1.Close();
//關閉連接
//增加資料庫數據
在Web Form上新增對應欄位數量個數的TextBox,及一個button,為該按鍵增加Click響應事件代碼如下:
this.OleDbInsertCommand1.CommandText = "INSERTsintosADDRESS(NAME,
EMAIL, AGE, ADDRESS) valueS
(''"+TextBox1.Text+"'',''"+TextBox2.Text+"'',''"+TextBox3.Text+"'',''"+TextBox4.Text+"'')";
OleDbInsertCommand1.Connection.Open();
//打開連接
OleDbInsertCommand1.ExecuteNonQuery();
//執行該SQL語句
OleDbInsertCommand1.Connection.Close();
//關閉連接
--------------------------------------------------------------------------------
6.C#連接SyBase
程序代碼: (OleDb)
--------------------------------------------------------------------------------
Provider=Sybase.ASEOLEDBProvider.2;Initial Catalog=資料庫名;User ID=用戶名;Data Source=數據源;Extended Properties="";Server Name=ip地址;Network Protocol=Winsock;Server Port Address=5000;
Visual C 連接資料庫
- 連接SQL Server 2000
使用DAO
看下面的代碼:
CDaoDatabase db;
CString conn;
conn="ODBC;Driver=
SQLServer};Server=192.168.0.4;Database=mydb;uid=sa;pwd=";
db.Open(NULL,FALSE,FALSE,conn);
CString s=db.GetConnect();
CDaoRecordset rs(&db);
rs.Open(AFX_DAO_USE_DEFAULT_TYPE,"select * from tb_code");
TRACE("%drn",rs.GetRecordCount());
rs.Close();
db.Close();
其中Server=192.168.0.4是sql server伺服器的ip地址,也可以用主機名表示;Database=mydb表示使用mydb資料庫;uid和pwd分別表示訪問資料庫的用戶名和密碼。
注意:上面的代碼的運行還要用#include "afx.h" 把afx.h包含進來。當然最好還是加入些必要的出錯處理代碼,這里就不在詳述了。
二 連接 Microsoft Access資料庫
看下面實例的代碼,這也是我用的比較多的一種方法,access文件只要放在和應用程序相同的文件夾中就能保證代碼可以正確執行。
CString sPath,message;
GetMoleFileName(NULL,sPath.GetBufferSetLength (MAX_PATH+1),MAX_PATH);
sPath.ReleaseBuffer();
int nPos;
nPos=sPath.ReverseFind('');
sPath=sPath.Left(nPos);
CString runpath=sPath+"clzmf.mdb"; //這里的clzmf.mdb就是要打開的資料庫名
runpath.Replace('','/');
m_pDatabase=new CDaoDatabase;
try
{
m_pDatabase->Open(runpath);
}
catch(CDaoException *e)
{
message=_T("Could't open database-- Exception:");
message+=e->m_pErrorInfo->m_strDescription;
AfxMessageBox(message);
}
CString sqlstr="select * from user_info where user_id='myid';
CDaoRecordset rs(m_pDatabase);
try
{
rs.Open(AFX_DAO_USE_DEFAULT_TYPE,sqlstr);
}
catch(CDaoException *e)
{
message=_T("Could't open Recordset-- Exception:");
message+=e->m_pErrorInfo->m_strDescription;
AfxMessageBox(message);
}
這里加入了異常處理的代碼,其他注意選項可以參照Sql Server 2000的注意選項。
#連接SQL資料庫並且在表中進行對數據操作2007-11-30 16:07using System;
using System.Collections.Generic;
using System.Text;
using Model;
using System.Data;
using System.Data.SqlClient;
//在表中修改
private void btnOK_Click(object sender, EventArgs e)
{
try
{
DialogResult result = MessageBox.Show("你確定?", "系統提示", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
if (result == DialogResult.Yes)
{
//string strConn = "server=.;uid=sa;pwd=;database=wareDB";
string strConn = "server=.;uid=sa;pwd=;database=ShopManegerDB";
SqlConnection conn = new SqlConnection(strConn);
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
cmd.CommandText = "select * from Shop";
SqlDataAdapter da = new SqlDataAdapter();
da.SelectCommand = cmd; //獲取選擇命令
//創建自動生成Sql對象
SqlCommandBuilder builder = new SqlCommandBuilder(da);
//保存修改
da.Update(ds.Tables[0]); //提交更新
MessageBox.Show("修改成功");
this.Isindsplay();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message);
}
}
//在表中操作刪除
private void 刪除ToolStripMenuItem_Click(object sender, EventArgs e)
{
//保證選中
if (dgvData.CurrentCell.RowIndex != -1)
{
DialogResult result = MessageBox.Show("你確定?", "系統提示", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
if (result == DialogResult.Yes)
{
//刪除
ds.Tables[0].Rows[dgvData.CurrentCell.RowIndex].Delete(); //刪除該選中行
}
}
}
刪除成功後,在次按保存按鈕.