web中oracle查看外键约束有外键的怎么让它显示他之前选过的值

基于MVC4+EasyUI的Web开发框架经验总结(9)--在Datagrid里面实现外键字段的转义操作 - 伍华聪 - 博客园
随笔 - 473, 文章 - 20, 评论 - 7056, 引用 - 20
我们在使用EasyUI的时候,很多情况下需要使用到表格控件datagrid,这个控件控件非常强大,使用起来很简洁,但是我在使用中,发现对于一个表里面的外键字段进行转义,并显示引用表的一些名称的操作,却显得比较难以实现,找了很多资料,基本上没有找到对应的解决方案。本文主要介绍我对这种外键字段转义的操作的实现方式,以便供大家参考了解。
1、DataGrid的初始化操作
在了解对内容的解析前,我们先来了解EasyUI里面Datagrid的初始化操作过程,然后逐步进行分析,寻求解决方式。
一般情况下,Datagrid内容的初始化代码如下所示,注意下面红色部分的内容Customer_ID,就是我们需要转换为客户名称的处理。因为我们这里返回的表数据包含了一个外键ID:Customer_ID,我需要把它转换一下客户的名称。
//实现对DataGird控件的绑定操作
function InitGrid(queryData) {
$('#grid').datagrid({
//定位到Table标签,Table标签的ID是grid
url: '/Contact/FindWithPager',
//指向后台的Action来获取当前用户的信息的Json格式的数据
title: '客户联系人',
iconCls: 'icon-view',
height: 650,
width: function () { return document.body.clientWidth * 0.9 },//自动宽度
nowrap: true,
autoRowHeight: false,
striped: true,
collapsible: true,
pagination: true,
pageSize: 50,
pageList: [50, 100, 200],
rownumbers: true,
//sortName: 'Seq',
//根据某个字段给easyUI排序
sortOrder: 'asc',
remoteSort: false,
idField: 'ID',
queryParams: queryData,
//异步查询的参数
columns: [[
{ field: 'ck', checkbox: true },
{ title: '客户ID', field: 'Customer_ID', width: 180, sortable: true},
{ title: '编号', field: 'HandNo', width: 80, sortable: true },
{ title: '姓名', field: 'Name', width: 80, sortable: true },
{ title: '身份证号码', field: 'IDCarNo', width: 120, sortable: true },
title: '出生日期', field: 'Birthday', width: 120, sortable: true,
formatter: function (value, rec, index) {
if (value == undefined) {
return "";
if ((value + '').indexOf('1900') == 0) {
return "";
toolbar: [{
id: 'btnAdd',
text: '添加',
iconCls: 'icon-add',
handler: function () {
ShowAddDialog();//实现添加记录的页面
id: 'btnEdit',
text: '修改',
iconCls: 'icon-edit',
handler: function () {
ShowEditOrViewDialog();//实现修改记录的方法
id: 'btnDelete',
text: '删除',
iconCls: 'icon-remove',
handler: function () {
Delete();//实现直接删除数据的方法
id: 'btnView',
text: '查看',
iconCls: 'icon-table',
handler: function () {
ShowEditOrViewDialog("view");//实现查看记录详细信息的方法
id: 'btnReload',
text: '刷新',
iconCls: 'icon-reload',
handler: function () {
//实现刷新栏目中的数据
$("#grid").datagrid("reload");
onDblClickRow: function (rowIndex, rowData) {
$('#grid').datagrid('uncheckAll');
$('#grid').datagrid('checkRow', rowIndex);
ShowEditOrViewDialog();
2、尝试失败的操作
1)使用格式化函数Formatter
针对以上的处理,有些人可能很快就想到使用格式化Formatter来实现了,一般情况下处理转义和自定义显示操作,非此莫属。
有可能想使用的代码如下所示。
title: '客户名称', field: 'Customer_ID', width: 180, sortable: true,
formatter: function (value, row) {
$.ajaxSettings.async = false;
$.getJSON("/Customer/GetCustomerName?id=" + value, function (result) {
return "&span&" + result + "&/span&";
但是,如果这样做,你会发现格式化函数没有办法调用ajax的操作,获取对应的数据,也就是无法进行解析客户的ID为名称。因此这种方法,失败!
2)使用onLoadSuccess函数
这个onLoadSuccess函数,本意就是在Datagrid顺利加载后执行的函数,一般情况下,我想在加载后,在更新表格里面的数据,如下面的代码所示。
onLoadSuccess: function (data) {
var rows = $("#grid").datagrid("getRows");
if (rows.length &= 1) {
for (var i = 0; i & rows. i++) {
$.getJSON("/Customer/GetCustomerName?id=" + rows[i].Customer_ID, function (result) {
$('#grid').datagrid('updateRow', { index: 0, row: { field: result } });
下面的方法也是通过Ajax的方式获取数据,然后进行更新,不过很不幸,也不通过,无法正常解析。
3、成功解析的方式
好了,既然无法通过上面脚本的方式来进行解析,我们通过曲线救国的方式,应该也是可以的。
由于Datagrid显示的数据是下面的方式就可以的
var result = new { total = list.Count, rows = list };
那么我们在返回数据给datagrid的控制器函数里面,对返回的内容,增加一个&客户名称&的信息,应该就可以了。
1)转换内容为DataTable并增加字段
但是我的框架里面,返回的内容都设置为了List&T&的这种方式,也就是T代表的是实体类,我们很难改变实体类里面的属性并赋值,那么我们也可以把它转换为DataTable了。
//增加一个客户名称字段,然后进行解析,构建一个DataTable返回
DataTable dtReturn = DataTableHelper.ListToDataTable&ContactInfo&(list);
dtReturn.Columns.Add("CustomerName");
foreach (DataRow row in dtReturn.Rows)
row["CustomerName"] = BLLFactory&Customer&.Instance.GetCustomerName(row["Customer_ID"].ToString());
var result = new { total = dtReturn.Rows.Count, rows = dtReturn };
通过函数DataTableHelper.ListToDataTable&ContactInfo&(list);可以把列表的内容构建成一个DataTable的内容,并增加一个CustomerName的字段,然后遍历每一行,填入解析Customer_ID后的名称,并返回记录就可以了。
在视图里面,我们通过增加一个字段进行绑定就可以了,如下所示。
title: '客户ID', field: 'Customer_ID', width: 180, sortable: true, hidden:true
{ title: '客户名称', field: 'CustomerName', width: 180, sortable: true },
2)在实体类基类增加一些额外的字段属性
刚才我们看到,把实体类列表转换为DataTable,然后并遍历赋值,挺麻烦的一件事,也可能影响一些性能,如果我们实体类里面有一些备用的属性作为内容解析,在界面上直接使用这些备用属性就可以了,这样会更加方便。
因此我在所有实体类的基类里面增加三个属性,Data1、Data2、Data3,有点类似Visio模具形状的属性设置了,呵呵。
/// &summary&
/// 框架实体类的基类
/// &/summary&
[DataContract]
public class BaseEntity
#region 在实体类存储一些特殊的数据
/// &summary&
/// 用来给实体类传递一些额外的数据,如外键的转义等,该字段不保存到数据表中
/// &/summary&
[DataMember]
public string Data1 { get; set; }
/// &summary&
/// 用来给实体类传递一些额外的数据,如外键的转义等,该字段不保存到数据表中
/// &/summary&
[DataMember]
public string Data2 { get; set; }
/// &summary&
/// 用来给实体类传递一些额外的数据,如外键的转义等,该字段不保存到数据表中
/// &/summary&
[DataMember]
public string Data3 { get; set; }
#endregion
有了这些备用的属性,我们就可以解决外键转义的内容存储问题了。
在查询里面,我们只需要遍历一次,把转换好的内容赋值给对应的实体类属性就好了。
foreach (ContactInfo info in list)
//增加一个特殊字段的转义
info.Data1 = BLLFactory&Customer&.Instance.GetCustomerName(info.Customer_ID);
最后在视图里面,我们的代码如下所示。
title: '客户ID', field: 'Customer_ID', width: 180, sortable: true, hidden:true
{ title: '客户名称', field: 'Data1', width: 180, sortable: true },
主界面里面的列表展示如下所示。
数据导入界面里面的列表展示如下所示。
基于MVC4+EasyUI的Web开发框架的系列文章:在java web项目中如何向两张有主外键关系的表中插入数据_百度知道
在java web项目中如何向两张有主外键关系的表中插入数据
我有更好的答案
先将没有外键的那个表存数据,然后再存有外键的
先插入主键表的数据,然后再查询出主键表的主键ID,根据这个主键ID在向外键表中插入数据。
这个是一个简单的事务处理。就像银行转账的道理一样。当然如果数据库设置了约束。那就是单表插入也是会出错。就看你的设计了
应该先插入外键表再插入主表
其他类似问题
为您推荐:
外键的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁问个项目中的外键有关问题 - Java Web开发当前位置:& &&&问个项目中的外键有关问题问个项目中的外键有关问题&&网友分享于:&&浏览:3次问个项目中的外键问题最近在逛一些论坛,听见有人人说他们做到项目中表全部都不使用外键,说影响性能,但又听说使用了外键别担心,有hibernate缓存,无须担心,这到底怎么回事,实际项目中到底使用外键不?求工作的CSDNer解答一下,小弟还在读大三,不知道具体情况,3q3qps 我知道外键是要影响性能,不知道是否实际项目中到底使用不,------解决方案--------------------看情况把,对于数据压力很大的应用,最好不用外键;相反用外键可以让你比较省力的完成数据完整性的任务。
------解决方案--------------------这个看情况了,如果一个功能对应的数据表不是很多的情况下,可以不使用外键,我们目前就是这个情况,数据一致性,通过存储过程统一处理了
------解决方案--------------------同意1楼说法
------解决方案--------------------反正我做的项目大到800W小到20W,还没有使用外键的。外键仅仅存在于数据库设计中。个人觉得有外键会更严谨,并且更符合规范,但是实际项目中更注重的是效率。
12345678910
12345678910
12345678910 上一篇:下一篇:文章评论相关解决方案 12345678910 Copyright & &&版权所有问题:在java
web中,有外键的servlet要怎么实现!
描述:在java
web中,有外键的servlet要实现增删改查该怎么写?求一个简单的例子,急急急!!!!!解决方案1:http://bbs.csdn.net/topics/解决方案2:http://blog.csdn.net/jspamd/article/details/
以上介绍了“在java
web中,有外键的servlet要怎么实现!”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:/wd/589792.html
上一篇: 下一篇:

我要回帖

更多关于 oracle查看外键约束 的文章

 

随机推荐