1. /**
  2. * 作者:牛腩
  3. * 创建时间:2010年3月7日17时35分
  4. * 类说明:对MYSQL数据库的操作类
  5. */
  6. using System;
  7. using System.Data;
  8. using MySql.Data.MySqlClient;
  9. namespace Niunan.BYLW.Utility
  10. {
  11. /// <summary>对MYSQL数据库的操作类
  12. ///
  13. /// </summary>
  14. public class MYSQLHelper
  15. {
  16. private MySqlConnection conn = null;
  17. private MySqlCommand cmd = null;
  18. private MySqlDataReader sdr = null;
  19. public MYSQLHelper()
  20. {
  21. //string connStr = WebConfigurationManager.ConnectionStrings["connStr"].ToString();
  22. string connStr = "server=localhost;database=test;uid=root;pwd=123456;charset=utf8";
  23. conn = new MySqlConnection(connStr);
  24. }
  25. /// <summary>创建Command对象
  26. ///
  27. /// </summary>
  28. /// <param name="sql">SQL语句</param>
  29. public void CreateCommand(string sql)
  30. {
  31. conn.Open();
  32. cmd = new MySqlCommand(sql, conn);
  33. }
  34. /// <summary>添加参数
  35. ///
  36. /// </summary>
  37. /// <param name="paramName">参数名称</param>
  38. /// <param name="value">值</param>
  39. public void AddParameter(string paramName, object value)
  40. {
  41. cmd.Parameters.Add(new MySqlParameter(paramName, value));
  42. }
  43. /// <summary>执行不带参数的增删改SQL语句
  44. ///
  45. /// </summary>
  46. /// <param name="cmdText">增删改SQL语句</param>
  47. /// <param name="ct">命令类型</param>
  48. /// <returns></returns>
  49. public bool ExecuteNonQuery()
  50. {
  51. int res;
  52. try
  53. {
  54. res = cmd.ExecuteNonQuery();
  55. if (res > 0)
  56. {
  57. return true;
  58. }
  59. }
  60. catch (Exception ex)
  61. {
  62. throw ex;
  63. }
  64. finally
  65. {
  66. if (conn.State == ConnectionState.Open)
  67. {
  68. conn.Close();
  69. }
  70. }
  71. return false;
  72. }
  73. /// <summary>执行查询SQL语句
  74. ///
  75. /// </summary>
  76. /// <param name="cmdText">查询SQL语句</param>
  77. /// <returns></returns>
  78. public DataTable ExecuteQuery()
  79. {
  80. DataTable dt = new DataTable();
  81. using (sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection))
  82. {
  83. dt.Load(sdr);
  84. }
  85. return dt;
  86. }
  87. /// <summary>返回查询SQL语句查询出的结果的第一行第一列的值
  88. ///
  89. /// </summary>
  90. /// <returns></returns>
  91. public string ExecuteScalar()
  92. {
  93. string res = "";
  94. try
  95. {
  96. object obj = cmd.ExecuteScalar();
  97. if (obj != null)
  98. {
  99. res = obj.ToString();
  100. }
  101. }
  102. catch (Exception ex)
  103. {
  104. throw ex;
  105. }
  106. finally
  107. {
  108. if (conn.State == ConnectionState.Open)
  109. {
  110. conn.Close();
  111. }
  112. }
  113. return res;
  114. }
  115. }
  116. }

都是把那个SQLITEHelper的操作类搬过来的,改了MySqlConnection等变量名,对MYSQL来说经常会出现中文乱码,经实验,解决方法:

① 用PHPMYADMIN建立MYSQL数据库的时候记得选择UTF-8的编码

② 在上面的数据库操作类中的连接字符串中记得加上charset=utf8

这样用上面的操作类来插入中文就不会出现乱码了。

 

自己封装的ASP.NET的MYSQL的数据库操作类的更多相关文章

  1. php : mysql数据库操作类演示

    设计目标: 1,该类一实例化,就可以自动连接上mysql数据库: 2,该类可以单独去设定要使用的连接编码(set names XXX) 3,该类可以单独去设定要使用的数据库(use XXX): 4,可 ...

  2. php MySQL数据库操作类源代码

    php MySQL数据库操作类源代码: <?php class MySQL{ private $host; //服务器地址 private $name; //登录账号 private $pwd; ...

  3. 设计模式 - 单例模式mysql数据库操作类

    待续... index.php 调用方法: <?php header('Content-Type:text/html; charset=utf8'); require 'instance.php ...

  4. MySQL数据库操作类(PHP实现,支持连贯操作)

    <?php /** * Author: suvan * CreateTime: 2018/2/27 * description: 数据库操作类(仅对接MySQL数据库,主要利用MySQLi函数) ...

  5. asp.net+mysq 数据库操作类

    对数据库操作的使用方法: 1.引入命名空间 2.操作.三四行代码即可完成数据操作.类似于: using System; using System.Data; using System.Text; us ...

  6. asp.net数据库操作类(一)

    Hi Boy, 我现在需要使用asp.net操作access数据库,你来做个.boy听后就开始百度了,最后找到了一个比较好的方法.如下:  C# Code  1234567   <appSett ...

  7. php pdo mysql数据库操作类

    <?php namespace iphp\core; use iphp\App; /** * 数据库操作基类 基于pdo * @author xuen * 支持链式操作,支持参数绑定 * 说明1 ...

  8. Mysql之数据库操作

    数据库操作: 链接数据库: mysql -uroot -p masql -uroot -pmysql 退出数据库: exit/quit/ctrl + d   sql语句最后需要分号结尾: 查看时间: ...

  9. C#---数据库访问通用类、Access数据库操作类、mysql类 .[转]

    原文链接 //C# 数据库访问通用类 (ADO.NET)using System;using System.Collections.Generic;using System.Text;using Sy ...

随机推荐

  1. Java JVM多线程

  2. Java 成员初始化顺序

    package com.cwcec.test; class Fu { int num = 5; //构造代码块 { System.out.println("Fu constructor co ...

  3. Maven的setting配置文件

    一.Maven的setting配置文件 和 在Eclipse中对Maven的正确配置. 1.Maven的配置文件(Maven的安装目录/conf/settings.xml ) 和 Maven仓库下(默 ...

  4. PHP 在windows下配置sendmail,通过 mail() 函数发送邮件

    php mail()函数在windows不能用,需要安装sendmail. 1. 从http://glob.com.au下载sendmail.zip 2. 解压sendmail.zip到目录下(最好使 ...

  5. 外部JS的阻塞下载

    转载于:http://www.cnblogs.com/mofish/archive/2011/09/29/2195256.html 所有浏览器在下载JS的时候,会阻止一切其他活动,比如其他资源的下载, ...

  6. web_config配置

    <configuration>    <system.web>      <compilation debug="true" targetFramew ...

  7. CF816E-Karen and Supermarket

    题目 Description 今天Karen要去买东西. 一共有 \(n\) 件物品,每件物品的价格为\(c_i\),同时每件物品都有一张优惠券,可以对这件物品减价 \(d_i\) . 使用第 \(i ...

  8. 【loj2319】[NOIP2017]列队 Splay(卡过)

    题目描述 给出一个 $n\times m$ 的矩阵,第 $i$ 行第 $j$ 列的数为 $(i-1)\times m+j$ . 现在有 $q$ 次操作,每次操作给出位置 $(x,y)$ ,取出 $(x ...

  9. Django获取多个数据及文件上传

    1. 选择性别: 1)更新login.html模板 2)views.py中获取客户端提交的数据 3)当选择性别为“男”后,后台得到了gender=1. 2.选择爱好,可以多选,所以后台会获得多个数据. ...

  10. 【hdu6093】Rikka with Number

    多校第五場的題. 首先是一個好數只在某個進制下,不會是在兩個進制下都爲好數. 另外每個進制好數的個數爲d!-(d-1)!,因爲要保證第一位不爲0. 然後就是在臨界進制下有多少個好數的問題,可以變成兩個 ...