我基础不好,根据所学的知识,书本的例题修改的,也不知道我理解的是否符合老师要求

运用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将数据存入数据库、读取数据库(运用封装)陈老师作业的更多相关文章

  1. 大数据学习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 ...

  2. pyspider爬取数据存入es--2.测试数据库连通性

    写一个简单案例测试能否将数据写入es #!/usr/bin/env python # -*- encoding: utf-8 -*- # Created on 2017-10-27 08:35:57 ...

  3. pyspider爬取数据存入mysql--2.测试数据库能否连通

    做一个简单的测试,看数据能否存入mysql 1 #!/usr/bin/env python 2 # -*- encoding: utf-8 -*- 3 # Created on 2017-10-26 ...

  4. pyspider爬取数据存入redis--2.测试数据库连通性

    直接上代码 #!/usr/bin/env python # -*- encoding: utf-8 -*- # Created on 2017-10-27 09:56:50 # Project: re ...

  5. 解析xml数据存入bean映射到数据库的 需求解决过程

    解析xml数据存入bean映射到数据库的 需求解决过程2017年12月19日 15:18:57 守望dfdfdf 阅读数:419 标签: xmlbean 更多个人分类: 工作 问题编辑版权声明:本文为 ...

  6. 读取数据库数据,并将数据整合成3D饼图在jsp中显示

    首先我将生成饼图的方法独立写成一个PieChar.java类,详细代码如下:(数据库需要自己建,如有需要的话) import java.io.IOException; import java.sql. ...

  7. 10天学会phpWeChat——第三天:从数据库读取数据到视图

    在第二天,我们创建了我们的第一个phpWeChat功能模块,但是比较简单.实际生产环境中,我们不可能有如此简单的需求.更多的情况是数据存储在MySql数据库中,我们开发功能模块的作用就是将这些数据从M ...

  8. 解决:HTML中多文本域(textarea)回车后数据存入数据库,EL表达式取出异常。

    问题描述: 当多文本域(textarea)回车后数据存入数据库. EL表达式取出异常,值换行倒置页面报错. 问题解决: 存值脚本代码,提交前转换\n为<br/>. <script t ...

  9. 编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时会产生Additional information: 阅读器关闭时尝试调用 Read 无效问题,解决方法与解释

    在自学杨中科老师的视频教学时,拓展编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时 会产生Additional information: 阅读器关闭时尝试调用 ...

随机推荐

  1. JavaScript学习小结(一)——JavaScript入门基础

    一.JavaScript语言特点 1.1.JavaScript是基于对象和事件驱动的(动态的) 它可以直接对用户或客户输入做出响应,无须经过Web服务程序.它对用户的响应,是采用以事件驱动的方式进行的 ...

  2. Windows 和  Linux 下 禁止ping的方法

    Windows 和Linux 下 禁止ping的方法 目的: 禁止网络上的其他主机或服务器ping自己的服务器 运行环境: Windows 03.08  linux 方法: Windows 03下: ...

  3. mac虚拟机parallels 无法启动 "Windows 7" 虚拟机

    关机前在虚拟机上安装了个游戏有点大,第二天开机就使用不了虚拟机了: 提示:mac虚拟机parallels  无法启动 "Windows 7" 虚拟机.  释放至少 241 MB 的 ...

  4. Ubuntu 14.04 安装flash插件

    分别tar.gz和apt-get方法 第一种: adboe官网下载tar.gz,进入terminal 1.解压缩包,输入命令“tar -zxvf 软件包名字” 2.拷贝插件到mozilla目录,输入命 ...

  5. Bootstrap 2.3.2学习

    1.下载架包,下载编译好的文件,文件目录结构如下所示: bootstrap/ ├── css/ │ ├── bootstrap.css │ ├── bootstrap.min.css ├── js/ ...

  6. JDBC基础一

    JDBC:java database connectivity SUN公司提供的一套操作数据库的标准规范. JDBC与数据库驱动的关系:接口与实现的关系. JDBC规范(掌握四个核心对象): Driv ...

  7. 在usercontrol中如何使用验证控件CustomValidator 中的客户端验证

    在用户控件中,为一个文本控件添加CustomValidator验证,然后设置CustomValidator 的ClientValidationFunction 属性为客户端的Validate(sour ...

  8. 使用@media做自适应

    @media (min-width: 768px){ //>=768的设备 }    @media (max-width: 1199){ //<=1199的设备 }

  9. [terry笔记]更改oracle用户名

    更改oracle的用户名 之前有个需求,整理一个schema的表.索引等规划到一个表空间里,利用expdp/impdp然后remap就完成了,但是整理好的用户名remap变更了,应用又不想修改其连接信 ...

  10. Moses更改权重的命令变化 -d -t -

    -l  可以用: weight-l 或者lm  (不需要在前面加-)   还是用-weight-overwrite “Distortion0= 0"更保险 reording weight i ...