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. sql nolock是什么

    百度:SQL Server 中的 NOLOCK 到底是什么意思? 文章地址:http://blog.sina.com.cn/s/blog_7d3b18a50100rfwg.html 查询语句加上 no ...

  2. C#高级编程(第六版)学习:第三十一章:Windows窗体

    第三十一章 Windows窗体 创建Windows窗体应用程序 在文本编辑器中输入: /* * form.cs * a simple windows form * */ using System; u ...

  3. J2EE体系

    J2EE的概念 目前,Java 2平台有3个版本,它们是适用于小型设备和智能卡的Java 2平台Micro版(Java 2 Platform Micro Edition,J2ME).适用于桌面系统的J ...

  4. 【beta】Scrum站立会议第4次....11.6

    小组名称:nice! 组长:李权 成员:于淼  刘芳芳韩媛媛 宫丽君 项目内容:约跑app(约吧) 时间:  12:00——12:30 地点:传媒西楼220室 本次对beta阶段的需求进行更新如下: ...

  5. [翻译]API Guides - Service

    官方文档原文地址:http://developer.android.com/guide/components/services.html Service是应用程序组件之一,它并不提供一个用户界面,可以 ...

  6. Python2 获取docx/doc文件内容

    整体思路: 下载文件并修改后缀为zip文件,解压zip文件,所要获取的内容在固定的文件夹下:work/temp/word/document.xml 所用包,全部是python自带,不需要额外下载安装. ...

  7. ConcurrentHashMap原理分析(1.7与1.8)-put和 get 需要执行两次Hash

    ConcurrentHashMap 与HashMap和Hashtable 最大的不同在于:put和 get 两次Hash到达指定的HashEntry,第一次hash到达Segment,第二次到达Seg ...

  8. python 小数保留位数

    利用round(number[, ndigit] )函数四舍五入 保留浮点数的小数点. 如保留小数点后两位. num = 9.2174 new_num = round( num , 2 ) 则new_ ...

  9. 多realm以及jdbcRealm配置

    多realm配置 public class MyRealm1 implements Realm { public String getName() { return "myrealm1&qu ...

  10. Django 2.0 学习(18):Django 缓存、信号和extra

    Django 缓存.信号和extra Django 缓存 由于Django是动态网站,所以每次请求均会去数据库进行相应的操作,当程序访问量大时,耗时必然会显著增加.最简单的解决方法是:使用缓存,缓存将 ...