一、常用技术概括及介绍
1. SQL server:处理数据库的设计
2. asp.net
3. html :前端网页
4. css :网页的布局设计
5. JavaScript :能够更好的操作页面
6. jQuery :
7. ajax :处理局部刷新请求
二、分层介绍 (类库)
1.bll:业务层、
2.dal:数据层、
3.model:对应数据库的表、
4.common:公共方法
5.webapp:新建的app
6.webapp自带的配置文件
创建好之后如下:
三、实现步骤
1. 数据层中两个类,对应封装增删改查语句
using System; using System.Collections.Generic; using System.Configuration; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Data; using System.Data.SqlClient; namespace CZBK.ItcastProject.DAL { public class SqlHelper { //getdatetable方法获取整个表 //参数1.sql语句 2. 判断是sql语句还是存储过程 3. 传递的参数 private static readonly string connStr = ConfigurationManager.ConnectionStrings["connStr"].ConnectionString; //读取配置文件中的字符串 public static DataTable GetDataTable(string sql,CommandType type,params SqlParameter[]pars) { using (SqlConnection conn = new SqlConnection(connStr)) { using (SqlDataAdapter apter = new SqlDataAdapter(sql, conn)) { if (pars != null) { apter.SelectCommand.Parameters.AddRange(pars); } apter.SelectCommand.CommandType = type; DataTable da = new DataTable(); apter.Fill(da); return da; } } } //获取受影响行数,ExecuteNonQuery 主要用在插入,更新,删除 一般情况用在查询的时候返回的是-1 public static int ExecuteNonquery(string sql, CommandType type, params SqlParameter[] pars) {
using (SqlConnection conn = new SqlConnection(connStr)) { using (SqlCommand cmd = new SqlCommand(sql, conn)) { if (pars != null) { cmd.Parameters.AddRange(pars); } cmd.CommandType = type; conn.Open(); return cmd.ExecuteNonQuery(); } } } } }
1 using CZBK.ItcastProject.Model; 2 using System; 3 using System.Collections.Generic; 4 using System.Linq; 5 using System.Text; 6 using System.Threading.Tasks; 7 using System.Data; 8 using System.Data.SqlClient; 9 namespace CZBK.ItcastProject.DAL 10 { 11 public class UserInfoDal 12 { 13 /// <summary> 14 /// 获取用户列表 15 /// </summary> 16 /// <returns></returns> 17 public List<UserInfo> GetList() 18 { 19 string sql = "select * from UserInfo"; 20 DataTable da = SqlHelper.GetDataTable(sql, CommandType.Text); 21 List<UserInfo> list = null; 22 if (da.Rows.Count > 0) 23 { 24 list = new List<UserInfo>(); 25 UserInfo userInfo = null; 26 foreach (DataRow row in da.Rows) 27 { 28 userInfo = new UserInfo(); 29 LoadEntity(userInfo, row); 30 list.Add(userInfo); 31 } 32 } 33 return list; 34 } 35 /// <summary> 36 /// 添加用户信息 37 /// </summary> 38 /// <param name="userInfo"></param> 39 /// <returns></returns> 40 public int AddUserInfo(UserInfo userInfo) 41 { 42 string sql = "insert into UserInfo(UserName,UserPass,RegTime,Email) values(@UserName,@UserPass,@RegTime,@Email)"; 43 SqlParameter[] pars = { 44 new SqlParameter("@UserName",SqlDbType.NVarChar,32), 45 new SqlParameter("@UserPass",SqlDbType.NVarChar,32), 46 new SqlParameter("@RegTime",SqlDbType.DateTime), 47 new SqlParameter("@Email",SqlDbType.NVarChar,32) 48 }; 49 pars[0].Value = userInfo.UserName; 50 pars[1].Value = userInfo.UserPass; 51 pars[2].Value = userInfo.RegTime; 52 pars[3].Value = userInfo.Email; 53 return SqlHelper.ExecuteNonquery(sql, CommandType.Text, pars); 54 } 55 56 /// <summary> 57 /// 根据ID删除用户的信息 58 /// </summary> 59 /// <param name="id"></param> 60 /// <returns></returns> 61 public int DeleteUserInfo(int id) 62 { 63 string sql = "delete from UserInfo where ID=@ID"; 64 SqlParameter[] pars = { 65 new SqlParameter("@ID",SqlDbType.Int) 66 }; 67 pars[0].Value = id; 68 return SqlHelper.ExecuteNonquery(sql,CommandType.Text,pars); 69 } 70 71 /// <summary> 72 /// 修改用户信息 73 /// </summary> 74 /// <param name="userInfo"></param> 75 /// <returns></returns> 76 public int EditUserInfo(UserInfo userInfo) 77 { 78 string sql = "update UserInfo set UserName=@UserName,UserPass=@UserPass,RegTime=@RegTime,Email=@Email where ID=@ID"; 79 SqlParameter[] pars = { 80 new SqlParameter("@UserName",SqlDbType.NVarChar,32), 81 new SqlParameter("@UserPass",SqlDbType.NVarChar,32), 82 new SqlParameter("@RegTime",SqlDbType.DateTime), 83 new SqlParameter("@Email",SqlDbType.NVarChar,32), 84 new SqlParameter("@ID",SqlDbType.Int) 85 }; 86 pars[0].Value = userInfo.UserName; 87 pars[1].Value = userInfo.UserPass; 88 pars[2].Value = userInfo.RegTime; 89 pars[3].Value = userInfo.Email; 90 pars[4].Value = userInfo.Id; 91 return SqlHelper.ExecuteNonquery(sql, CommandType.Text, pars); 92 } 93 94 /// <summary> 95 /// 根据用户的编号,获取用户的信息 96 /// </summary> 97 /// <param name="id"></param> 98 /// <returns></returns> 99 public UserInfo GetUserInfo(int id) 100 { 101 string sql = "select * from UserInfo where ID=@ID"; 102 SqlParameter[] pars = { 103 new SqlParameter("@ID",SqlDbType.Int) 104 }; 105 pars[0].Value = id; 106 DataTable da=SqlHelper.GetDataTable(sql, CommandType.Text, pars); 107 UserInfo userInfo = null; 108 if (da.Rows.Count > 0) 109 { 110 userInfo = new UserInfo(); 111 LoadEntity(userInfo, da.Rows[0]); 112 } 113 return userInfo; 114 } 115 116 117 private void LoadEntity(UserInfo userInfo, DataRow row) 118 { 119 userInfo.UserName = row["UserName"] != DBNull.Value ? row["UserName"].ToString() : string.Empty; 120 userInfo.UserPass = row["UserPass"] != DBNull.Value ? row["UserPass"].ToString() : string.Empty; 121 userInfo.Email = row["Email"] != DBNull.Value ? row["Email"].ToString() : string.Empty; 122 userInfo.Id = Convert.ToInt32(row["ID"]); 123 userInfo.RegTime = Convert.ToDateTime(row["RegTime"]); 124 } 125 } 126 }