最近一直在做网页。用的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. hashcat使用命令简介

    1.指定HASH类型 在HashCat中--hash-type ?参数可以指定要破解的HASH类型,运行hashcat主程序加上--help参数,在* Generic hash types:中可以看到 ...

  2. 怎样从外网访问内网Oracle数据库?

    本地安装了一个Oracle数据库,只能在局域网内访问到,怎样从外网也能访问到本地的Oracle数据库呢?本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Oracle数据库 默认安装的Or ...

  3. imageio.ffmpeg.download() has been deprecated. Use 'pip install im ageio-ffmpeg' instead.'

    Use this instead: sudo pip3 install imageio==2.4.1

  4. linux centos6.8搭建 jdk 环境

    1. 上官网下载jdk1.8的包 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html ...

  5. oracle 11g禁用和强制direct path read

    一般在混合型环境中,大表在进行全表扫描或者走并行的时候一般会出现direct path read等待事件,如果在OLTP或者纯粹的DSS环境中,出现大量的direct path read直接路径读取, ...

  6. SaaS的中年危机(转)

    如果说SaaS软件和人有什么地方很像的话,中年危机一定是其中一个.另一个是交税. 经常有人问我,春阳,你觉得xx SaaS公司怎么样? 如果这是一家成立2年以上的公司,我的回答多半是“活的不是那么滋润 ...

  7. 【题解】bzoj 4327 JSOI2012 玄武密码

    原题传送门 我们先对所有询问串建立AC自动机(今天洛咕上有人分不清AC自动机和自动AC机) 然后将母串在AC自动机上跑,每走到一个点x,从x点出发沿着fail指针所能到的所有前缀都是匹配成功的,暴力向 ...

  8. windows模糊查询指定进程是否存在

    习惯的查询 wmic process | findStr /i "**" /i 忽略大小写 我查考的链接 常用批处理命令总结3之Find和FindStr

  9. 20145212罗天晨 WEB基础实践

    实验问题回答 1.什么是表单 表单在网页中主要负责数据采集功能 一个表单有三个基本组成部分: 表单标签 表单域:包含了文本框.密码框.隐藏域.多行文本框.复选框.单选框.下拉选择框和文件上传框等 表单 ...

  10. Matlab绘制三维曲面(以二维高斯函数为例)

    原文地址为:Matlab绘制三维曲面(以二维高斯函数为例) 寒假学习了一下Python下的NumPy和pymatlab,感觉不是很容易上手.来学校之后,决定继续看完数字图像处理一书.还是想按照上学期的 ...