第20课-数据库开发及ado.net 可空值类型,资料管理器,多条件查询,Case
第20课-数据库开发及ado.net
可空值类型,资料管理器,多条件查询,Case
SqlHelper
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data;
using System.Data.SqlClient;
using System.Text;
namespace _02省市联动
{
public static class SqlHelper
{
//常量 无法修改
private const string A = "aaa";
//readonly 是一个只读的变量,只能在声明或构造函数中修改
//只读变量只能在构造函数或者是一开始声明变量的时候赋值,不允许在其它地方为变量赋值。
//连接字符串
private static readonly string conStr = ConfigurationManager.ConnectionStrings["constr"].ConnectionString;
/// <summary>
/// 封装一个ExecuteNonQuery方法,执行insert、delete、updata
/// </summary>
/// <param name="sql"></param>
/// <param name="pms"></param>
/// <returns></returns>
public static int ExecuteQuery(string sql,params SqlParameter[] pms)
{
using (SqlConnection con=new SqlConnection (conStr))
{
using (SqlCommand com=new SqlCommand (sql,con))
{
if (pms!=null)
{
com.Parameters.AddRange(pms);
}
con.Open();
return com.ExecuteNonQuery();
}
}
}
/// <summary>
/// 封装返回一个单个值的方法
/// </summary>
/// <returns></returns>
public static object ExecuteScalar(string sql,params SqlParameter[] pms)
{
using (SqlConnection con = new SqlConnection(conStr))
{
using (SqlCommand com=new SqlCommand (sql,con))
{
if (pms!=null)
{
com.Parameters.AddRange(pms);
}
con.Open();
return com.ExecuteScalar();
}
}
}
/// <summary>
/// 封装一个返回SqlDataReader的方法
/// </summary>
/// <returns></returns>
public static SqlDataReader ExecuteReader(string sql,params SqlParameter[] pms)
{
SqlConnection con=new SqlConnection (conStr);
using (SqlCommand com=new SqlCommand (sql,con))
{
if (pms!=null)
{
com.Parameters.AddRange(pms);
}
try
{
con.Open();
return com.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
}
catch (Exception)
{
con.Close();
con.Dispose();
throw;
}
}
}
public static DataTable ExecuteDataTable(string sql,params SqlParameter[] pms)
{
DataTable dt = new DataTable();
using (SqlDataAdapter adapter=new SqlDataAdapter (sql,conStr ))
{
//如何添加参数
adapter.Fill(dt);
}
return dt;
}
}
}
省市联动
using System;
using System.Collections.Generic;
using System.Text;
namespace _02省市联动
{
public class ProvinceItem
{
public int AreaId {get ;set;}
public string AreaName{get ;set;}
public int AreaPid{get ;set;}
public override string ToString()
{
return this.AreaName;
}
}
}
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
namespace _02省市联动
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
//加载省份信息到第一个ComboBox
LoadProvince();
//设置俩个下拉菜单的默认值为“请选择”
comboBox1.SelectedIndex = 0;
comboBox2.SelectedIndex = 0;
}
private void LoadProvince()
{
string sql = "select * from TblArea where AreaPId =0";
using (SqlDataReader reader=SqlHelper .ExecuteReader(sql))
{
{
if (reader .HasRows)
while(reader .Read())
{
ProvinceItem item = new ProvinceItem();
item.AreaId = reader.GetInt32(0);
item.AreaName = reader.GetString(1);
item.AreaPid = reader.GetInt32(2);
comboBox1.Items.Add(item);
}
}
}
//为ComboBox 增加一个“请选择”
ProvinceItem itemDefault = new ProvinceItem();
itemDefault.AreaId = -1;
itemDefault.AreaName = "请选择";
comboBox1.Items.Insert(0, itemDefault);
}
/// <summary>
/// 下拉菜单的选择项改变事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void comboBox1_SelectedValueChanged(object sender, EventArgs e)
{
//获取当前用户选择的项
if (comboBox1.SelectedIndex > 0)
{
//加载第二个下来菜单,数据来源:根据第一个下拉菜单用户选项的AeraId来查询该项的所有子项
//获取当前选中项的ID
ProvinceItem item=comboBox1.SelectedItem as ProvinceItem;
int areaId = item.AreaId;
LoadCity(areaId);
}
}
private void LoadCity(int areaId)
{
comboBox2.Items.Clear();
string sql = "select * from TblArea where AreaPId=@aid";
using (SqlDataReader reader = SqlHelper.ExecuteReader(sql, new SqlParameter("@aid", areaId)))
{
if (reader .HasRows )
{
while (reader.Read())
{
ProvinceItem item = new ProvinceItem();
item.AreaId = reader.GetInt32(0);
item.AreaName = reader.GetString(1);
item.AreaPid = reader.GetInt32(2);
comboBox2.Items.Add(item);
}
}
}
//也添加一个“请选择”
ProvinceItem itemDefault = new ProvinceItem();
itemDefault.AreaId = -1;
itemDefault.AreaName = "请选择";
comboBox2.Items.Insert(0, itemDefault);
comboBox2.SelectedIndex = 0;
}
}
}
省市数据递归加载到TreeView
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
namespace _03省市数据递归加载到TreeView
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
////1.把所有的省份及直辖市加载到TreeView的根节点上
//List<Area> listProvince = GetSubItemByParentId(0);
//foreach (Area item in listProvince)
//{
// treeView1.Nodes.Add(item .AreaName );
//}
//递归将省市加载到TreeView中
LoadDataToTree(treeView1.Nodes,0);
}
private void LoadDataToTree(TreeNodeCollection treeNodeCollection, int pid)
{
//1.根据指定的Pid获取该城市下的子城市
List<Area> listCity = GetSubItemByParentId(pid);
//2.遍历将获取到的数据绑定到TreeNodeCollection节点集合中
foreach (var item in listCity )
{
//返回刚刚添加的这个节点
TreeNode node = treeNodeCollection.Add(item.AreaName);
LoadDataToTree(node.Nodes ,item.Areaid);
}
}
//封装一个方法,根据父ID查询下面的所有子项
private List<Area> GetSubItemByParentId(int pid)
{
List<Area> list = new List<Area>();
string sql = "select * from TblArea where areaPid=@pid";
using (SqlDataReader reader = SqlHelper .ExecuteReader (sql,new SqlParameter ("@pid",pid)))
{
if (reader .HasRows )
{
while (reader .Read ())
{
Area model = new Area();
model.Areaid = reader.GetInt32(0);
model.AreaName = reader.GetString(1);
model.AreaPid = reader.GetInt32(2);
list.Add(model);
}
}
}
return list;
}
}
}
using System;
using System.Collections.Generic;
using System.Text;
namespace _03省市数据递归加载到TreeView
{
public class Area
{
public int Areaid { get; set; }
public string AreaName { get; set; }
public int AreaPid { get; set; }
}
}
第20课-数据库开发及ado.net 可空值类型,资料管理器,多条件查询,Case的更多相关文章
- 第19课-数据库开发及ado.net ADO.NET--SQLDataReader使用.SqlProFiler演示.ADoNET连接池,参数化查询.SQLHelper .通过App.Config文件获得连接字符串
第19课-数据库开发及ado.net ADO.NET--SQLDataReader使用.SqlProFiler演示.ADoNET连接池,参数化查询.SQLHelper .通过App.Config文件获 ...
- 第17课-数据库开发及ado.net 聚合函数,模糊查询like,通配符.空值处理.order by排序.分组group by-having.类型转换-cast,Convert.union all; Select 列 into 新表;字符串函数;日期函数
第17课-数据库开发及ado.net 聚合函数,模糊查询like,通配符.空值处理.order by排序.分组group by-having.类型转换-cast,Convert.union all; ...
- 第16课-数据库开发及ado.net-数据库SQl,创建数据库和表,增删改语句,约束,top和Distinct,聚合函数介绍
第16课-数据库开发及ado.net 数据库SQl,创建数据库和表,增删改语句,约束,top和Distinct,聚合函数介绍 SQL语句入门(脚本.命令) SQL全名是结构化查询语言(Structur ...
- 第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据
第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform ...
- 第15课-数据库开发及ado.net-数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库
第15课-数据库开发及ado.net 数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库 1. 学习方法 2. 多涨见识 3. 比自己强的人一起,学习更强:比自己更聪明的人 ...
- 数据库开发及ADO.NET
大部分数据库都需要数据库服务器才能运行. Catalog(分类)又叫做数据库DataBase Table(表)不同类型的东西放到不同的区域中,将这种区域叫做表. 列(Column)字段Field 主键 ...
- SQL从入门到基础 - 01 数据库开发及ADO.Net
一.数据库概述 1. 用自定义文件格式保存数据的劣势:并发性差,查找数据的速度差. 2. DBMS(DataBase Management System数据库管理系统)和数据库.平时谈到“数据库”的含 ...
- .NET混合开发解决方案7 WinForm程序中通过NuGet管理器引用集成WebView2控件
系列目录 [已更新最新开发文章,点击查看详细] WebView2组件支持在WinForm.WPF.WinUI3.Win32应用程序中集成加载Web网页功能应用.本篇主要介绍如何在WinForm ...
- 【Spring】Spring的数据库开发 - 2、Spring JdbcTemplate的常用方法(execute、update、query)
Spring JdbcTemplate的常用方法 文章目录 Spring JdbcTemplate的常用方法 execute() update() query() 简单记录-Java EE企业级应用开 ...
随机推荐
- 省市区三级联动picker-view-微信小程序
这个是微信小程序的picker-view组件,开发的省市区3级联动,体验还不错,就分享给大家了, 此版本的省市区数据为本地JS数据,免去请求加载数据了,大家直接看源码,先看下面的动图: 项目地址: ...
- TaskCreationOptions.LongRunning 运行比可用线程数更多的任务
最近在学WebSocket,服务端需要监听多个WebSocket客户端发送的消息. 开始的解决方法是每个WebSocket客户端都添加一个线程进行监听,代码如下: /// <summary> ...
- 【转】C#如何创建泛型类T的实例
原文地址:https://www.cnblogs.com/lxhbky/p/6020612.html 最近在学历基类的写法时,遇到了一个问题:如何怎么创建一个泛型类T的实例呢? 废话不多说了, ...
- 面向对象总结、configparser配置文件模块、logging日志模块
面向对象总结 # 学习态度# python基础 2个月# html css js jq 1个月 # 上课困 # 学习方法 :# 列出知识点# 例子 写了哪些 # 面向对象学了哪些块# 为什么要讲面向对 ...
- docker容器备份、恢复和迁移volume方案
volume作为数据的载体,在很多情况下需要对其中的数据进行备份.迁移或是恢复.下面一docker容器的volume为例,说一下备份的技巧. 我们先建立一个容器vol_simple,该容器在/date ...
- C#6.0语言规范(十三) 接口
接口定义合同.实现接口的类或结构必须遵守其合同.接口可以从多个基接口继承,并且类或结构可以实现多个接口. 接口可以包含方法,属性,事件和索引器.接口本身不为它定义的成员提供实现.接口仅指定必须由实现接 ...
- Windows + VS2013 + Dlib
Dlib是一个机器学习的C++库,包含了许多机器学习常用的算法, 而且文档和例子都非常详细. 安装有点类似于opencv,这里我从官网下载dlib-18.17到D盘 1. cmake转VS工程 这里使 ...
- MySQL查询50例
创建表和关系 /* 创建表 */ /*年级表*/ DROP TABLE IF EXISTS `class_grade`; CREATE TABLE `class_grade` ( `gid` int( ...
- es 修改拼音分词器源码实现汉字/拼音/简拼混合搜索时同音字不匹配
[版权声明]:本文章由danvid发布于http://danvid.cnblogs.com/,如需转载或部分使用请注明出处 在业务中经常会用到拼音匹配查询,大家都会用到拼音分词器,但是拼音分词器匹配的 ...
- String不得不说的那些事
一.String.StringBuilder和StringBuffer的区别 1. String是字符串常量,StringBuilder和StringBuffer是字符串变量 String对象创建完成 ...