首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C#学习之路(1)--数据库技术

前言 在7月10日就要去扬州实习了,首先是为期2个月的培训。一个月的Java,一个月的C#。在这一个月里面,准备梳理一下java和C#的基础知识,同时也进行更深一步的学习。...---- 创建一个ADO.NET数据库应用程序一般步骤 创建Windows窗体。 创建Connection对象,连接数据库。创建Command对象,执行SQL命令。...创建DataAdapter对象,提供数据源与记录集之间的数据交换,数据库与内存中的数据交换。 创建DataSet对象,将从数据源中得到的数据保存在内存中,然后对数据进行相关的各种操作。...adapter = new SqlDataAdapter(s, conn); 创建SqlCommandBuilder对象 创建这个对象,需要传入SqlDataAdapter的对象。...如果没有这个对象,SqlDataAdapter对象调用Update()方法会报一个异常:System.InvalidOperationException: 当传递具有已修改行的 DataRow 集合时,

2K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql5.7 创建新表时提示时间戳非法

    # 背景 mysql版本5.7.8,需要创建新表,研发提供的sql文件,执行后报错如下: ERROR 1067 (42000): Invalid default value for 'deleted_at...' 就猜测到时因为5.7版本的mysql默认的时间戳不允许输入0000-00-00 00:00:00这种格式,之前碰到过类似问题,需要修改配置 查看了研发提供的sql文件,果真如此: ‘create_at...不希望修改配置文件,通过修改sql_model就可以了的,这种对新建表生效 SELECT @@sql_mode; 可查看sql_model,其中NO_ZERO_IN_DATE,NO_ZERO_DATE就是导致...5.7+版本无法输入0的时间戳 NO_ZERO_IN_DATE:在严格模式下,不允许日期和月份为零  NO_ZERO_DATE:设置该值,mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告...执行原来的sql文件,成功

    1.5K60

    C# 实现时间来到新的一天时触发事件

    C# 实现时间来到新的一天时触发事 独立观察员 2023 年 12 月 19 日 看到知乎有人提问《C# 如果要实现一个任务每天 0 点执行,用什么方法等待更高效?》...,回想起之前写过的一个方法,现在翻出来大家讨论讨论。 新建一个时间事件帮助类(单例),通过定时器,到第二天 0 点后触发 [新的一天] 事件,使用的地方订阅这个事件即可。...instance = new TimeEventHelper(); } #endregion #region 成员 /// /// [新的一天...实现时间来到新的一天时触发事件](https://dlgcy.com/csharp-new-day-event/) C# C# 字符串排序时指定偏好的排列顺序 对于 C# 中 Task 的 StartNew...C#10 新特性 [调用方参数表达式] 解决了我七年前的困惑 【分享】C# 字节帮助类 ByteHelper C# 在自定义的控制台输出重定向类中整合调用方信息 C# 枚举转列表 .NET Windows

    32310

    C# 数据操作系列 - 3. ADO.NET 离线查询

    在查询这一高频需求上,C#为之做了很多工作,提供了更多的选择。这里介绍一个查询的另一套写法。 ? 1....Rows { get; }//获取属于该表的行的集合 又出现了两个新的类:DataColumnCollection、DataRowCollection。...那么我们看看如何进行一个离线查询吧 2.实践看看 以SQL Server数据库为例: 获取一个SqlDataAdapter,C#提供了四种方式获取: public SqlDataAdapter ();/...(sql, connectStr); 然后创建一个用于保存数据的DataSet,并把数据填充进去: DataSet set = new DataSet(); adapter.Fill(set); 然后可以看到这个...上图是在VS中的调试模式中,可以看到 根据上图我们大概可以猜测一下DataTable内部的数据结构,或者C#让我们理解的结构是什么。

    1.8K20

    C# 使用File.Create方法创建文件时,报进程被占用

    在一个程序里偶然用了System.IO.File.Create去创建文件,运行时一直报错(进程被占用),后来在网上找到了解决办法,引用了一下。...winfrom中操作文件: 判断是否有当前的文件存在,不存在则进行创建,在进行操作; if(!...System.IO.File.Exists(fileName)) { System.IO.File.Create(fileName); } 但是当我运行到发现没有当前的文件,就直接创建当前文件,...之后直接进行操作,出问题了直接报出异常,当前文件正在另一个进程中使用……仔细一看 System.IO.File.Create(fileName)返回的类型是FileStream,ND文件流,文件流不关闭不出异常那才叫怪呢...提供两种解决的方法: 方法一: if(!

    1.2K10

    C#操作Sql Server数据库以及MD5加密存储

    我们一般是在账号注册时将密码通过MD5加密后存入数据库,新注册账号之后。...在账号登录时我们需要判断输入的密码是否正确,而MD5加密是不可逆的 也就意味着它无法解密,所以我们需要将用户输入的密码再加密一次然后再与数据库中已加密存储的密码进行比对,如果比对结果一致则登陆成功。...C#操作Sql Server的几个对象: 首先要加上命名空间using System.Data.SqlClient; 我用到的对象其实也就是这几个,先拿用户登录界面这部分来举例子吧: ①SqlConnection...:创建数据库连接对象。...DataSet ds = new DataSet(); //实例化DataSet对象 ⑤SqlDataAdapter:创建一个用于检索和保存数据的对象,可以用来填充DataSet。

    2K20

    BS1032-基于C#+SqlServer+CS架构实现学生选课信息管理系统,学生选课录入系统

    采用C#+SqlServer+CS架构实现的学生选课管理系统,学生选课录入系统,系统采用多层C/S软件架构,采用C#编程语言开发技术实现界面窗口版本的学生管理系统程序界面,实现CS架构窗口事件监听,完成学生选课创建...:C#编程语言,MFC,C#多线程,窗口事件监听,数据库,SQLSERVER,GUI主要包含算法:其他等二、效果实现系统主页图片课程管理图片其他效果省略三、核心代码1.课程添加本系统添加选课信息,主要采用窗口监听用户操作动作...,记录用户输入的课程信息进行校验,校验通过后存入数据库等。...adp1 = new SqlDataAdapter(sql, conn); DataSet ds = new DataSet(); adp1.Fill(ds...adp1 = new SqlDataAdapter(sql, conn); DataSet ds = new DataSet(); adp1.Fill(ds

    97120

    C#数据库操作的3种典型用法

    C#数据库操作的3种典型用法 由于最近和数据库打交道,需要用C#和SQL Server 2005进行操作,就把近段时间内的最常用的操作做个总结.本人也是第一次用C#操作数据库,所以这三种典型用法对初学者还是挺有帮助的...以下是我在visual studio 2005上写的一个类(连的是SQL Server 2005),已经过测试通过.里面有3个方法比较典型,在此把源码贴出: using System; using System.Collections.Generic...sqlDataAdapter = new SqlDataAdapter(); sqlDataAdapter.SelectCommand = sqlCommand; DataSet dataSet...); sqlDataAdapter.Fill(dataSet, dataTableName); //Do something to dataset then you can update it to...} } } 以上的程序概括了最典型的用法,也是最基本的用法 声明:本贴为转帖,原文地址:http://www.knowsky.com/345354.html

    66530

    C#创建线程带参数的方法

    本文给大家介绍C#创建线程带参数的方法,包括无参数线程的创建,带一个参数线程的创建及带两个及以上参数线程的创建,非常不错,具有参考借鉴价值,感兴趣的朋友一起看下吧 1、无参数线程的创建 Thread thread...使用ParameterizedThreadStart,调用 System.Threading.Thread.Start(System.Object) 重载方法时将包含数据的对象传递给线程。...注意传递的参数只能是object类型,不过可以进行强制类型转换。...world"); Thread thread = new Thread(new ThreadStart(tt.ThreadProc)); thread.Start(); } } 以上所述是小编给大家介绍的C...#创建线程带参数的方法 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的!

    2K20

    C#自定义控件的创建

    在编程过程中,现有的c#控件远远不能满足我们的需要,这时候就需要我们自己来开发控件了。本人在开发自定义控件时走了一些弯路,写下此篇,希望能够给有需要的朋友一些帮助,也借此加深自己的印象。...1.创建自定义控件 ?...2.添加控件,组合成一个新的控件 自定义控件功能:打开一张图片,将图片展示在pictureBox控件中,并将图片的名称、大小、尺寸显示出来 控件如下: pictureBox1:命名为picBox label1...bmPic.Size.Height.ToString(); } } } } 点击【解决方案】,右键弹出窗口,点击【生成解决方案】 至此,自定义控件的创建已经完成...生成的控件路径在Debug文件夹下,dll文件 3.自定义控件测试 新建windows窗体应用程序 发现在左边的控件工具栏中并没有刚刚的自定义控件,不要急!! 选择工具下的【选择工具箱项】 ?

    1.6K21

    docker部署dist文件时要重新创建新镜像和容器吗

    当你使用Docker部署dist文件时,你有两个选项来使更改生效:重新创建新镜像和容器,或者在原镜像的基础上重启容器。...重新创建新镜像和容器:如果你的dist文件发生了更改,一种方法是构建一个新的镜像,将最新的dist文件添加到其中,然后使用这个新的镜像创建一个新的容器。...创建一个新的容器:使用原始镜像创建一个新的容器,并将新的dist文件挂载到容器中。你可以使用docker run命令,并使用-v参数将主机的dist目录映射到容器内部的相应位置。...在新容器中将新的dist文件复制到合适的位置,替换原有的dist文件。退出临时容器。创建一个新的容器:使用原始镜像创建一个新的容器。...构建过程中的每个指令都会生成一个中间镜像层,并且这些中间镜像层可以被缓存,以便在未更改相关指令时加快后续的构建过程。构建完成后,可以使用生成的镜像来创建和运行容器。

    40820

    探索C# 10.0的关键新特性

    前言随着.NET 6的发布,C# 10.0带来了许多创新特性和改进,旨在简化编码过程,增强开发者的生产力,并提供更现代、简洁的编程体验,可以说,这些新特性不仅增强了C#的表达能力,还提高了开发者的编程效率和代码的可读性...Init-only properties(初始化只读属性)Init-only 属性使得在对象创建时可以赋值,但一旦创建完成就无法更改,比如 person.FirstName = "Jane"; 这将导致编译错误...在 C# 10.0 之前,如果我们要创建一个对象,需要明确指定类型,比如创建一个名为 person 的 Person 类型的对象Person person = new Person();而在 C# 10.0...new 表达式时,我们省略了类型名 Person,而是在 new 后面直接使用了目标类型 Person,编译器会自动推断出类型。...总结其实C# 10.0还有很多新特性,以上只是C# 10.0部分重要新特性的一部分,此外还包括对可空引用类型的进一步改进、record structs等,所有这些新功能都使C#语言更加现代化和易用,感兴趣的可以通过更新到最新版本的

    34041

    C# 直接创建多个类和使用反射创建类的性能

    本文告诉大家我对比的使用直接创建多个类和使用反射创建多个类的性能 在上一篇 C# 程序内的类数量对程序启动的影响 的基础上,继续做实验 现在创建 1000 个类和一个测试使用的类,测试方法请看 C# 标准性能测试...虽然一开始就知道了反射的性能比较差,但是究竟有多差,在创建对象的时候的差异有多少?...反射创建对象的方法有很多个,本文就只测试其中的两个,一个是通过 Activator 的方式创建,另一个是通过 ConstructorInfo 的方式创建 本文通过实际测试发现了使用 Activator...Method Mean Error StdDev WeejujeGaljouPemhu 15.68 us 0.2810 us 0.2628 us 下面来对比两个不同的反射的创建方式和直接创建的速度...通过 ConstructorInfo 创建比直接创建慢 137 倍 创建对比直接创建和两个不同的反射方法的代码 private static void BenediZayle()

    2.4K20

    BS1031-基于C#+SqlServer+CS架构实现学生成绩信息管理系统,学生成绩录入系统

    采用C#+SqlServer+CS架构实现的学生成绩管理系统,学生成绩录入系统,系统采用多层C/S软件架构,采用C#编程语言开发技术实现界面窗口版本的学生管理系统程序界面,实现CS架构窗口事件监听,完成学生成绩创建...:C#编程语言,MFC,C#多线程,窗口事件监听,数据库,SQLSERVER,GUI主要包含算法:其他等二、效果实现系统主页图片学生添加图片表结构设计图片其他效果省略三、核心代码1.学生添加本系统添加学生成绩...,主要采用窗口监听用户操作动作,记录用户输入的学生成绩进行校验,校验通过后存入数据库等。...sql = "select * from student where stuxuehao='" + textBoxpname.Text.Trim() + "'"; SqlDataAdapter...adp = new SqlDataAdapter(sql, conn); DataSet ds = new DataSet();

    59520
    领券