黑马程序员+ADO.Net基础(中)
---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IOS开发</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------
10 案例登录:
/// <summary>
/// 登录成功后清空errorTimes
/// </summary>
/// <param name="conStr"></param>
/// <param name="name"></param>
private static void ResetErrorTimes(string conStr, string name)
{
using (SqlConnection conn = new SqlConnection(conStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "update T_user set errortimes=0 where name=@Name";
cmd.Parameters.Add(new SqlParameter("@Name", name));
cmd.ExecuteNonQuery();
}
}
}
/// <summary>
/// 登录错误后errortimes+1
/// </summary>
/// <param name="conStr"></param>
/// <param name="name"></param>
private static void IncErrorTimes(string conStr, string name)
{
using (SqlConnection conn = new SqlConnection(conStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "update T_user set errortimes+=1 where name=@Name";
cmd.Parameters.Add(new SqlParameter("@Name", name));
cmd.ExecuteNonQuery();
}
}
}
/// <summary>
/// 登录三次错误后退出
/// </summary>
/// <param name="conStr"></param>
static void ThreeLogin(string conStr)
{
do
{
Console.WriteLine("用户名:");
string name = Console.ReadLine();
Console.WriteLine("密码:");
string pwd = Console.ReadLine();
int errortimes = 0;
using (SqlConnection conn = new SqlConnection(conStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "select * from T_user where name=@Name ";
cmd.Parameters.Add("@Name", name);
using (SqlDataReader reader = cmd.ExecuteReader())
{
if (reader.Read())
{
errortimes = reader.GetInt32(reader.GetOrdinal("errortimes"));
if (errortimes >= 3)
{
Console.WriteLine("登录错误超过三次,不能再登录了");
break;
}
else
{
if (reader.GetString(reader.GetOrdinal("password")) == pwd)
{
Console.WriteLine("登录成功");
ResetErrorTimes(conStr, name);
break;
}
else
{
Console.WriteLine("登录失败!");
//reader.Close();//在连接没有关闭前不能有其他操作
//cmd.CommandText = "update T_user set errortimes+=1 where name=@Name";
//cmd.ExecuteNonQuery();
IncErrorTimes(conStr, name);
}
}
}
else
{
Console.WriteLine("用户不存在,请重新输入!");
}
}
}
}
} while (true);
}
11 导入导出数据:
/// <summary>
/// 插入数据到数据库中
/// </summary>
/// <param name="conStr"></param>
/// <param name="name"></param>
/// <param name="age"></param>
private static void InsertData(string conStr,string name,int age) {
using (SqlConnection conn=new SqlConnection(conStr))
{
conn.Open();
using (SqlCommand cmd=conn.CreateCommand())
{
cmd.CommandText = "insert into T_Person values(@Name,@Age)";
cmd.Parameters.Add("@Name",name);
cmd.Parameters.Add("@Age",age);
cmd.ExecuteNonQuery();
}
}
}
/// <summary>
/// 文件导入数据库
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button1_Click(object sender, EventArgs e)
{
string conStr = @"Data Source=ZHANGLIANG\SQLEXPRESS;Initial Catalog=MyDB;Integrated Security=True";
OpenFileDialog ofd=new OpenFileDialog();
if (ofd.ShowDialog()==DialogResult.OK)
{
using (FileStream filestream =File.OpenRead(ofd.FileName))
{
using (StreamReader reader=new StreamReader(filestream))
{
string lines = null;
while ((lines=reader.ReadLine())!=null)
{
string[] line = lines.Split('|');
string name = line[0];
int age = Convert.ToInt32(line[1]);
InsertData(conStr,name,age);
}
}
}
MessageBox.Show("导入数据成功!");
}
}
/// <summary>
/// 导出
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void button2_Click(object sender, EventArgs e)
{
using (SqlConnection conn = new SqlConnection(conStr))
{
conn.Open();
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "select name,age from T_Person";
using (SqlDataReader reader = cmd.ExecuteReader())
{
SaveFileDialog sfd = new SaveFileDialog();
if (sfd.ShowDialog() == DialogResult.OK)
{
///StringBuilder sb = new StringBuilder();
while (reader.Read())
{
string name = reader.GetString(reader.GetOrdinal("name"));
int age = reader.GetInt32(reader.GetOrdinal("age"));
using (FileStream stream=new FileStream(sfd.FileName, FileMode.Append))
{
using (StreamWriter writer=new StreamWriter(stream,Encoding.Default))
{
writer.WriteLine(string.Format("{0}|{1}",name,age));
}
}
}
MessageBox.Show("写入数据成功!");
}
}
}
}
}
---------------------- <a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IOS开发</a>、<a href="http://edu.csdn.net"target="blank">.Net培训</a>、期待与您交流! ----------------------
详细请查看:<a href="http://edu.csdn.net" target="blank">http://edu.csdn.net</a>
黑马程序员+ADO.Net基础(中)的更多相关文章
- 黑马程序员+ADO.Net基础(下)
---------------<a href="http://edu.csdn.net"target="blank">ASP.Net+Android ...
- 黑马程序员+ADO.Net基础(上)
---------------<a href="http://edu.csdn.net"target="blank">ASP.Net+Android ...
- 黑马程序员:Java基础总结----泛型(高级)
黑马程序员:Java基础总结 泛型(高级) ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 泛型(高级) 泛型是提供给javac编译器使用的,可以限定集合中的输入类型 ...
- 黑马程序员:Java基础总结----类加载器
黑马程序员:Java基础总结 类加载器 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 类加载器 Java虚拟机中可以安装多个类加载器,系统默认三个主要类加载器,每个 ...
- 黑马程序员:Java基础总结----静态代理模式&动态代理
黑马程序员:Java基础总结 静态代理模式&动态代理 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 静态代理模式 public class Ts { ...
- 黑马程序员:Java基础总结----枚举
黑马程序员:Java基础总结 枚举 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 枚举 为什么要有枚举 问题:要定义星期几或性别的变量,该怎么定义?假设用1-7分别 ...
- 黑马程序员:Java基础总结----反射
黑马程序员:Java基础总结 反射 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 反射 反射的基石:Class类 Class类代表Java类,它的各个实例对象又分别 ...
- 黑马程序员:Java基础总结----JavaBean 内省
黑马程序员:Java基础总结 JavaBean 内省 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! JavaBean 内省 软件包 java.beans 包含与开 ...
- 黑马程序员:Java基础总结----java注解
黑马程序员:Java基础总结 java注解 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! java注解 lang包中的基本注解 @SuppressWarnings ...
随机推荐
- js中判断true和false的情况
- java javacv调用摄像头并拍照
调用摄像头并拍张照片,我一开始用的java的jmf媒体框架,但这个有很多的局限性不好使并且很有麻烦,兜了一圈发现javacv东西,研究之后这东西简单,方便:废话不多说了来重点. javacv官网:点击 ...
- ElasticSearch 命令行管理工具Curator
一.背景 elastic官网现在已经大面积升级到了5.x版本,然而针对elasticsearch的命令行管理工具curator现在仍然是4.0版本. 刚开始找到此工具,深深的怕因为版本更迭无法使用,还 ...
- libxml2 移植 arm9
准备工作: 1.libxml2软件版本:libxml2-2.6.32.tar.gz 2.交叉编译工具链:arm-none-linux-guneabi 软件安装: 1.设置环境变量: export PA ...
- Java中四种引用:强、软、弱、虚引用
这篇文章非常棒:http://alinazh.blog.51cto.com/5459270/1276173 Java中四种引用:强.软.弱.虚引用 1.1.强引用当我们使用new 这个关键字创建对象时 ...
- Spring.net 间接调用被AOP拦截的方法失效(无法进入aop的拦截方法)
.下面的tx要定义 <objects xmlns="http://www.springframework.net" xmlns:db="http://www.spr ...
- Cracking-- 1.1 判断字符串中是否有重复字符
第三种方法为位运算的方法. 位运算符: << 左移 & 与 | 或 #include <iostream> #include <string> #incl ...
- mysql字段类型
会安装mysql,会几条sql语句,会jdbc,会hibernate配置,以为就会mysql了,最近几天面试被问到mysql的问题,无地自容,系统的学习一下. mysql优化之一,选择合适的而不是最大 ...
- MATLAB 秒表函数 tic toc 计算程序运行时间
若需要测试出程序运行所需时间,或对不同的运行方式所需时间进行对比,则可利用秒表函数tic和toc.Tic函数启动定时器,第一个紧跟它的toc函数终止定时器并报告此时定时器的流逝时间.其语法如下: t ...
- Web大文件上传控件-jsp-sql示例更新-Xproer.HttpUploader6.2
版权所有 2009-2016荆门泽优软件有限公司 保留所有权利 官方网站:http://www.ncmem.com/ 产品首页:http://www.ncmem.com/webapp/up6.2/in ...