using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using MySql.Data.MySqlClient; /加mysql命名空间;/
using System.Data; //使用System.Data命名空间,否则;DataTable出不来;

//命名空间:chapter08.util

namespace chapter08.util
{
///


/// 这个是一个公共的连接数据库的类
/// static:静态的关键字;static:不可变的;访问的时候,可以直接类名.属性/类名.方法
///

class DBHelper
{
static String str = "server=localhost;userid=root;password=root;database=school;charset=utf8";
//1.获得通用连接对象 ;static,是否可以去掉;
public static MySqlConnection getConn() {
MySqlConnection conn = new MySqlConnection(str);
conn.Open(); //自动打开;
return conn;
}
//2.关闭连接;关闭的连接对象,所以参数是连接对象
public static void close(){
MySqlConnection conn = getConn();
if(conn!=null){
conn.Close();
}
}
//3.增删改操作;方法有参数没有???
public static int update(String sql) {
//通用方法的增删改的连接对象也是通用的.
MySqlConnection conn = getConn();
MySqlCommand comm = new MySqlCommand(sql,conn); //sql是从外部传过来的命令语句;conn是通用的连接对象.
int result = comm.ExecuteNonQuery();
return result;
}
//4.查询操作;参数
public static DataTable query(String sql) {
//通用方法的增删改的连接对象也是通用的.
MySqlConnection conn = getConn();
MySqlDataAdapter adapter = new MySqlDataAdapter(sql, conn);
//定义了一个数据表格对象;没有数据;
DataTable dt = new DataTable();
//这时候填充到数据表格对象dt里面
adapter.Fill(dt); //这时候dt就有数据了;
return dt;
}
}
}