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的更多相关文章

  1. 第19课-数据库开发及ado.net ADO.NET--SQLDataReader使用.SqlProFiler演示.ADoNET连接池,参数化查询.SQLHelper .通过App.Config文件获得连接字符串

    第19课-数据库开发及ado.net ADO.NET--SQLDataReader使用.SqlProFiler演示.ADoNET连接池,参数化查询.SQLHelper .通过App.Config文件获 ...

  2. 第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;  ...

  3. 第16课-数据库开发及ado.net-数据库SQl,创建数据库和表,增删改语句,约束,top和Distinct,聚合函数介绍

    第16课-数据库开发及ado.net 数据库SQl,创建数据库和表,增删改语句,约束,top和Distinct,聚合函数介绍 SQL语句入门(脚本.命令) SQL全名是结构化查询语言(Structur ...

  4. 第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据

    第18课-数据库开发及ado.net 连接数据库.增.删.改向表中插入数据并且返回自动编号.SQLDataReade读取数据 ADO.NET 为什么要学习? 我们要搭建一个平台(Web/Winform ...

  5. 第15课-数据库开发及ado.net-数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库

    第15课-数据库开发及ado.net 数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库 1.  学习方法 2.  多涨见识 3.  比自己强的人一起,学习更强:比自己更聪明的人 ...

  6. 数据库开发及ADO.NET

    大部分数据库都需要数据库服务器才能运行. Catalog(分类)又叫做数据库DataBase Table(表)不同类型的东西放到不同的区域中,将这种区域叫做表. 列(Column)字段Field 主键 ...

  7. SQL从入门到基础 - 01 数据库开发及ADO.Net

    一.数据库概述 1. 用自定义文件格式保存数据的劣势:并发性差,查找数据的速度差. 2. DBMS(DataBase Management System数据库管理系统)和数据库.平时谈到“数据库”的含 ...

  8. .NET混合开发解决方案7 WinForm程序中通过NuGet管理器引用集成WebView2控件

    系列目录     [已更新最新开发文章,点击查看详细] WebView2组件支持在WinForm.WPF.WinUI3.Win32应用程序中集成加载Web网页功能应用.本篇主要介绍如何在WinForm ...

  9. 【Spring】Spring的数据库开发 - 2、Spring JdbcTemplate的常用方法(execute、update、query)

    Spring JdbcTemplate的常用方法 文章目录 Spring JdbcTemplate的常用方法 execute() update() query() 简单记录-Java EE企业级应用开 ...

随机推荐

  1. JS通过ClassName禁止DIV点击

    //通过ClassName获取div,使用setAttribute设置div禁止点击 var itemRoom= document.getElementsByClassName("page- ...

  2. wpf Listbox 实现按住ctrl键来取消选中

    1. 首先继承一个listbox,来获得按住ctrl键时,点击的item public class ListBoxEx : ListBox { public BeatTemplateWave GetA ...

  3. IE浏览器兼容性模式

    最近支持公司的一个内部业务管理系统,系统是基于jQuery来实现:用了2年的MVVM框架的我转向这个完全使用jQuery框架来开发的系统,真是相当不爽(相信用过MVVM框架的跟我是相同的感受):更为憋 ...

  4. 【CF600E】 Lomsat gelral

    CF600E Lomsat gelral Solution 考虑一下子树的问题,我们可以把一棵树的dfn序搞出来,那么子树就是序列上的一段连续的区间. 然后就可以莫队飞速求解了. 但是这题还有\(\T ...

  5. 用开源 ASP.NET MVC 程序 Bonobo Git Server 搭建 Git 服务器(转)

    用开源 ASP.NET MVC 程序 Bonobo Git Server 搭建 Git 服务器   现在不用Git,都不好意思说自己是程序员. 当你想用Git,而源代码服务器是Windows系统时,你 ...

  6. [原创]K8飞刀20150720 新增Shellcode Loader支持多种格式

    工具: K8飞刀编译: 自己查壳组织: K8搞基大队[K8team]作者: K8拉登哥哥博客: http://qqhack8.blog.163.com发布: 2015/7/20 3:00:18 简介: ...

  7. Dell R730服务器 Raid5配置

    Dell R730服务器,有7块5t硬盘,默认做的RAID5.我们的目的是取其中6块硬盘做RAID5,留一块硬盘做热备. 一块SSD系统盘. 在这里,我具体解释一下 ①6块硬盘做成RAID5 ②6块硬 ...

  8. android屏幕密度规律及dp px转换

    px和dp(sp) 之间转化公式: 1  乘以(dp转px)或者除以(px转dp) scal缩放因子,在上浮0.5f /** * 密度转换像素 * */ public static int dip2p ...

  9. expr命令总结

    expr在linux中是一个功能非常强大的命令.通过学习做一个小小的总结.1.计算字符串的长度.我们可以用awk中的length(s)进行计算.我们也可以用echo中的echo ${#string}进 ...

  10. Composite组合模式(结构型模式)

    1.概述 在面向对象系统中,经常会遇到一些具有"容器性质"的对象,它们自己在充当容器的同时,也充当其他对象的容器. 2.案例 需要构建一个容器系统,需要满足以下几点要求: (1). ...