VisualStudio2013内置SQLServer入门(二)--增删改查
前一篇 http://www.cnblogs.com/qixi233/p/4766451.html
这篇是sqlserver的操作
界面比较走心哈哈哈,将就着看,主要就是下面增删改查四个btn
对于sqlserver的操作基本就几个:
- 开关SqlConnection
- SqlCommand将"SQL命令"与"SQLConnection"连接
- 执行命令并根据返回值来将操作结果反馈给用户
现在开始操作:(代码比较简单,如果有书写不够规范之处请告知谢谢)
代码结构:
数据库视图:
0. 开关数据库连接
优先于四大操作的存在,每次用户操作之前开启,每次用户操作之后关闭
/// <summary>
/// 开启数据库
/// </summary>
private void openCon() {
string str_con = "server=(LocalDB)\\v11.0;database=master;integrated security=true";
con = new SqlConnection(str_con);
if (con.State == ConnectionState.Closed)
{
con.Open();
return;
}
if(con.State==ConnectionState.Broken){
con.Close();
con.Open();
}
} /// <summary>
/// 关闭数据库
/// </summary>
private void closeCon() {
if (con.State !=ConnectionState.Closed) {
con.Close();
con.Dispose();
}
}
- 查
- 根据id查询数据库中是否存在对应数据,有则返回,没有则提示
#region btn_查询
private void btn_check_Click(object sender, RoutedEventArgs e)
{
openCon();
//查询是否有id
if (tb_id.Text.Trim() != "")
{
string sql_cmd = "select userName,cardType from tb_card where cardID='" + tb_id.Text.Trim() + "'";
//可以试试用open直接返回SqlConnection对象,然后查询暂时不封装
using (cmd = new SqlCommand(sql_cmd, con))
{
using (SqlDataReader reader = cmd.ExecuteReader())
{
if (reader.Read())
{
tb_name.Text = reader.GetString();
tb_type.Text = reader.GetString();
}
else
{
MessageBox.Show("查询失败");
}
}
}
}
else
{
MessageBox.Show("id输入框不得为空");
}
closeCon();
}
#endregion- 增
- 检查是否存在id,不存在则添加
#region btn_添加
private void btn_add_Click(object sender, RoutedEventArgs e)
{
openCon();
if (tb_id.Text.Trim() != "" && tb_name.Text.Trim() != "" && tb_type.Text.Trim() != "")
{
try
{
//查询是否有id
string cmd_check = "select userName,cardType from tb_card where cardID='" + tb_id.Text.Trim() + "'";
using (cmd = new SqlCommand(cmd_check, con))
{
using (SqlDataReader reader = cmd.ExecuteReader())
{
if (reader.Read())
{
MessageBox.Show("数据库中已有此卡信息,无法添加");
return; //有重复就退出不处理
}
}
}
//插入
string cmd_add = String.Format("insert into tb_card(cardID,userName,cardType) values ({0},{1},{2})",
"\'" + tb_id.Text.Trim() + "\'", "N\'" + tb_name.Text.Trim() + "\'", "\'" + tb_type.Text.Trim() + "\'");
using (cmd = new SqlCommand(cmd_add, con))
{
if (cmd.ExecuteNonQuery() != -)
{
MessageBox.Show("添加成功");
}
}
}
catch (Exception ex)
{
MessageBox.Show("添加失败,详细信息:" + ex.ToString());
}
}
else
{
MessageBox.Show("信息不得为空");
}
closeCon();
}
#endregion
- 改
- 检测是否存在id,若存在则修改,不存在则告知用户
#region btn_更新
private void btn_update_Click(object sender, RoutedEventArgs e)
{
openCon();
if (tb_id.Text.Trim() != "" && tb_name.Text.Trim() != "" && tb_type.Text.Trim() != "")
{
try
{
//查询id是否存在
string cmd_check = "select userName,cardType from tb_card where cardID='" + tb_id.Text.Trim() + "'";
using (cmd = new SqlCommand(cmd_check, con))
{
using (SqlDataReader reader = cmd.ExecuteReader())
{
if (!reader.Read())
{
MessageBox.Show("数据库中没有此卡信息,无法修改");
return;
}
}
}
string cmd_update = String.Format("update tb_card set userName={0},cardType={1} where cardID={2}",
"N\'" + tb_name.Text.Trim() + "\'", "\'" + tb_type.Text.Trim() + "\'", "\'" + tb_id.Text.Trim() + "\'");
using (cmd = new SqlCommand(cmd_update, con))
{
if(cmd.ExecuteNonQuery()!=-){
MessageBox.Show("更新成功");
}
}
}
catch (Exception ex)
{
MessageBox.Show("更新失败,详细信息:" + ex.ToString());
}
}
else
{
MessageBox.Show("信息不得为空");
}
closeCon();
}
#endregion
- 删
- 检测id是否存在,存在则删除该行,不存在则告知用户
#region btn_删除
private void btn_delete_Click(object sender, RoutedEventArgs e)
{
openCon();
if (tb_id.Text.Trim().Length != )
{
try
{
string cmd_check = "select * from tb_card where cardID='" + tb_id.Text.Trim() + "'";
using (cmd = new SqlCommand(cmd_check, con))
{
using (SqlDataReader reader = cmd.ExecuteReader())
{
if (!reader.Read())
{
MessageBox.Show("数据库中没有此卡信息,无法删除");
return;
}
}
}
string cmd_delete = "delete from tb_card where cardID='" + tb_id.Text.Trim() + "'";
using (cmd = new SqlCommand(cmd_delete, con))
{
if (cmd.ExecuteNonQuery() != -)
{
MessageBox.Show("删除成功");
}
}
}
catch (Exception ex)
{
MessageBox.Show("删除失败,详细信息:" + ex.ToString());
}
}
else {
MessageBox.Show("id不得为空");
}
closeCon();
}
#endregion
大家最喜欢的直接上代码上完了,再说说我遇到的几个坑:
第一个就是一开始不知道为什么只能添加数字,连英文字母都不能添加,后来经过查看代码中的sql命令发现是在有英文的地方没有加上''将其包围起来;
第二个就是每次中文添加之后就乱码,后来知道有nvarchar这种东西,然后再再添加中文的地方之前加个N,例如:七喜--》N'七喜',这样就搞定了
第三个就是cmd命令的执行,我一开始无论增删改查都用ExecuteReader,但是觉得怪怪的,最后看stackoverflow的大神的答案和官方文档才知道一般增删改都用ExecuteNonQuery
最后发几条学习过程中参考的链接:
http://www.cnblogs.com/mr-wid/archive/2013/05/09/3068229.html 21分钟 MySQL 入门教程
https://msdn.microsoft.com/en-us/library/ms187752.aspx 微软的数据库类型参考
http://www.w3school.com.cn/sql/sql_datatypes.asp w3c的各种数据库类型参考
http://stackoverflow.com/questions/5349114/executenonquery stackoverflow关于executenonquery使用
有神马地方说错或者有神马意见欢迎提出谢谢
VisualStudio2013内置SQLServer入门(二)--增删改查的更多相关文章
- VisualStudio2013内置SQLServer入门
最近做项目老大要求用到sqlserver,但是这项目的数据库只是本地演示用并不复杂,于是决定试试VisualStudio2013内置的SQLServer.对于这个东西的了解并没有多少,然后项目初学习的 ...
- mybatis入门(二):增删改查
mybatis的原理: 1.mybatis是一个持久层框架,是apache下的顶级项目 mybatis托管到googlecode下,目前托管到了github下面 2.mybatis可以将向prepar ...
- mybatis入门二-----增删改查
一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...
- MyBatis学习系列二——增删改查
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...
- Mybatis入门之增删改查
Mybatis入门之增删改查 Mybatis如果操作成功,但是数据库没有更新那就是得添加事务了.(增删改都要添加)----- 浪费了我40多分钟怀疑人生后来去百度... 导入包: 引入配置文件: sq ...
- Redis入门之增删改查等常用命令总结
Redis是用C语言实现的,一般来说C语言实现的程序"距离"操作系统更近,执行速度相对会更快. Redis使用了单线程架构,预防了多线程可能产生的竞争问题. 作者对于Redis源代 ...
- Hibernate入门_增删改查
一.Hibernate入门案例剖析: ①创建实体类Student 并重写toString方法 public class Student { private Integer sid; private ...
- MyBatis入门2_增删改查+数据库字段和实体字段不一致情况
本文为博主辛苦总结,希望自己以后返回来看的时候理解更深刻,也希望可以起到帮助初学者的作用. 转载请注明 出自 : luogg的博客园 谢谢配合! 当数据库字段和实体bean中属性不一致时 之前数据库P ...
- JDBC【1】-- 入门之增删改查
目录 1.jdbc是什么 2.使用IDEA开发 2.1 创建数据库,数据表 2.2 使用IDEA创建项目 1.jdbc是什么 JDBC(Java DataBase Connectivity,java数 ...
随机推荐
- [LeetCode#271] Encode and Decode Strings
Problem: Design an algorithm to encode a list of strings to a string. The encoded string is then sen ...
- 对于利用pca 和 cca 进行fmri激活区识别的理解
1.pca 抛开fmri研究这个范畴,我们有一个超长向量,这个超长向量在fmri研究中,就是体素数据.向量中的每个数值,都代表在相应坐标轴下的坐标值.这些坐标轴所组成的坐标系,其实是标准单位坐标系.向 ...
- Delphi Webservice 杂谈
用WebService来实现B2B集成的最大好处在于可以轻易实现互操作性 WebService可用基于XML的SOAP来表示数据和调用请求,并且通过HTTP协议来传输这些XML格式的数据,因为此时的调 ...
- Linux学习笔记29——IPC状态命令
一 IPC IPC是进程间通讯,在前面,我们相继学习了进程间通讯机制有信号量,内存共享,消息队列.状态命令(ipcs)和删除命令(ipcrm)提供了一种检查和清理IPC机制的方法. 二 状态命令 1 ...
- 用Delphi制作仿每行带按钮的列表
Delphi做程序开发在使用到列表控件时,一般是列表放文本内容,在列表以外放操作按钮,选中列表某项再点按钮进行操作.现在Web开发做列表的样式总是列表的每行都有操作按钮,如微博的列表风格: Web开发 ...
- LianLianKan - HDU 4272(状态压缩)
题目大意:有一列数据,可以从最上面的开始连接下面相同的元素,然后消除,不过距离不能超过6,询问最后能不能消除完整个数列. 分析:首先讨论一点最远能消除的地方,比如点的位置是x,如若想要消除x+1位置处 ...
- EassyUI内置方法与属性
Jquery插件 easyUI属性汇总 作者: 字体:[增加 减小] 类型:转载 时间:2011-01-19我要评论 找了个时间看了下EasyUI插件,对它的插件感觉是很舒服,特地把Easy UI的大 ...
- SQL profile纵览(10g)
第一篇:介绍 10g开始,查询优化器(Query optimizer)扩展成自动调整优化器(Automatic Tuning Optimizer).也就是扩展了功能.此时,我们就可以让 ...
- PopupWindow源码分析
PopupWindow是我们经常使用的一个控件,严格来说这个PopuWindow就用来在指定位置显示一个View. 经过分析源码,PopupWindow里面没有Window对象,只是把View设置到屏 ...
- SQL string类型的数据按int类型排序 分类: SQL Server 2014-12-08 16:56 393人阅读 评论(0) 收藏
说明: 我在做wms进销存软件时,发现一个问题:一张入库单(T_OutIn_BoxTop),入库扫描时要分成多箱,箱号(BoxTop_No)可以是数字也可以是字符串,所以箱号只能是字符串类型的,问题来 ...