Hi AbushNasi,
Please refer below sample.
Model
public class Customers
{
public int Id { get; set; }
public string PG { get; set; }
public string LC { get; set; }
public string PROT { get; set; }
}
Controller
public class HomeController : Controller
{
// GET: Home
public ActionResult Index()
{
List<SelectListItem> items = PopulateData();
return View(items);
}
[HttpPost]
public ActionResult Index(List<SelectListItem> items)
{
string selected = string.Join(",", items.Where(x => x.Selected).Select(x => x.Value).ToArray());
string conString = ConfigurationManager.ConnectionStrings["constr"].ConnectionString;
using (SqlConnection con = new SqlConnection(conString))
{
string query = "INSERT INTO List (Values) VALUES (@Values)";
using (SqlCommand cmd = new SqlCommand(query))
{
cmd.Connection = con;
cmd.CommandType = CommandType.Text;
cmd.Parameters.AddWithValue("@Values", selected);
con.Open();
cmd.ExecuteNonQuery();
con.Close();
}
}
return View(items);
}
public List<SelectListItem> PopulateData()
{
List<SelectListItem> items = new List<SelectListItem>();
items.Add(new SelectListItem { Text = "PG", Value = "LC" });
items.Add(new SelectListItem { Text = "LC", Value = "LC" });
items.Add(new SelectListItem { Text = "PROT", Value = "PROT" });
return items;
}
}
View
@model List<SelectListItem>
@{
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Index</title>
</head>
<body>
@using (Html.BeginForm("Index", "Home", FormMethod.Post))
{
<table>
<tr>
<th>Customer Id:</th>
<th>Name:</th>
<th>Country:</th>
</tr>
@for (int i = 0; i < Model.Count; i++)
{
<tr>
<td>
@Html.CheckBoxFor(m => m[i].Selected)
</td>
<td>
@Html.DisplayFor(m => m[i].Text)
@Html.HiddenFor(m => m[i].Value)
@Html.HiddenFor(m => m[i].Text)
</td>
</tr>
}
</table>
<br />
<input type="submit" value="Submit" />
}
</body>
</html>