C#学习日记之数据库连接
一、webconfig设置和参数解释
在C#中新建一个网站时,webconfig文件中会有一个默认的数据库连接语句,如下
<connectionStrings>
<add name="DefaultConnection" providerName="System.Data.SqlClient" connectionString="Data Source=(LocalDb)\v11.0;
Initial Catalog=aspnet-easyui-test-20141212151928;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|\aspnet-easyui-test-20141212151928.mdf" />
</connectionStrings>
简单记录一下其标签的意思。
(1)name:数据库连接语句。在C#页面代码中使用时,可以知道其相关属性。
(2)providerName:没什么好说的,SQL数据库一般都是System.Data.SqlClient,如果使用的是Oracle数据库,应该是System.Data.OracleClient。
(3)connectionString:照着默认的写就可以了,没什么说法。
(4)Initial Catalog:你的数据库名字
(5)Integrated Security:有True|False|SSPI。True代表集成登陆数据库,将使用当前的Windows帐户凭据进行身份验证。SSPI的作用与True的作用一样的。False则要求你填入数据库登陆的uid和pwd。也就是账户和密码,一般数据库账户名都是sa,密码是在数据库创建时候填写的。
(6)User ID:=uid,大小写不区分。在Integrated Security为False的情况下才需要填写,代表数据库的登陆账户,一般都是sa。
(7)Password:=pwd,大小写不区分。数据库的登陆密码。
(8)AttachDBFilename:可以写成“extended properties”,“initial file name”,指定连接打开的时候动态附加到服务器上的数据库文件的位置,可以不填写。这个属性可以接受数据库的完整路径和相对路径(例如使用|DataDirectory|语法),在运行时这个路径会被应用程序的 App_Data 目录所代替。
下面是我自己写的一个:
<connectionStrings>
<add name="DefaultConnection" providerName="System.Data.SqlClient" connectionString="Data Source=(LocalDb)\v11.0;
Initial Catalog=aspnet-easyui-test-20141212151928;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|\aspnet-easyui-test-20141212151928.mdf" />
<add name="TestConnection" providerName="System.Data.SqlClient" connectionString="Data Source=(LocalDb)\v11.0;
Initial Catalog=TestUser;Integrated Security=false;User ID=sa;Password=123456"/>
</connectionStrings>
二、C#后台连接
1.写一个抽象类sqlHelper来进行数据库处理以及存储过程的处理,然后在DAL中用stringbuilder来组装数据库操作语句。首先需要配置数据库,也就是刚刚在webconfig中配置好的连接语句需要用上了。
public static string connectionString = ConfigurationManager.ConnectionStrings["TestConnection"].ConnectionString;
公用方法就不赘述了,写一个简单的如何执行SQL语句的吧,把注释也给写上了。
/// <summary>
/// 执行SQL语句,返回影响的记录数
/// </summary>
/// <param name="SQLString">SQL语句</param>
/// <returns>影响的记录数</returns>
public static int ExecuteSql(string SQLString)
{
using (SqlConnection connection = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(SQLString, connection))
{
try
{
connection.Open();
int rows = cmd.ExecuteNonQuery();
return rows;
}
catch (System.Data.SqlClient.SqlException e)
{
connection.Close();
throw e;
}
}
}
}
最后返回的是int类型的数据,影响结果的记录数。PS:对此类代码进行编写的时候,都要带上两个命名空间:System.Data和System.Data.SqlClient,有些时候还要带上System.Text,加上了这些命名空间才能显示系统内部带上的方法。
2.第二步就可以在DAL中进行调用这些方法了。不过DAL中主要封装的是处理数据的SQL语句,例如:
/// <summary>
/// 更新一条数据
/// </summary>
/// <param name="model"></param>
/// <returns></returns>
public bool Update(MODEL.UserInfoModel model)
{
StringBuilder strSql = new StringBuilder();
strSql.Append("update UserDetail set ");
strSql.Append("username=@username,");
strSql.Append("password=@password,");
strSql.Append("sex=@sex,");
strSql.Append("age=@age,");
strSql.Append("political=@political,");
strSql.Append("height=@height,");
strSql.Append("weight=@weight,");
strSql.Append("graduated=@graduated,");
strSql.Append("professional=@professional,");
strSql.Append("graduateddate=@graduateddate,");
strSql.Append("address=@address,");
strSql.Append("phone=@phone,");
strSql.Append("other=@other ");
strSql.Append("where userid=@userid");
SqlParameter[] parameters = {
new SqlParameter("@username",SqlDbType.VarChar,),
new SqlParameter("@password",SqlDbType.VarChar,),
new SqlParameter("@sex",SqlDbType.Int,),
new SqlParameter("@age",SqlDbType.Int,),
new SqlParameter("@political",SqlDbType.Int,),
new SqlParameter("@height",SqlDbType.Int,),
new SqlParameter("@weight",SqlDbType.Int,),
new SqlParameter("@graduated",SqlDbType.VarChar,),
new SqlParameter("@professional",SqlDbType.VarChar,),
new SqlParameter("@graduateddate",SqlDbType.DateTime),
new SqlParameter("@address",SqlDbType.VarChar,),
new SqlParameter("@phone",SqlDbType.VarChar,),
new SqlParameter("@other",SqlDbType.VarChar,),
new SqlParameter("@userid",SqlDbType.Int,)
};
parameters[].Value = model.UserName;
parameters[].Value = model.Password;
parameters[].Value = model.Sex;
parameters[].Value = model.Age;
parameters[].Value = model.Political;
parameters[].Value = model.Height;
parameters[].Value = model.Weight;
parameters[].Value = model.Graduated;
parameters[].Value = model.Professional;
parameters[].Value = model.GraduatedDate;
parameters[].Value = model.Address;
parameters[].Value = model.Phone;
parameters[].Value = model.Other;
parameters[].Value = model.UserId; int rows = SqlHelper.ExecuteSql(strSql.ToString(), parameters);
if (rows > )
return true;
else
return false; }
当然,其中我用model封装了UserDetail数据库里面的所有字段,通过这样一个方法,我就可以自如的在model中调用数据库里的字段了,毕竟model里面字段的值改变的话,数据库里的数据也响应改变。
C#学习日记之数据库连接的更多相关文章
- Linux学习日记-使用EF6 Code First(四)
一.在linux上使用EF 开发环境 VS2013+mono 3.10.0 +EF 6.1.0 先检测一下EF是不是6的 如果不是 请参阅 Linux学习日记-EF6的安装升级(三) 由于我的数据库 ...
- Java学习-006-三种数据库连接 MySQL、Oracle、sqlserver
此文主要讲述在初学 Java 时,常用的三种数据库 MySQL.Oracle.sqlserver 连接的源代码整理.希望能对初学 Java 编程的亲们有所帮助.若有不足之处,敬请大神指正,不胜感激!源 ...
- android学习日记05--Activity间的跳转Intent实现
Activity间的跳转 Android中的Activity就是Android应用与用户的接口,所以了解Activity间的跳转还是必要的.在 Android 中,不同的 Activity 实例可能运 ...
- android学习日记03--常用控件Dialog
常用控件 9.Dialog 我们经常会需要在Android界面上弹出一些对话框,比如询问用户或者让用户选择.这些功能我们叫它Android Dialog对话框 对话框,要创建对话框之前首先要创建Bui ...
- android学习日记03--常用控件checkbox/radiobutton
常用控件3.checkbox 复选框,确定是否勾选,点击一下勾选,点击第二下取消,当有一系列备选项时适合用checkbox控件,方便用户提交数据. 贴上例子Activity的java代码 packag ...
- android学习日记03--常用控件button/imagebutton
常用控件 控件是对数据和方法的封装.控件可以有自己的属性和方法.属性是控件数据的简单访问者.方法则是控件的一些简单而可见的功能.所有控件都是继承View类 介绍android原生提供几种常用的控件bu ...
- Zend Framework学习日记(2)--HelloWorld篇(转)
Zend Framework学习日记(2)--HelloWorld篇 这一篇主要演示如何用zf命令行工具建立一个基于Zend Framework框架的工程,也是我初学Zend Framework的小练 ...
- Zend Framework学习日记(1)--环境搭建篇(转)
Zend Framework学习日记(1)--环境搭建篇 (1)开发工具 Zend Framework框架:http://framework.zend.com/download/latest 包含2个 ...
- Python 学习日记(第三周)
知识回顾 在上一周的学习里,我学习了一些学习Python的基础知识下面先简短的回顾一些: 1Python的版本和和安装 Python的版本主要有2.x和3.x两个版本这两个版本在语法等方面有一定的区别 ...
随机推荐
- HDU 5741 Helter Skelter(构造法)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5741 [题目大意] 一个01相间的串,以0开头,给出的序列每个数字表示连续的0的个数或者1的个数, ...
- Matlab单元(Cell)数据的应用
MATLAB里面的cell有的翻译为单元有的翻译为细胞型数据.它是MATLAB的一种特殊数据类型,可以将它看作是一种无所不包的广义矩阵.组成cell的元素可以是任何一种数据类型的常数或者常量,每一个元 ...
- php在apache中运行模式
php在apache中运行模式 (2011-12-18 02:38:27) 标签: 杂谈 分类: 服务器及软件 一.php在php在三种工作方式:Apache 模块DLL) 以下分别比较: 1. ph ...
- 合作开发,导入MyEclipse项目报错问题
因工作原因,同事将他的java项目交接给了我.和平时的交接一样.他把他最新的源代码,打成压缩包,发给我.我解压后,使用myeclipse开发工具,通过导入,将项目导入到我的开发工具中,这个时候有一个问 ...
- Extjs4 类的定义和扩展
一般定义方式,注意方法和函数的添加方式不同.(添加函数只能用override方式添加不知为什么,有知道的,请搞之.) 定义一个类,并给他一个方法 1: Ext.define('Simple.Class ...
- AT&T汇编试讲--获取CPU Vendor ID
纯汇编代码如下: # a test program to get the processor vendor id # data segment .section .data output: .asci ...
- 优化器的使用oracle ---explain plan
如果要分析某条SQL的性能问题,通常我们要先看SQL的执行计划,看看SQL的每一步执行是否存在问题. 如果一条SQL平时执行的好好的,却有一天突然性能很差,如果排除了系统资源和阻塞的原因,那么基本可以 ...
- FusionCharts 学习总结
FusionCharts和Charts一样都是对数据进行统计并绘制成图标的控件,但FusionCharts带有跨浏览器的flash图表组件解决方案,功能更为强大.. 在这里我将采用Js来加载Fusio ...
- c/c++ double的数字 转成字符串后 可以有效的避免精度要求不高的数
char n[100]; sprintf(n,"%lf",db);
- POJ 2142:The Balance_扩展欧几里得(多组解)
先做出两个函数的图像,然后求|x|+|y|的最小值.|x|+|y|=|x0+b/d *t |+|y0-a/d *t| 这个关于t的函数的最小值应该在t零点附近(在斜率大的那条折线的零点附近,可以观察出 ...