改变数据库中的True/False的小窍门
开发工具与关键技术:SQL Server 2014 Management Studio 改变数据库中的True/False
作者:李国旭
撰写时间:2019年7月26日
关于这个如何改变数据库中的True和False的值,方法有很多种。那么下面呢我给大家介绍俩种方法;第一种我们大家都会做的,那就是最直接最简单的方法,就是直接在数据库中手写他们的True和False的值。这个我们大家都会,接下来我要讲的就是利用设定的启用和作废在页面上,通过勾选复选框来改变数据库中的True和False的值。
下面我们一起来看一下这个例子:
第一步,首先给它设定一个按钮,我们就通过这个复选框的按钮来改变它数据库中里面的True和False的值;在这之前呢先获取它数据库里面的值和表格改变后的状态,这里就需要用到layui的一个样式了如下:
layuiForm.on('checkbox(字段)', function (data) {
//console.log(data.elem.checked); //是否被选中,true或者false
ZoneInvalidation = data.elem.checked;
});
上面我们呢我们如果不知到是否拿到数据库的值的时候,我们就可以先输出一下看看是否被选中,“True”或者是“False”所以就要先输出一下看看是拿到了还是没拿到它的值。注意:要声明一个全局的变量来接受他的值,要不然我们是拿不到它的值的,所以一定要声明它的全局变量。
第二步,给它是否启用一个隐藏域同时,给它设定一个ID。然后在保存新增的时候呢,就获取它的ID,我这里用的是原生JS来获取的,并没有用Jquery的写法的去获取它的ID;通过获取了之后就给它赋值(Value),如下图所示:
下面的就是控制器那边的代码:
修改是否启用的状态,给它传参数和bool类型的是否启用的字段
public ActionResult UpdateCabinetinvalidation(int CarryCabinetId, bool Cabinetinvalidation)
{
ReturnJsonVo returnJson = new ReturnJsonVo();
try{
var varLinq = (from tb in myModel.B_CarryCabinet
where tb.CarryCabinetID == CarryCabinetId
select tb).Single();
varLinq.Cabinetinvalidation = Cabinetinvalidation;
myModel.Entry(varLinq).State = EntityState.Modified;
if (myModel.SaveChanges() > 0){
returnJson.State = true;
returnJson.Text = "修改成功";
}
else{
returnJson.State = false;
returnJson.Text = "修改失败";
}
}
catch (Exception e){
Console.WriteLine(e);
returnJson.Text = "数据异常";
}
return Json(returnJson, JsonRequestBehavior.AllowGet);
}
下面的是页面的状态效果图:
靠左边是数据库中的状态而右边是页面的状态,页面显示已作废的有两条和数据库中相对应。