使用sqlhelper的简单增删改查
一:所说的简单的三层构架,就是说没有业务逻辑层,将各层没有放到单独的项目中,解决方案如下:

二:form1.cs的详细代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms; namespace product
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
/// <summary>
/// 插入一条数据
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button1_Click(object sender, EventArgs e)
{
product p= new product(); p.Name="红马車";
//p.Number=50;
// p.Price=5165;
p.C_id = ;
productDAL.insertInfor(p); }
/// <summary>
/// 获得所有信息的总条数
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button2_Click(object sender, EventArgs e)
{
int result= productDAL.getInforNum();
MessageBox.Show(result.ToString());
}
/// <summary>
/// 删除指定id的一条数据
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button3_Click(object sender, EventArgs e)
{
productDAL.delectInfor();
}
/// <summary>
/// 查询指定id的这条信息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button4_Click(object sender, EventArgs e)
{
product p = new product();
p= productDAL.getInfor();
MessageBox.Show(p.C_id+p.Name+p.Number); }
}
}
三:product.cs的详细代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace product
{
public class product
{
public int Id {get;set; }
public string Name{get;set;}
public decimal? Price{get;set;}//decimal数据库中,对应vs里的decimal
public int? Number{get;set;}
public int C_id{set;get;} }
}
四:productDAL.cs的详细代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;
using System.Data;
using System.Windows.Forms; namespace product
{
public static class productDAL
{
/// <summary>
/// 方法:将vs里的可空类型转换为数据库认识的可空类型
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
static object toDbValue(object value)
{
if (value == null)
return DBNull.Value;//数据库的空值类型
else
return value;
}
/// <summary>
/// 方法:将数据库的可空类型转换为vs认识的可空类型
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
static object fromDbValue(object value)
{
if (value == DBNull.Value)
return null;//vs里的空值类型
else
return value;
}
/// <summary>
/// 增加一条数据
/// </summary>
public static void insertInfor(product produ)
{
sqlhelper.ExecuteNon(@"insert into product(name,price,number,c_id)values(@name,@price,@number,@c_id)",
new SqlParameter("@name",produ.Name),
new SqlParameter("@price",toDbValue( produ.Price)),
new SqlParameter("@number",toDbValue( produ.Number)),
new SqlParameter("@c_id", produ.C_id));//添加用values,不用value.(@"insert into product(name,price,number,c_id)values(@name,@price,@number,@c_id)"加上@能识别换行符和空格,增加了字符串的长度 }
/// <summary>
/// 返回信息的总条数
/// </summary>
/// <returns></returns>
public static int getInforNum()
{
//int result = sqlhelper.ExecuteNon("select * from product" );
//select * from product和select count(*) from product都是没有受影响的行数
//select count(*) from product用数据库查询就是一个行数,所以返回首行首列就可以了
int result = sqlhelper.ExecuteSca("select count(*) from product");//这里本来是两个参数,那个长度可变参数可以不赋值
return result;
}
/// <summary>
/// 删除指定id的这条数据
/// </summary>
/// <param name="id"></param>
public static void delectInfor(int id)
{
sqlhelper.ExecuteNon("delete product where id=@id",
new SqlParameter("@id",id));//delete,不要写成delect }
/// <summary>
/// 查询指定id的这条数据
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public static product getInfor(int id)
{
DataTable table= sqlhelper.datatable("select * from product where id=@id",
new SqlParameter("@id",id)); if (table.Rows.Count <= )
return null;//没有找到这个id的数据,返回null
else if (table.Rows.Count > )
throw new Exception("id重复了");
else
{
product pro = new product();
DataRow row = table.Rows[]; pro.Name = (string)row["name"];
pro.Price = (decimal?)fromDbValue(row["price"]);//表里是可空类型的用double?
pro.Number = (int?)fromDbValue(row["number"]);
pro.C_id = (int)row["c_id"];
return pro;
} }
}
}
五:sqlhelper.cs的详细代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.SqlClient;
using System.Configuration; namespace product
{
public static class sqlhelper
{
static SqlConnection conn;
static SqlCommand cmd;
/// <summary>
/// 返回受影响的行数
/// </summary>
private readonly static string constr = ConfigurationManager.ConnectionStrings["constr"].ConnectionString;
public static int ExecuteNon(string sql,params SqlParameter[] parameter )
{
using (conn = new SqlConnection(constr))
{
conn.Open();
using (cmd = conn.CreateCommand())
{
cmd.CommandText = sql;
cmd.Parameters.AddRange(parameter);
int result = cmd.ExecuteNonQuery();
return result; }
} } /// <summary>
///返回结果的首行首列
/// </summary>
/// <param name="sql"></param>
/// <param name="parameter"></param>
/// <returns></returns>
public static int ExecuteSca(string sql, params SqlParameter[] parameter)
{
using (conn = new SqlConnection(constr))
{
conn.Open();
using (cmd = conn.CreateCommand())
{
cmd.CommandText = sql;
cmd.Parameters.AddRange(parameter);
int result = (int) cmd.ExecuteScalar();
return result;
}
}
} /// <summary>
/// 返回一个数据流
/// </summary>
/// <param name="sql"></param>
/// <param name="parameter"></param>
/// <returns></returns>
public static object SqldataRea(string sql, params SqlParameter[] parameter)
{
using (conn = new SqlConnection(constr))
{
conn.Open();
using (cmd = conn.CreateCommand())
{
cmd.CommandText = sql;
cmd.Parameters.AddRange(parameter);
SqlDataReader sdr= sdr=cmd.ExecuteReader(); return sdr;
}
}
} /// <summary>
/// 返回一个表
/// </summary>
/// <param name="sql"></param>
/// <param name="parameter"></param>
/// <returns></returns>
public static DataTable datatable(string sql, params SqlParameter[] parameter)
{
using (conn = new SqlConnection(constr))
{
conn.Open();
using (cmd = conn.CreateCommand())
{
cmd.CommandText = sql;
cmd.Parameters.AddRange(parameter);
SqlDataAdapter sda = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
sda.Fill(ds);
return ds.Tables[];
}
}
}
}
}
使用sqlhelper的简单增删改查的更多相关文章
- ado.net的简单数据库操作(三)——简单增删改查的实际应用
果然,在犯困的时候就该写写博客,写博客就不困了,哈哈! 上篇我记录了自己的SqlHelper的开发过程,今天记录一下如何使用这个sqlhelper书写一个具有简单增删改查的小实例啦. 实例描述:在数据 ...
- Redis:五种数据类型的简单增删改查
Redis简单增删改查例子 例一:字符串的增删改查 #增加一个key为ay_key的值 127.0.0.1:6379> set ay_key "ay" OK #查询ay_ke ...
- 国产化之路-统信UOS + Nginx + Asp.Net MVC + EF Core 3.1 + 达梦DM8实现简单增删改查操作
专题目录 国产化之路-统信UOS操作系统安装 国产化之路-国产操作系统安装.net core 3.1 sdk 国产化之路-安装WEB服务器 国产化之路-安装达梦DM8数据库 国产化之路-统信UOS + ...
- Mybatis实现简单增删改查
Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...
- Android_ADB 常用 shell命令 和 sqlite3 简单增删改查
今天学习了一个ADB的常用命令.接下来简单使用几个常用ADB shell 命令. 首先我们得明白什么是adb.exe ADB -Android Debug Bridge, 是 Android sdk ...
- sqlhelper sqlparameter 实现增删改查
这是sqlHelper.cs类,类内里封装了方法 using System; using System.Collections.Generic; using System.Linq; using Sy ...
- MyBatis之二:简单增删改查
这一篇在上一篇的基础上简单讲解如何进行增删改查操作. 一.在mybatis的配置文件conf.xml中注册xml与注解映射 <!-- 注册映射文件 --> <mappers> ...
- 基于springmvc的简单增删改查实现---中间使用到了bean validation
package com.kite.controller; import java.util.HashMap; import java.util.Map; import javax.validation ...
- JDBC实现简单增删改查
JDBC全称为:Java Data Base Connectivity (java数据库连接),主要用于java与数据库的链接. 整个链接过程如下图: 1.数据库驱动:Driver 加载mysql驱动 ...
随机推荐
- 为当前的div 动态添加一个样式
$("#target").addClass("newClass");
- ArcGIS 设置地图显示范围大小
Arcmap的FullExtent默认是地图加载的时候的extent.其实这个fullExtent是可以设置的. 打开ArcMap,选择左边图例的Layers ,右键点击,选择“Properties. ...
- [PDF] PDFOperation--C#PDF文件操作帮助类 (转载)
点击下载 PDFOperation.rar 这个类是关于PDFOperation的帮助类,主要是实现C#PDF的文件操作,具体实现功能如下1.构造函数2.私有字段3.设置字体4.设置页面大小5.实例化 ...
- 一个少了context的赋值的错误
错误类型如下,怎么也找不到错误,后来仔细看了源代码,原来忘了context的赋值,只是声明,声明后不马上引用到值容易出事. 11-12 15:00:09.877: E/AndroidRuntime(6 ...
- windows 8 vpn 错误解决
最近微软发布了Windows 8 RTM版,很多朋友也安装了,我当然也不例外.这几天就有不少朋友问我VPN连接无论怎么都说密码错误不能验证,于是,便连接VPN进行了下测试,如下: 配置好VPN,步凑不 ...
- Jsoup解析Html教程
Jsoup应该说是最简单快速的Html解析程序了,完善的API以及与JS类似的操作方式,为Java的Html解析带来极大的方便,结合多线程适合做一些网络数据的抓取,本文从一下几个方面介绍一下,篇幅有限 ...
- [Twisted] Protocols协议和Protocol Factories 协议工厂
Protocols 描述了如何异步处理网络事件.Twisted维护了许多协议的实现,如HTTP,Telent,DNS,IMAP.Portocols实现了IProtocol接口, IProtocol包含 ...
- windows8一直更新不了的问题————解决方案
以下是微软官方工程师的详细解答: 尊敬的佐先生: 您好! 感谢您联系微软技术支持!我是微软技术支持工程师,我姓张.我将协助您解决有关问题.您的问题编号是SRX 1274238225 对于您当前的更新问 ...
- Net常用资源小集
Visual Studio——IDEs工具之王,.NET开发者的必备IDE.Visual Studio提供非常强大的启动工具箱,并且还有一些让人惊喜的插件支持.在去年,微软发布了Visual Stud ...
- [Neural Networks] Momentum
一.目的 加快参数的收敛速度. 二.做法 另第t次的权重更新对第t+1次的权重更新造成影响. 从上式可看出,加入momentum后能够保持权重的更新方向,同时加快收敛.通常alpha的取值为[0.7, ...