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)服务器角色和数据库角色相关操作
/*------------------------------------------------------------------------------------ [服务器级别-服务器角色] ...
随机推荐
- [源码解析] 深度学习分布式训练框架 horovod (10) --- run on spark
[源码解析] 深度学习分布式训练框架 horovod (10) --- run on spark 目录 [源码解析] 深度学习分布式训练框架 horovod (10) --- run on spark ...
- 通过RenderDoc真机抓取数据来落地验证和解决特效性能的问题
前言 需求是来自于我在为我司的一个线上RPG游戏做特效的性能优化的过程中,需要验证对特效的一个改动是否能够提高性能,当然这个改动是在不影响美术效果的前提. 特效性能问题 技能特效 主角的一个大招(技能 ...
- 编译aarch64 Linux内核并基于qemu运行
核心流程 首先,本文主要讲述如何编译Linux内核并在qemu虚拟机上运行.这里针对的架构是aarch64. 本文的实验平台是Ubuntu 16.04. 为了达成目标,我们需要有qemu.buildr ...
- 接口自动化框架搭建Unittes+HTMLTestRunner
本次主要尝试搭建接口自动化框架,基于 unittest+HTMLTestRunner 框架主要模块: config: 存放配置文件 lib: 封装了一些接口前置函数:处理各种事物 log: 存放生成的 ...
- (转发)forward与(重定向)redirect的区别
(转发)forward与(重定向)redirect的区别 forward是服务器请求资源,服务器直接访问目标地址的URL,把那个URL的响应内容读取过来,然后把这些内容再发给浏览器.浏览器根本不知道服 ...
- mysql日期时间处理
获得当前周的周一到周日 select subdate(curdate(),date_format(curdate(),'%w')-1)//获取当前日期在本周的周一 select subdate(c ...
- 发送 email (转)
<?phpnamespace app\common\controller;//基类class Email{ /* Public Variables */ var $smtp_port; var ...
- CG-CTF 签到
int __cdecl sub_401340(unsigned __int8 *a1) { int v2; // [esp+18h] [ebp-D0h] int v3; // [esp+1Ch] [e ...
- [源码解析] 深度学习分布式训练框架 horovod (14) --- 弹性训练发现节点 & State
[源码解析] 深度学习分布式训练框架 horovod (14) --- 弹性训练发现节点 & State 目录 [源码解析] 深度学习分布式训练框架 horovod (14) --- 弹性训练 ...
- 深入理解索引和AVL树、B-树、B+树的关系
目录 什么是索引 索引的分类 索引和AVL树.B-树.B+树的关系 AVL树.红黑树 B-树 B+树 SQL和NoSQL索引 什么是索引 索引时数据库的一种数据结构,数据库与索引的关系可以看作书籍和目 ...