001-ADO.NET
Web.config
<connectionStrings>
<add name="connStr" connectionString="server=.;database=MyWeb;uid=sa;pwd=123"/>
</connectionStrings>
SqlHelper.cs
/// <summary>
/// SqlHelper(数据库帮助类)
/// </summary>
public static class SqlHelper
{
/// <summary>
/// SQL连接字符串
/// </summary>
private static string connStr = System.Configuration.ConfigurationManager.ConnectionStrings["connStr"].ConnectionString;
/// <summary>
/// 获取数据库列表数据
/// </summary>
/// <param name="sql">SQL语句</param>
/// <param name="ps">SQL参数</param>
/// <returns>返回DataTable</returns>
public static DataTable GetList(string sql, params SqlParameter[] ps)
{
//创建Sql连接对象(参数:连接字符串)
using (SqlConnection conn = new SqlConnection(connStr))
{
//填充DataSet和更新SQL Server数据库(一组数据命令,一个数据库连接)
SqlDataAdapter sda = new SqlDataAdapter(sql, conn);
//设置存储过程,在数据源中选择记录
sda.SelectCommand.Parameters.AddRange(ps);
//表示内存中数据的一个表
DataTable dt = new DataTable();
//添加或刷新指定范围中的行DataSet,以匹配中使用数据源的那些DataTable名称
sda.Fill(dt);
//返回表数据
return dt;
}
}
/// <summary>
/// 执行SQL查询,并返回受影响的行数
/// </summary>
/// <param name="sql">SQL语句</param>
/// <param name="ps">SQL参数</param>
/// <returns>返回受影响的行数</returns>
public static int ExecuteNonQuery(string sql, params SqlParameter[] ps)
{
//创建Sql连接对象(参数:连接字符串)
using (SqlConnection conn = new SqlConnection(connStr))
{
//表示对SQL Server数据库执行Sql语句或存储过程
SqlCommand cmd = new SqlCommand(sql, conn);
//对命令传入参数
cmd.Parameters.AddRange(ps);
//打开数据库连接
conn.Open();
//执行Sql语句,返回受影响的行数
return cmd.ExecuteNonQuery();
}
}
/// <summary>
/// 执行查询,返回结果集中第一行的第一列
/// </summary>
/// <param name="sql">SQL语句</param>
/// <param name="ps">SQL参数</param>
/// <returns>返回结果集第一行的第一列</returns>
public static object ExecuteScalar(string sql, params SqlParameter[] ps)
{
//创建Sql连接对象(参数:连接字符串)
using (SqlConnection conn = new SqlConnection(connStr))
{
//对SQL Server数据库执行Sql语句
SqlCommand cmd = new SqlCommand(sql, conn);
//传入命令参数
cmd.Parameters.AddRange(ps);
//打开数据库
conn.Open();
//返回结果集第一行的第一列
return cmd.ExecuteScalar();
}
}
}
CantusDal.cs
/// <summary>
/// Lrc歌词数据层
/// </summary>
public class CantusDal : ICantusDal
{
/// <summary>
/// 获取数据库列表数据.Dal
/// </summary>
/// <returns></returns>
public List<Cantus> GetList()
{
//sql查询语句
string sql = "select * from cantus";
//创建内存数据库表,接收查询到的数据
DataTable dt = SqlHelper.GetList(sql);
//创建List<Cantus>泛型集合
List<Cantus> list = new List<Cantus>();
//循环遍历(DataTable每一行数据)
foreach (DataRow row in dt.Rows)
{
//list集合添加数据单元
list.Add(new Cantus()
{
Id = Convert.ToInt32(row["Id"]),//Id(id)
Serial = Convert.ToByte(row["Serial"]),//Serial(曲目)
Song = row["Song"].ToString(),//Song(歌词)
Album = row["Album"].ToString(),//Album(专辑)
Number = (short)row["Number"],//Number(张数)
Date = Convert.ToDateTime(row["Date"]),//Date(年份)
Writer = row["Writer"].ToString(),//Writer(作词)
Composer = row["Composer"].ToString(),//Composer(作曲)
Arranger = row["Arranger"].ToString(),//Arranger(编曲)
Singing = row["Singing"].ToString(),//Singing(原唱)
Lyric = row["Lyric"].ToString()//Lyric(歌词)
});
}
return list;
}
/// <summary>
/// 添加数据
/// </summary>
/// <returns></returns>
public bool Add(Cantus ct)
{
string sql = "insert into cantus values(@Serial,@Song,@Album,@Number,@Date,@Writer,@Composer,@Arranger,@Singing,@Lyric)";
SqlParameter[] ps = {
new SqlParameter("@Serial",ct.Serial),
new SqlParameter("@Song",ct.Song),
new SqlParameter("@Album",ct.Album),
new SqlParameter("@Number",ct.Number),
new SqlParameter("@Date",ct.Date),
new SqlParameter("@Writer",ct.Writer),
new SqlParameter("@Composer",ct.Composer),
new SqlParameter("@Arranger",ct.Arranger),
new SqlParameter("@Singing",ct.Singing),
new SqlParameter("@Lyric",ct.Lyric),
};
return SqlHelper.ExecuteNonQuery(sql, ps) > ;
}
}
CantusBll.cs
/// <summary>
/// 业务逻辑层.BLL
/// </summary>
public class CantusBll : ICantusBll
{
/// <summary>
/// 声明Dal操作对象
/// </summary>
private CantusDal ctDal;
/// <summary>
/// 构造函数()
/// </summary>
public CantusBll()
{
//创建Dal操作对象
ctDal = new CantusDal();
}
/// <summary>
/// 返回数据层获取的数据
/// </summary>
/// <returns></returns>
public List<Cantus> GetList()
{
return ctDal.GetList();
}
/// <summary>
/// 添加数据
/// </summary>
/// <param name="ct"></param>
/// <returns></returns>
public bool Add(Cantus ct)
{
return ctDal.Add(ct);
}
}
BackController.cs
public class BackController : Controller
{
CantusBll ctBll = new CantusBll();
// GET: Back
public ActionResult Index()
{
List<Cantus> ct = ctBll.GetList();
JavaScriptSerializer js = new JavaScriptSerializer();
string result = js.Serialize(ct);
Response.Write(result);
return View();
}
}
001-ADO.NET的更多相关文章
- 转:ADO.NET连接字符串
名称 ADO.NET连接字符串 说明 ADO.NET连接字符串:SQL Server,SQL Server 2005,ACCESS,Oracle,MySQL,Interbase,IBM DB2,Syb ...
- ADO.NET测试题
第一部分: 新建一个数据库:ADO测试,包含下面两个数据表,使用代码创建,并保留创建的代码文本. 学生表Student: 编号(Code):nvarchar类型,不能为空,主键 姓名(Name):nv ...
- ADO.NET实体数据模型使用探索1
今天研究了下ADO.NET实体数据模型,想写个关于两张有外键关系的增改删查,以此来稍增加点难度. 编程环境:vs2010+sql2005 1.在SQL2005下建立三张表:学生信息表Student(S ...
- ADO.NET与Oracle(一):获取多行记录集
近期接触ADO.NET和Oracle.将我寻常遇到的一些问题和大家共享. 我认为要想入门ADO.NET操作Oracle,最主要的要求就是要会通过ADO.NET更新Oracle中的数据. 该文简单讲些利 ...
- ADO数据库链接
一.数据库操作准备 // --------------------------------------------------------------------------------------- ...
- (转 飛雲若雪)ADO.NET
一.简单介绍ADO.NET System.Data:DataTable,DataSet,DataRow,DataColumn,DataRelation,Constraint System.Data.C ...
- MFC中使用ADO方式连接数据库
文章转自:http://blog.sina.com.cn/s/blog_a43aba5601014z8h.html 一.数据库操作准备 1.导入ADO动态链接库 在工程的stdafx.h中加入如下语句 ...
- ADO.NET 总结
一.简单介绍ADO.NET System.Data:DataTable,DataSet,DataRow,DataColumn,DataRelation,Constraint System.Data.C ...
- ADO.NET连接字符串大全---各种数据库的连接字符串
ADO.NET连接字符串大全 ADO.NET连接字符串 名称 ADO.NET连接字符串 说明 ADO.NET连接字符串:SQL Server,SQL Server 2005,ACCESS,Oracle ...
- ADO.NET连接字符串大全
说明ADO.NET连接字符串:SQL Server,SQL Server 2005,ACCESS,Oracle,MySQL,Interbase,IBM DB2,Sybase,Informix,Ingr ...
随机推荐
- 咸鱼入门到放弃7--jsp<二>jsp常用标签
一.JSP标签介绍 JSP标签也称之为Jsp Action(JSP动作)元素,它用于在Jsp页面中提供业务逻辑功能,避免在JSP页面中直接编写java代码,造成jsp页面难以维护. 二.JSP常用标签 ...
- java中的try-catch-finally异常处理(学习笔记)
一.异常概述 异常:Exception,是在运行发生的不正常情况. 原始异常处理: if(条件) { 处理办法1 处理办法2 处理办法3 } if(条件) { 处理办法4 处理办法5 处理办法6 } ...
- json,HTTP协议
JSON 语法规则 JSON 语法是 JavaScript 对象表示语法的子集. 数据在名称/值对中 数据由逗号分隔 大括号保存对象 中括号保存数组 JSON 对象 JSON 对象使用在大括号({}) ...
- 微信小程序--家庭记账本开发--03
组件.标签以及模板的使用 在一个微信小程序中,需要用到大量的组件,一些页面的设计也需要模板,在自己所学课程中,对于一些组件.标签模板的使用有了初步的了解. 1.组件 组件是数据和方法的简单封装,对于微 ...
- 6101 最优贸易 (双向spfa)
描述C国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双向通行的 ...
- 【Redis】-- 安装及配置
我们redis的安装较为复杂,属于Linux上的源码编译安装,即不能直接通过yum安装. 1.安装Redis 具体步骤: 1.进入redis官网,复制下载链接,通过wget下载源码 官网:https: ...
- C#からネイティブDLLを呼び出す場合のVSからのデバッグのジレンマを解決する
「C#を使う最大のメリットって.やっぱり.Visual Studioですよね!」って自信を持って言いたいですね. という心境ではあるんですが.私の仕事はどっちかというとC++よりなので.どうしても.D ...
- 编程菜鸟的日记-初学尝试编程-C++ Primer Plus 第5章编程练习3
#include <iostream>using namespace std;int main(){ double count=0; long double cleo=100; long ...
- EF Working with Transactions
原文:https://msdn.microsoft.com/en-us/data/dn456843.aspx Prior to EF6 Entity Framework insisted on ope ...
- __x__(44)0910第六天__表单
form表单: form必须属性:action,指定一个服务器地址. 若希望表单中的数据发送给服务器,必须设置name属性. 用户填写的信息,将会追加在url地址?后面,以查询字符串的形式发送给服务器 ...