C# WinForm 数据库连接及对数据库的相关操作
1.首先在App.config配置文件中配置数据库连接字符串:
<appSettings>
<add key="connectionstring" value="server=XXX.XX.X.XX;uid=sa;pwd=******;database=XXXX"/>
<!--<add key="datahost" value="XXX.XX.X.XX" />
<add key="database" value="XXXX" />
<add key="uid" value="sa" />
<add key="pwd" value="******" />-->
</appSettings>
2.代码获取配置文件中设置的数据库连接字符串
private static string connectionString = ConfigurationManager.AppSettings["connectionstring"];
3.创建数据库连接方法:
public static SqlConnection CreateSqlConn() {
SqlConnection conn = new SqlConnection(connectionString);
return conn;
}
4.通过创建数据库操作类(SqlCommand),实现对数据库的增删改查操作:
增:
public static int SaveWorkInfo(SqlConnection conn,string workName,string dealPeriod,string syncType) {
if(conn.State == ConnectionState.Closed){
conn.Open();
}
IDbTransaction tran = conn.BeginTransaction();
int id = 0;
try {
string tableName = "HH_SyncWorkInfo";
string column = "WorkName,DealPeriod,SyncType,CreatedTime";
string value = "'" + workName + "','" + dealPeriod + "','" + syncType + "',getDate()";
id = createPkReturnId(tableName,column,value,conn,tran);
if(id > 0){
tran.Commit();
conn.Close();
}
}catch(Exception ex){
tran.Rollback();
conn.Close();
throw new Exception("保存数据失败!具体详情:" + ex.Message.ToString());
}
return id;
} private static int createPkReturnId(string tableName, string column, string value, SqlConnection conn, IDbTransaction tran)
{
try
{
String strSQL = "INSERT INTO " + tableName + " (" + column + ") VALUES (" + value + ");SELECT @@Identity";
SqlCommand cmd = (SqlCommand)conn.CreateCommand();
cmd.CommandText = strSQL;
cmd.Transaction = (SqlTransaction)tran;
int id = Int32.Parse(cmd.ExecuteScalar().ToString());
return id;
}
catch (Exception ex)
{
conn.Close();
throw new Exception("主表数据保存失败!具体详情:" + ex.Message.ToString());
}
}
删:
public static bool DeleteWorkItem(string ID)
{
SqlConnection conn = CreateSqlConn();
conn.Open();
IDbTransaction tran = conn.BeginTransaction();
try
{
string strSQL = "delete HH_SyncWorkInfo where ID='" + ID + "'";
int result = conn.Execute(strSQL, null, tran);
if (result > 0)
{
tran.Commit();
conn.Close();
return true;
}
else {
tran.Rollback();
conn.Close();
return false;
}
}
catch (Exception ex)
{
tran.Rollback();
conn.Close();
throw new Exception("删除失败!具体详情:" + ex.Message.ToString());
}
}
改:
public static bool UpdateWorkInfo(string id, string workName, string dealPeriod, string syncType)
{
using (var conn = CreateSqlConn())
{
string sql_update = "update HH_SyncWorkInfo SET WorkName = '" + workName + "',dealPeriod = '"+ dealPeriod + "',syncType= '"+ syncType +"' where ID = " + id;
int result = conn.Execute(sql_update); if (result > 0)
return true;
else
return false;
}
}
查:
public static List<WorkInfo> GetWorksInfo()
{
using (var conn = CreateSqlConn())
{
string sql = "select * from HH_SyncWorkInfo";
List<WorkInfo> list = conn.Query<WorkInfo>(sql).AsList();
if (list.Count > 0)
{
return list;
}
else
{
return null;
}
}
}
5.调用存储过程
/// <summary>
///
/// </summary>
/// <param name="sql">存储过程名称</param>
/// <param name="parameters">参数数组</param>
/// <returns></returns>
public static string exectueProcude(string sql, params SqlParameter[] parameters) {
using (SqlConnection conn = SqlHelperDB.CreateSqlConn())
{
conn.Open();
using (SqlCommand cmd = new SqlCommand())
{
cmd.Connection = conn;
cmd.CommandText = sql;
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddRange(parameters);
string result = cmd.ExecuteScalar().ToString();
cmd.Parameters.Clear();
conn.Close();
return result;
}
}
}
通过ExecuteScalar()返回执行结果第一行第一列的值。
在程序中调用执行存储过程方法:
SqlParameter[] para = new SqlParameter[1];
para[0] = new SqlParameter("@OrgID", org_list[nRow].FID);
string Max_CreateTime = ProviderDB.executeProcude("HH_P_GET_GetMax_CreateTime", para);
C# WinForm 数据库连接及对数据库的相关操作的更多相关文章
- python操作mysql数据库的相关操作实例
python操作mysql数据库的相关操作实例 # -*- coding: utf-8 -*- #python operate mysql database import MySQLdb #数据库名称 ...
- PHP对MySQL数据库的相关操作
一.Apache服务器的安装 <1>安装版(计算机相关专业所用软件---百度云链接下载)-直接install<2>非安装版(https://www.apachehaus.com ...
- Android下的SQLite数据库的相关操作及AndroidTestCase测试
一:创建数据库 package com.itcode.mysqlite; import android.content.Context; import android.database.sqlite. ...
- mysql数据库和mongodb数据库的相关操作以及两个数据库的区别
在docs命令中执行数据操作 MySQL数据库 先启动MySQL服务器 net start mysql 进入MySQL服务器MySQL -uroot -p(这里写你的数据库密码) (-P是从哪个端口 ...
- MySQL数据库---记录相关操作
序 表中记录的相关操作一共四种:插入,更新,删除.查询.其中使用最多,也是最难的就是查询. 记录的插入 1. 插入完整数据(顺序插入) 语法一: INSERT INTO 表名(字段1,字段2,字段3… ...
- 用C#进行WinForm开发对数据库的相关操作
class SQLHelper { public SqlConnection conn; //<summary> //链接.打开数据库 //</summary> public ...
- mysql数据库字符集相关操作(修改表字段编码,使其支持emoji表情)
普通的UTF8编码是不支持emoji表情插入的,会报异常: Caused by: java.sql.SQLException: Incorrect string value: '\xF0\x9F\x9 ...
- Linux小知识(1): bash中执行数据库的相关操作
工作中经常会遇到命令行操作数据库或登陆至其他服务器等情况,往往需要通过命令行进入相关的数据库或登陆至相关的服务器,再执行指令操作,因此有没有方法,在命令行或bash脚本中模拟进入数据库或登陆服务器操作 ...
- SQLServer 维护脚本分享(04)服务器角色和数据库角色相关操作
/*------------------------------------------------------------------------------------ [服务器级别-服务器角色] ...
随机推荐
- react 的优点
1. 声明式开发 react 是声明式的开发方式,与之对应的是命令式开发方式.之前用jquery写代码的时候,我们都是直接操作dom,这种我们称为命令式的编程.命令式编程需要我们一点点的告诉dom,它 ...
- Mongo3基础操作
由于3.X的文档是在3.X当前最新版本前记录,所以这里列出一些常用的操作,比如建立库,删除库,等一些格式,然后在描述开启远程和创建用户的一些区别,以及讲解2.X和3.X配置文件区别. 1. Mongo ...
- 14、web服务器介绍
14.1.用户访问网站流程: 1. dns解析原理: 客户端到dns服务器之间的查询为递归查询: dns服务器到根域名服务器的查询是迭代查询: [lc@m01 ~]$ dig www.baidu.co ...
- ps2020 将图片中的字清除 并且不损坏背景图
步骤:1:使用选框工具选中要删除的字:2:选择-->色彩范围,选中字体颜色 :3.选择-->修改-->扩展:4.图片区域,右键填充--内容识别--确定: 1.使用选框工具选中要删除 ...
- 资源:docker离线安装包下载路径
docker安装包下载路径: docker所有版本:https://download.docker.com/linux/static/stable/
- WebService:CXF的JaxWsDynamicClientFactory实现调用WebService接口
首先需要引入依赖jar包 #版本只供参考,具体看项目 <dependency> <grouId>org.apache.cxf</grouId> <artifa ...
- pixel的Edxposed刷机过程
1.先解开bl锁 这里的步骤,因为我机子本来就是解过的了,所以简单记录一下过程好了 第一步:确保你的环境变量是否设置好了,判断的标准就是打开终端(我是mac),usb连接上,然后输入 adb devi ...
- linux学习之路第七天(压缩和解压类指令详解)
压缩和解压类 1.gzip/gunzip 指令 gzip 指令用于压缩文件, gunzip用于解压的 基本语法 gzip 文件 (功能描述:压缩文件,指令将文件压缩成*.gz文件) gunzip 文件 ...
- 《基于JQuery和CSS的特效整理》系列分享专栏
<基于JQuery和CSS的特效整理>已整理成PDF文档,点击可直接下载至本地查阅https://www.webfalse.com/read/201724.html 文章 一款基于jQue ...
- CG-CTF WxyVM
一. 之前一直以为虚拟机是那种vmp的强壳,下午看了一些文章才逐渐明白虚拟机这个概念,目前ctf中题目出现的都是在程序中相等于内嵌了一个虚拟机,将程序代码转换成自己定义的指令,通过内嵌的虚拟机进行解释 ...