运用.NIT将数据存入数据库、读取数据库(运用封装)陈老师作业
我基础不好,根据所学的知识,书本的例题修改的,也不知道我理解的是否符合老师要求
运用C#将数据存入数据库、并且可以读取数据库里的数据,此项目我运用了封装。我运用了一个窗体将数据存读数据。
我首先创建了一个数据库,库名“数学题库” ,然后创建了一个表“tiku1”,

添加一个类Class1
class Class1
{
public string strCon = @"Data Source=.;Initial Catalog=数学题库;Integrated security=true";
public SqlConnection sqlcon = new SqlConnection();
public SqlDataAdapter sda = new SqlDataAdapter();
public DataSet ds = new DataSet();
public DataTable dt = new DataTable();
public SqlDataReader sdr;
public void suanshu()
{
try
{
sqlcon = new SqlConnection(strCon);
}
catch (Exception e)
{
MessageBox.Show("数据库连接不成功:" + e.ToString());
}
}
public void suanFill(string selstr)
{
dt.Clear();
sda = new SqlDataAdapter(selstr, strCon);
sda.Fill(ds,"tiku1");
dt = ds.Tables["tiku1"];
}
public void suanselect(string showtnfo)
{
sqlcon.Open();
SqlCommand sqlcmd = new SqlCommand(showtnfo, sqlcon);
sdr = sqlcmd.ExecuteReader();
}
public void suanInsert(string insertinfo)
{
sqlcon.Open();
SqlCommand sqlcmd = new SqlCommand(insertinfo, sqlcon);
try
{
sqlcmd.ExecuteNonQuery();
}
catch (Exception e)
{
MessageBox.Show("数据插入失败:" + e.ToString());
}
sqlcon.Close();
}
public void suanGridViewUpd()
{
SqlCommandBuilder scb = new SqlCommandBuilder(sda);
DialogResult result;
result = MessageBox.Show("确定保存修改过的数据吗?", "操作提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
if (result == DialogResult.OK)
{
dt = ds.Tables["tuku1"];
sda.Update(dt);
dt.AcceptChanges();
}
}
public void suanDelete(string delStr)
{
sqlcon.Open();
SqlCommand sqlcmd = new SqlCommand(delStr, sqlcon);
try
{
sqlcmd.ExecuteNonQuery();
MessageBox.Show("数据删除成功!");
}
catch (Exception ex)
{
MessageBox.Show("数据删除失败" + ex.ToString());
}
sqlcon.Close();
}
}
}
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
string selstr = @"select * from tiku1 ";
Class1 db = new Class1();
private void Form1_Load(object sender, EventArgs e)
{
db.suanshu();
db.suanFill(selstr);
comboBox1.ValueMember = "序号";
comboBox1.DataSource = db.dt.DefaultView;
}
private void button4_Click(object sender, EventArgs e)
{
db.suanshu();
db.suanFill(selstr);
dataGridView1.DataSource = db.dt;
}
private void button1_Click(object sender, EventArgs e)
{
db.suanshu();
string insertinfo = "insert into tiku1(序号,第一个数,符号一,第二个数,符号二,第三个数,符号三,结果) values('" + comboBox1.Text + "','" + textBox1.Text +
"','" + textBox2.Text +
"','" + textBox3.Text + "','" + textBox4.Text + "','" + textBox5.Text + "','" + textBox6.Text +
"','" + textBox7.Text +
"')";
db.suanInsert(insertinfo);
db.suanFill(selstr);
dataGridView1.DataSource = db.dt;
}
private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
{
string selinfo = "select 第一个数,符号一,第二个数,符号二,第三个数,符号三,结果 from tiku1 where 序号='" + comboBox1.Text.ToString().Trim() + "'";
db.suanshu();
db.suanselect(selinfo);
while (db.sdr.Read())
{
textBox1.Text = db.sdr["第一个数"].ToString();
textBox2.Text = db.sdr["符号一"].ToString();
textBox3.Text = db.sdr["第二个数"].ToString();
textBox4.Text = db.sdr["符号二"].ToString();
textBox5.Text = db.sdr["第三个数"].ToString();
textBox6.Text = db.sdr["符号三"].ToString();
textBox7.Text = db.sdr["结果"].ToString();
}
db.sdr.Close();
}
private void button3_Click(object sender, EventArgs e)
{
db.suanshu();
string strupd = "delete from tiku1 where 序号='" + comboBox1.Text.Trim() + "'";
db.suanDelete(strupd);
db.suanFill(selstr);
dataGridView1.DataSource = db.dt;
}
private void button2_Click(object sender, EventArgs e)
{
db.suanshu();
db.suanGridViewUpd();
}
}
}

说明
每道题我都编辑了序号,可以根据序号选题,改题,(序号我设置了下拉列表)
1、点击查询可以查询数据库里表里数据
2、点击添加可以添加数据
3、删除数据,更新数据
运用.NIT将数据存入数据库、读取数据库(运用封装)陈老师作业的更多相关文章
- 大数据学习day25------spark08-----1. 读取数据库的形式创建DataFrame 2. Parquet格式的数据源 3. Orc格式的数据源 4.spark_sql整合hive 5.在IDEA中编写spark程序(用来操作hive) 6. SQL风格和DSL风格以及RDD的形式计算连续登陆三天的用户
1. 读取数据库的形式创建DataFrame DataFrameFromJDBC object DataFrameFromJDBC { def main(args: Array[String]): U ...
- pyspider爬取数据存入es--2.测试数据库连通性
写一个简单案例测试能否将数据写入es #!/usr/bin/env python # -*- encoding: utf-8 -*- # Created on 2017-10-27 08:35:57 ...
- pyspider爬取数据存入mysql--2.测试数据库能否连通
做一个简单的测试,看数据能否存入mysql 1 #!/usr/bin/env python 2 # -*- encoding: utf-8 -*- 3 # Created on 2017-10-26 ...
- pyspider爬取数据存入redis--2.测试数据库连通性
直接上代码 #!/usr/bin/env python # -*- encoding: utf-8 -*- # Created on 2017-10-27 09:56:50 # Project: re ...
- 解析xml数据存入bean映射到数据库的 需求解决过程
解析xml数据存入bean映射到数据库的 需求解决过程2017年12月19日 15:18:57 守望dfdfdf 阅读数:419 标签: xmlbean 更多个人分类: 工作 问题编辑版权声明:本文为 ...
- 读取数据库数据,并将数据整合成3D饼图在jsp中显示
首先我将生成饼图的方法独立写成一个PieChar.java类,详细代码如下:(数据库需要自己建,如有需要的话) import java.io.IOException; import java.sql. ...
- 10天学会phpWeChat——第三天:从数据库读取数据到视图
在第二天,我们创建了我们的第一个phpWeChat功能模块,但是比较简单.实际生产环境中,我们不可能有如此简单的需求.更多的情况是数据存储在MySql数据库中,我们开发功能模块的作用就是将这些数据从M ...
- 解决:HTML中多文本域(textarea)回车后数据存入数据库,EL表达式取出异常。
问题描述: 当多文本域(textarea)回车后数据存入数据库. EL表达式取出异常,值换行倒置页面报错. 问题解决: 存值脚本代码,提交前转换\n为<br/>. <script t ...
- 编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时会产生Additional information: 阅读器关闭时尝试调用 Read 无效问题,解决方法与解释
在自学杨中科老师的视频教学时,拓展编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时 会产生Additional information: 阅读器关闭时尝试调用 ...
随机推荐
- 分布式MySQL集群方案的探索与思考
转载:http://www.infoq.com/cn/articles/exploration-of-distributed-mysql-cluster-scheme?utm_campaign=rig ...
- 【译】Spark官方文档——Spark Configuration(Spark配置)
注重版权,尊重他人劳动 转帖注明原文地址:http://www.cnblogs.com/vincent-hv/p/3316502.html Spark主要提供三种位置配置系统: 环境变量:用来启动 ...
- Spark官方文档——独立集群模式(Standalone Mode)
除了部署在Mesos之上, Spark也支持独立部署模式,包括一个Spark master进程和多个 Spark worker进程.独立部署模式可以运行在单机上作为测试之用,也可以部署在集群上.如果你 ...
- [.ashx檔?泛型处理例程?]基础入门#1....能否用中文教会我?别说火星文?
原文出處 http://www.dotblogs.com.tw/mis2000lab/archive/2013/08/20/ashx_beginner_01.aspx [.ashx檔?泛型处理例程? ...
- Oracle 11gR2 RAC修改SCAN IP
一.查看当前环境: # grid用户 检查scan-ip地址的配置 [grid@node1 ~]$ srvctl config scan SCAN name: scan-cluster.com, Ne ...
- .NET设计模式系列文章 from TerryLee
http://www.cnblogs.com/Terrylee/archive/2006/07/17/334911.html 最初写探索设计模式系列的时候,我只是想把它作为自己学习设计模式的读书笔记来 ...
- Python生成器以及yield语句
生成器是一种暂缓求值的技术,它可以用来生成一系列的值,但不会一次性生成所有的值,而只在需要的时候才计算和生成一个值. 通过yield语句构建生成器 要得到一个生成器,我们需要定义一个函数,这个函数返回 ...
- 从0 开始 WPF MVVM 企业级框架实现与说明 ---- 第四讲 WPF中 ControlTemplate
上讲我们介绍了DataTemplate,现在我们就介绍下ControlTemplate,可能后面大多在编码时候会出现一些英文,工作习惯,请见谅. ControlTemplate: 控件的外观,也就是控 ...
- AsyncTask和Handler两种异步方式的实现和区别比较
1 AsyncTask实现的原理,和适用的优缺点 AsyncTask,是android提供的轻量级的异步类,可以直接继承AsyncTask,在类中实现异步操作,并提供接口反馈当前异步执行的程度(可以 ...
- 我爱我家:我为什么选择AppCan?
10年前,说起手机,大家联想到的词大概是:电话.短信.QQ.拍照,以及贪吃蛇等有限的几个小游戏.而如今,手机毫无疑问已经成为人们生活中不可或缺的部分.这是一个神奇的东西:通讯工具,外卖神器,游戏机,移 ...