最近一直在做网页。用的js比较多,最近需要做一个C#相关的demo,一开始还有点不适应,写了几句有点感觉了

本篇博客的主要内容是C#怎么读取数据库文件里的数据以及相关控件如何绑定数据源,所做的Demo如图所示:

首先在from上将需要控件拖放好,设置属性,连接数据库:

工具--连接到数据库--选择数据源,填写相关数据:

连接数据库之后,在开头引用using System.Data.SqlClient;

编写一个函数,命名为SetCombobox,从数据库内位Combobox绑定数据源,具体的函数如下

      //Combobox绑定数据源
private void SetCombobox()
{
//输入想关联的数据库的基本信息
SqlConnection conn = new SqlConnection(@" server = DESKTOP-5SDB4D4;Initial Catalog= test;User ID=sa;Password=lmz123LMZ");
//打开数据库连接
conn.Open();
//sql语句
string str = " select * from [test].[dbo].[TRaw] where c1 = 0";
//创建命令对象
SqlCommand lo_cmd = conn.CreateCommand();
lo_cmd.CommandText = str;
SqlDataReader dtr = lo_cmd.ExecuteReader();
while (dtr.Read())
{
//邦定数据
comboBox1.Items.AddRange(new object[] { dtr["c3"] });//邦定数据
}
dtr.Close();
comboBox1.SelectedIndex = ;
conn.Close();
}

数据库内不同的法律法规有不同的指代编号,这里写一个dictionary函数,当选中法律条款时返回对应的数据编号

  //法律法规与编号相对应
Dictionary<string, int> laws = new Dictionary<string, int>();

当读取数据库时编写dictionary函数:

  //法律名称
string Lawsname = (string)dtr["c3"];
//法律代码
int number = (int)dtr["c0"]; //向dictionary函数赋值
if (!laws.ContainsKey(Lawsname))
laws.Add(Lawsname, number)
else
Console.WriteLine(Lawsname);

点击启动,完成,法律法规已经在列表中显示,且不同的法律法规对应着不同的数列:

在控件右边添加treeview控件,具体绑定数据库代码如下:

 //对应法律名称的法律编号
int rawid = laws[name];
int id = ;
treeView1.Nodes.Clear(); //输入想关联的数据库的基本信息
SqlConnection conn = new SqlConnection(@"server = DESKTOP-5SDB4D4;Initial Catalog= test;User ID=sa;Password=lmz123LMZ");
conn.Open();
//sql语句
string str = "select * from [test].[dbo].[TRaw] where c4 = 1 and c0 = " + rawid;
//创建命令对象
SqlCommand lo_cmd = conn.CreateCommand();
lo_cmd.CommandText = str;
SqlDataReader dtr = lo_cmd.ExecuteReader(); while (dtr.Read())
{
//父节点的内容
TreeNode node = new TreeNode("第" + NumberToChinese(id) + "条");
treeView1.Nodes.Add(node);
//自动展开
treeView1.ExpandAll();
string Laws1; //法律名称
if ( !dtr.IsDBNull() )
{
Laws1 = (string)dtr["c3"];
}
else
Laws1 = "子条款";
node.Tag = Laws1;
id++; }
dtr.Close();
conn.Close();

编辑nodeMouseClick事件:

 private void treeView1_NodeMouseClick(object sender, TreeNodeMouseClickEventArgs e)
{
label1.Text = e.Node.Tag.ToString();
}

效果如图所示,不同法律名称对应不同的数据量,单机node显示不同的法律条文:

Demo完整代码如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using DevComponents.DotNetBar;
using System.Data.SqlClient; namespace WindowsFormsApp1
{
public partial class Form1 :Form
{
//法律法规与编号相对应
Dictionary<string, int> laws = new Dictionary<string, int>(); public Form1()
{
InitializeComponent();
SetInfo();
SetCombobox();
} //设置属性信息
private void SetInfo()
{
//获取窗体长度
int width = this.Width;
//获取窗体高度
int height = this.Height; //设置panel1的属性
panel1.Height = height / ;
panel1.Top = ;
panel1.Left = ;
panel1.Width = width; //设置panel2的属性
panel2.Height = height - height / ;
panel2.Top = panel1.Height;
panel2.Left = ;
panel2.Width = width / ; //设置panel3的属性
panel3.Height = height - height / ;
panel3.Top = panel1.Height;
panel3.Left = width / ;
panel3.Width = width - width / ; //设置treeView1属性
treeView1.Top = ;
treeView1.Left = ;
treeView1.Width = panel2.Width;
treeView1.Height = panel2.Height;
} //Combobox绑定数据源
private void SetCombobox()
{
//输入想关联的数据库的基本信息
SqlConnection conn = new SqlConnection(@"server = DESKTOP-5SDB4D4;Initial Catalog= test;User ID=sa;Password=lmz123LMZ");
//打开数据库连接
conn.Open();
//sql语句
string str = " select * from [test].[dbo].[TRaw] where c1 = 0";
//创建命令对象
SqlCommand lo_cmd = conn.CreateCommand();
lo_cmd.CommandText = str;
SqlDataReader dtr = lo_cmd.ExecuteReader(); while (dtr.Read())
{
//邦定数据
comboBox1.Items.AddRange(new object[] { dtr["c3"] });//邦定数据
//法律名称
string Lawsname = (string)dtr["c3"];
//法律代码
int number = (int)dtr["c0"]; //向dictionary函数赋值
if (!laws.ContainsKey(Lawsname))
laws.Add(Lawsname, number);
else
Console.WriteLine(Lawsname);
}
dtr.Close();
comboBox1.SelectedIndex = ;
conn.Close();
} //显示具体的法律条款
private void ShowLaw(string name)
{
//对应法律名称的法律编号
int rawid = laws[name];
int id = ;
treeView1.Nodes.Clear(); //输入想关联的数据库的基本信息
SqlConnection conn = new SqlConnection(@"server = DESKTOP-5SDB4D4;Initial Catalog= test;User ID=sa;Password=lmz123LMZ");
conn.Open();
//sql语句
string str = "select * from [test].[dbo].[TRaw] where c4 = 1 and c0 = " + rawid;
//创建命令对象
SqlCommand lo_cmd = conn.CreateCommand();
lo_cmd.CommandText = str;
SqlDataReader dtr = lo_cmd.ExecuteReader(); while (dtr.Read())
{
//父节点的内容
TreeNode node = new TreeNode("第" + NumberToChinese(id) + "条");
treeView1.Nodes.Add(node);
//自动展开
treeView1.ExpandAll();
string Laws1; //法律名称
if ( !dtr.IsDBNull() )
{
Laws1 = (string)dtr["c3"];
}
else
Laws1 = "子条款";
node.Tag = Laws1;
id++; }
dtr.Close();
conn.Close();
} //当选择框发生变化时
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
string name = (string)comboBox1.SelectedItem;
ShowLaw(name);
} //数字转中文
public string NumberToChinese(int number)
{
string res;
string str = number.ToString();
string schar = str.Substring(, );
switch (schar)
{
case "":
res = "一";
break;
case "":
res = "二";
break;
case "":
res = "三";
break;
case "":
res = "四";
break;
case "":
res = "五";
break;
case "":
res = "六";
break;
case "":
res = "七";
break;
case "":
res = "八";
break;
case "":
res = "九";
break;
default:
res = "零";
break;
}
if (str.Length > )
{
switch (str.Length)
{
case :
case :
res += "十";
break;
case :
case :
res += "百";
break;
case :
res += "千";
break;
case :
res += "万";
break;
default:
res += "";
break;
}
res += NumberToChinese(int.Parse(str.Substring(, str.Length - )));
} res = res.Replace("十零", "十").Replace("一十", "十");
return res;
} private void treeView1_NodeMouseClick(object sender, TreeNodeMouseClickEventArgs e)
{
label1.Text = e.Node.Tag.ToString();
} }
}

C#端加载数据库,Combobox与Node控件绑定数据源demo示例的更多相关文章

  1. ComboBox控件绑定数据源后,添加'请选择'或'全部'

    ComboBox控件绑定数据源后,添加'请选择'或'全部' 当使用ComboBox控件绑定数据源之后,通过Items 属性添加的数据是无效的,此时如果要在所有选项前添加 选项 ,则需要考虑从数据源下手 ...

  2. ComboBox控件绑定数据源

    最近在研究机房收费系统的组合查询的方法时,看到了ComboBox控件可以进行数据绑定,我觉得这个功能真的很不错,可以给我省去很多的麻烦. 下面是我组合查询窗体界面 一.数据转换方法 现在我们开看一下我 ...

  3. Winform开发之ComboBox和ComboBoxEdit控件绑定key/value数据

    使用 ComboBox 控件绑定key/value值: 因为 ComboBox 是有 DataSource 属性的,所以它可以直接绑定数据源,如 DataTable.ListItem 等. 使用 Da ...

  4. [MFC] MFC 打开HTML资源(用ID版,也可加载到自己的web控件上)

    @ ^ @:如果是加载到web控件上,就把注释掉的解除注释(改为web控件点后面的函数),把下一句注释 BOOL Button::LoadFromResource(UINT nRes){//打开网页加 ...

  5. ASP.NET中页面加载时文本框(texbox控件)内有文字获得焦点时文字消失

    代码如下: <asp:TextBox ID="TextBox1" runat="server" Height="26px" MaxLe ...

  6. BitmapImage处理网络图片,例如阿里云获取的图片。异步加载到需要显示的控件上。提升速度非常明显。

    想直接把网络图片赋给控件,又要下载又要缓存,速度非常慢.不流畅. 需要进行处理,异步加载会显著提升速度.方法如下: public static BitmapImage ByteArrayToBitma ...

  7. 【WPF学习笔记】之如何点击“新建”按钮,在面板中加载一条条的“用户控件”的信息:动画系列之(四)

    ...... 承接上一系列动画三. 在主界面后台代码设置嵌套第二个用户控件. using System; using System.Collections.Generic; using System. ...

  8. 页面加载通过javascript来修改控件属性

    function changeFormElementStatus(tagNames) {            var tagNameArr = tagNames.split("," ...

  9. ajax验证表单元素规范正确与否 ajax展示加载数据库数据 ajax三级联动

    一.ajax验证表单元素规范正确与否 以用ajax来验证用户名是否被占用为例 1创建表单元素<input type="text" id="t"> 2 ...

随机推荐

  1. GUI常用对象介绍2

    %示意line对象的用法 hf=figure; hl=plot([:]); %示意line对象的属性 get(hl) %设置line的颜色 set(hl,'Color','r'); %设置每个点形状 ...

  2. hud1007 Quoit Design

    #include<algorithm> #include<iostream> #include<cstdlib> #include<cstring> # ...

  3. python smtplib 发送邮件简单介绍

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式python的smtplib提供了一种很 ...

  4. Ford VCM II Ford VCM2 Diagnostic Tool with Ford IDS v108 Installed On Laptop Ready to Use

    HOW to VCM2 Ford VCM II with Ford IDS v108 Work Well? VCM2 Ford VCM2 Ford diagnostic tool hot sale i ...

  5. sparkStreaming插入mysql 必须考虑到实时更新老的key

    原先使用批次提交更新 但数据库无变化,不得不一条一条的插入 公司数据量不大  还未做数据量大的测试 但实时更新是可以的 关键sql : insert into area_user_amt (date, ...

  6. N-Gram的基本原理

    1.N-Gram的介绍 N-Gram是基于一个假设:第n个词出现与前n-1个词相关,而与其他任何词不相关(这也是隐马尔可夫当中的假设).整个句子出现的概率就等于各个词出现的概率乘积.各个词的概率可以通 ...

  7. 每日linux命令学习-head命令和tail命令

    本节主要学习了linux文件浏览的相关命令,包括cat.less.more.read.tail等,由于本人经常使用cat.less.more命令,已经较为熟悉,所以本节重点学习head命令和tail命 ...

  8. 安装ubuntu18.04.1

    下载ubuntu:https://www.ubuntu.com/download/desktop 在虚拟机创建好ubuntu18.04.1后无法启动(选择的是linux,ubuntu64位),提示:此 ...

  9. linux python3 安装scrapy 后提示 -bash: scrapy: 未找到命令

    https://blog.csdn.net/dangsh_/article/details/79613210

  10. android 导出apk

    一个困扰了几个月的问题在今天得以解决,运动益智可能有点过,能让一个人思路清晰倒是真! 问题描述:本地调试运行及不加密导出apk运行正常,当加密生成apk安装后,从接口返回的数据总是空.尝试过各种配置, ...