用喝啤酒的扎杯泡了一大杯咖啡. 石进的钢琴曲放起来. 今天我不讲三国,说一说C#的简单三层. 做个小一点的winfrom应用程序..记录一下这几晚上的学习成果吧,算是...
数据库用的SqlServer(默默的说一句, 我不会用VS连接MySQL数据库.484傻???)
来吧,已经是中年的骚年.打开VS.
新建一个项目,名称爱叫啥就叫啥,然后右击项目名,添加类库.因为要做三层,所以呢添加个BLL层,再来个DAL层,再来个UI层就完事儿了,就是这么简单就完事了.就这么三个层而已..
C#,Java,PHP,python等等,语言之间都是相互有关联的, 比如说就像女孩,女子,妇女,老太婆,死婆娘之间的关系一样,她们都是女人,就具有女人的天性,没有女人冷冷清清,有了女人鸡犬不宁...大致就这样的吧...
三层呢,就是视图层,业务层,数据层.类似于Android开发中的MVP模式,这么做的好处就是解耦.也便于排查bug,另外相互依赖之间的关系一目了然.就像是女性之间的解耦一样哈.对待女孩要多看看两眼,对待蛮不讲理没文化的老太太就要避而远之.哈哈..
扯了这么多,咱们开始代码吧...
在代码开始之前,还需要在添加两个类库,就是common工具层和Model模型层....这个就相当于化妆品似的, 是对三层的一个修饰吧算是(个人这么理解)
NO.1
首先连接数据库,需要数据库连接字符串..(需要注意的是,这个连接字符串要配置在UI层的App.config里面)
//数据库连接字符串跟标签
这里的Data source指的是数据库服务的名称
接下来在dal层中封装访问数据库的类SqlHelper,需要执行sql语句时直接调用即可,代码如下(需要提前引用System.configuration程序集)
public static class SqlHelper
{
//1,在app.config文件写数据库连接字符串
//2,读取数据库连接字符串(需要先引用System.Configuration)
public static String connstr = ConfigurationManager.ConnectionStrings["scc"].ConnectionString;
//3,insert/delete/update执行数据库的方法
public static int ExecuteNonQuery(String sql,CommandType cmdtype,params SqlParameter[] pms) {
using (SqlConnection conn = new SqlConnection(connstr))
{
using (SqlCommand cmd = new SqlCommand(sql,conn))
{ //设置当前的是存储过程还是带参数的SQL语句
cmd.CommandType = cmdtype;
if (pms!=null)
{
cmd.Parameters.AddRange(pms);
}
conn.Open();
return cmd.ExecuteNonQuery();
}
}
}
//4,执行返回单个返回值的方法
public static object ExecuteScala(String sql, CommandType cmdType, params SqlParameter[] pms) {
using (SqlConnection conn = new SqlConnection(connstr))
{
using (SqlCommand cmd = new SqlCommand(sql,conn))
{
cmd.CommandType = cmdType;
if (pms!=null)
{
cmd.Parameters.AddRange(pms);
}
conn.Open();
return cmd.ExecuteScalar();
}
}
}
//5,执行返回多个值得方法
public static SqlDataReader ExecuteReader(String sql,CommandType cmdType,params SqlParameter[] pms) {
using (SqlConnection conn = new SqlConnection(connstr))
{
using (SqlCommand cmd = new SqlCommand(sql,conn))
{
cmd.CommandType = cmdType;
if (pms!=null)
{
cmd.Parameters.AddRange(pms);
}
try
{
conn.Open();
return cmd.ExecuteReader(CommandBehavior.CloseConnection);
}
catch
{
conn.Close();
conn.Dispose();
throw;
}
}
}
}
//6,返回数据表的方法
public static DataTable ExecuteDataTable(String sql,CommandType cmdtype,params SqlParameter [] pms) {
DataTable dt = new DataTable();
using (SqlDataAdapter adapter = new SqlDataAdapter(sql,connstr))
{
if (pms!=null)
{
adapter.SelectCommand.Parameters.AddRange(pms);
}
adapter.Fill(dt);
return dt;
}
}
}
好了,数据库的增删改查的方法封装好了.接下来呢,先把UI层的要显示的数据UI写一下..如下图
目前只写了添加功能,..修改和删除的最后在写...
接下来添加数据
UI层
LoadDataBLL bll = new LoadDataBLL();
dataGridView1.DataSource = bll.getData();
BLL层
public List getData()
{
LoadDataDAL dal = new LoadDataDAL();
return dal.getData();
}
DAL层
public class LoadDataDAL
{
List lists = new List();
public List getData() {
String sql = "select * from hero";
DataTable dt = SqlHelper.ExecuteDataTable(sql,CommandType.Text);
foreach (DataRow row in dt.Rows)
{
lists.Add(new HeroModel() {
name = row["name"].ToString(),
gender = row["gender"].ToString(),
price = Convert.ToInt32(row["price"]),
passiveskill = row["passiveskill"].ToString(),
oneskill = row["oneskill"].ToString(),
twoskill = row["twoskill"].ToString(),
threeskill = row["threeskill"].ToString(),
role = row["role"].ToString(),
});
}
return lists;
}
HeroModel就是一个bean类,Javabean类...代码就不贴了..
效果如下:
艾玛...十一点了..不写了.拾掇拾掇碎觉了...明天再继续..晚安(友情推荐晚安神曲---> <只要有你的地方(晚安版)>林俊杰)