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. UWP 使用Windows Community Toolkit 的OneDrive service上传下载文件

    上一年年底写过两篇文章 UWP 使用OneDrive云存储2.x api(一)[全网首发] UWP 使用OneDrive云存储2.x api(二)[全网首发] 没想到半年之后,VS编译提示方法已经过时 ...

  2. ASP.NET CORE之上传文件夹

    最近闲余时间在做一个仿百度网盘的项目,其中就有一个上传文件夹的功能.查了下网上好像对这个问题的描述比较少,所以在此记录一下. 1.网上找来找去发现webkitdirectory这个东西,H5的一个新的 ...

  3. 201621123018《Java程序设计》第7周学习报告

    1. 本周学习总结 1.1 思维导图:Java图形界面总结 2.书面作业 1. GUI中的事件处理 1.1 写出事件处理模型中最重要的几个关键词. 事件.事件源. 事件监听器.事件处理方法 1.2 任 ...

  4. docker容器备份、恢复和迁移volume方案

    volume作为数据的载体,在很多情况下需要对其中的数据进行备份.迁移或是恢复.下面一docker容器的volume为例,说一下备份的技巧. 我们先建立一个容器vol_simple,该容器在/date ...

  5. 关于IE9 table显示错位的问题

    首先,win10无法安装IE9,所以需要用IE11模拟IE9,这样:http://www.w10zj.com/Win10xy/Win10yh_638.html: 其次,table显示错位的可能原因:h ...

  6. 实现域名访问网站—nginx反向代理

    今天在跟项目的时候,是否被耍了三个多小时,最后在我准备号材料准备他人求助的时候,在收集材料的时候,居然访问通了, 别问我为什么,我也不知道 ,哈哈哈哈(苦逼脸...) 分享出来,大家共同学习: 这个是 ...

  7. Lucene使用案例

    Lucene是apache软件基金会4 jakarta项目组的一个子项目,是一个开放源代码的全文检索引擎工具包,但它不是一个完整的全文检索引擎,而是一个全文检索引擎的架构,提供了完整的查询引擎和索引引 ...

  8. python互斥锁

    互斥锁 进程之间数据隔离, 但是多个进程可以共享同一块数据,比如共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的,而共享带来的是竞争,竞争带来的结果就是错乱,如下 from mu ...

  9. vue教程1-07 模板和过滤器

    vue教程1-07 模板和过滤器 一.模板 {{msg}} 数据更新模板变化 {{*msg}} 数据只绑定一次 {{{msg}}} HTML转意输出 <!DOCTYPE html> < ...

  10. odoo开发笔记 -- odoo源码解析

    odoo 源码解析:http://blog.csdn.net/weixin_35737303