c#连接MySql数据库的两种方法

一、用MySQLDriverCS连接MySQL数据库

    先下载和安装MySQLDriverCS,地址:

    http://sourceforge.net/projects/mysqldrivercs/

    在安装文件夹下面找到MySQLDriver.dll,然后将MySQLDriver.dll添加引用到项目中

    注:我下载的是版本是 MySQLDriverCS-n-EasyQueryTools-4.0.1-DotNet2.0.exe

     using  System;
    
using  System.Collections.Generic;
    
using  System.ComponentModel;
    
using  System.Data;
    
using  System.Data.Odbc;
    
using  System.Drawing;
    
using  System.Linq;
    
using  System.Text;
    
using  System.Windows.Forms;
    
using  MySQLDriverCS;

    
namespace  mysql
    {
        
public   partial   class  Form1 : Form
        {
            
public  Form1()
            {
                InitializeComponent();
            }

            
private   void  Form1_Load( object  sender, EventArgs e)
            {
            MySQLConnection conn 
=   null ;
            conn 
=   new  MySQLConnection( new  MySQLConnectionString( " localhost " " inv " " root " " 831025 " ).AsString);
            conn.Open();
            MySQLCommand commn 
=   new  MySQLCommand( " set names gb2312 " , conn);
            commn.ExecuteNonQuery();
            
string  sql  =   " select * from exchange  " ;
            MySQLDataAdapter mda 
=   new  MySQLDataAdapter(sql, conn);
            DataSet ds 
=   new  DataSet();
            mda.Fill(ds, 
" table1 " );
            
this .dataGrid1.DataSource  =  ds.Tables[ " table1 " ];
            conn.Close();
            }
        }
    }


二、通过ODBC访问mysql数据库:

    1.安装Microsoft ODBC.net:我安装的是mysql-connector-odbc-3.51.22-win32.msi

    2.安装MDAC 2.7或者更高版本:我安装的是mdac_typ.exe 2.7简体中文版

    3.安装MySQL的ODBC驱动程序:我安装的是 odbc_net.msi

    4.管理工具 -> 数据源ODBC –>配置DSN…

    5.解决方案管理中添加引用 Microsoft.Data.Odbc.dll(1.0.3300)

    6.代码中增加引用 using Microsoft.Data.Odbc;

     using  System;
    
using  System.Collections.Generic;
    
using  System.ComponentModel
    
using  System.Drawing;
    
using  System.Linq;    // vs2005好像没有这个命名空间,在c#2008下测试自动生成的
     using  System.Text;
    
using  System.Windows.Forms;
    
using  Microsoft.Data.Odbc;

    
namespace  mysql
    {
        
public   partial   class  Form1 : Form
        {
            
public  Form1()
            {
                InitializeComponent();
            }

            
private   void  Form1_Load( object  sender, EventArgs e)
            {
                
string  MyConString  =   " DRIVER={MySQL ODBC 3.51 Driver}; "   +

                                     
" SERVER=localhost; "   +

                                     
" DATABASE=inv; "   +

                                     
" UID=root; "   +

                                     
" PASSWORD=831025; "   +

                                     
" OPTION=3 " ;

                OdbcConnection MyConnection 
=   new  OdbcConnection(MyConString);
                MyConnection.Open();
                Console.WriteLine(
"  success, connected successfully ! " );
                
string  query  =   " insert into test values( 'hello', 'lucas', 'liu') " ;
                OdbcCommand cmd 
=   new  OdbcCommand(query, MyConnection);
                
// 处理异常:插入重复记录有异常
                 try
                {
                     cmd.ExecuteNonQuery();
                 }

                
catch (Exception ex)
                 {
                     Console.WriteLine(
" record duplicate. " );
                 }

                 
finally
                 {
                     cmd.Dispose();
                 }

    
// ***********************用read方法读数据到textbox**********************

                
string  tmp1  =   null ;
                
string  tmp2  =   null ;
                
string  tmp3  =   null ;
                query 
=   " select * from test  " ;
                OdbcCommand cmd2 
=   new  OdbcCommand(query, MyConnection);
                OdbcDataReader reader 
=  cmd2.ExecuteReader();

                
while  (reader.Read())
                {
                    tmp1 
=  reader[ 0 ].ToString();
                    tmp2 
=  reader[ 1 ].ToString();
                    tmp3 
=  reader[ 2 ].ToString();
                }
                
this .textBox1.Text  =  tmp1  +   "   "   +  tmp2  +   "   "   +  tmp3;

                
*/

    
// ************************用datagridview控件显示数据表**************************
     string  MyConString  =   " DRIVER={MySQL ODBC 3.51 Driver}; "   +
                                     
" SERVER=localhost; "   +
                                     
" DATABASE=inv; "   +
                                     
" UID=root; "   +
                                     
" PASSWORD=831025; "   +
                                     
" OPTION=3 " ;
              OdbcConnection MyConnection 
=   new  OdbcConnection(MyConString);
              OdbcDataAdapter oda 
=   new  OdbcDataAdapter( " select * from customer  " , MyConnection);
              DataSet ds 
=   new  DataSet();
              oda.Fill(ds, 
" employee " );
              
this .dataGridView1.DataSource  =  ds.Tables[ " employee " ];
    
*/
               MyConnection.Close();
            }
        }
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值