當前位置:首頁 » 數據倉庫 » 資料庫的eval
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

資料庫的eval

發布時間: 2022-08-30 14:05:01

❶ Eval方法和Bind方法的區別

Eval 方法是靜態單向(只讀)方法,所以Eval 函數用於單向(只讀)綁定,該方法採用數據欄位的值作為參數並將其作為字元串返回。
Bind 方法支持讀/寫功能,所以Bind 函數用於雙向(可更新)綁定。該方法可以檢索數據綁定控制項的值並將任何更改提交回資料庫

❷ 大家知道asp.net那個讀取資料庫表欄位的函數eval是什麼意思

Eval方法實際上是TemplateControl的,而System.Web.UI.Page和System.Web.UI.UserControl都繼承於TemplateControl,所以我們可以在Page和UserControl上直接調用個方法。

Page.Eval方法可以幫助我們更好的撰寫數據綁定表達式,在ASP.NET 1.x時代,數據綁定表達式的一般形式是:

%# DataBinder.Eval( Container , 「DataItem.Name」) %

而在ASP.NET 2.0中,同樣的代碼,我們可以這樣寫:

%# Eval( 「Name」 )%

ASP.NET 2.0是怎麼實現的呢?我們先從Eval方法來研究,通過反射.NET Framework 2.0類庫的源代碼,我們可以看到這個方法是這樣實現的:

protected internal object Eval(string expression)

{

this.CheckPageExists();

return DataBinder.Eval(this.Page.GetDataItem(), expression);

}

第一行我們不必管,這是檢查調用的時候有沒有Page對象的,如果沒有則會拋出一個異常。

關鍵是第二行:

return DataBinder.Eval(this.Page.GetDataItem(), expression);

Page.GetDataItem()也是2.0中新增的一個方法,用途是正是取代ASP.NET 1.x中的Container.DataItem。

看來不摸清楚GetDataItem()方法,我們也很難明白Eval的原理。GetDataItem的實現也很簡單:

public object GetDataItem()

{

if ((this._dataBindingContext == null) (this._dataBindingContext.Count == 0))

{

throw new InvalidOperationException(SR.GetString(「"Page_MissingDataBindingContext「"));

}

return this._dataBindingContext.Peek();

}

我們注意到了有一個內部對象_dataBindingContext,通過查源代碼發現這是一個Stack類型的東西。所以他有Peek方法。而這一段代碼很容易看懂,先判斷這個Stack是否被實例化,然後,判斷這個Stack裡面是不是有任何元素,如果Stack沒有被實例化或者沒有元素則拋出一個異常。最後是將這個堆棧頂部的元素返回。

ASP.NET 2.0用了一個Stack來保存所謂的DataItem,我們很快就查到了為這個堆棧壓元素和彈出元素的方法:Control.DataBind方法:

protected virtual void DataBind(bool raiseOnDataBinding)

{

bool flag1 = false;//這個標志的用處在上下文中很容易推出來,如果有DataItem壓棧,則在後面出棧。

if (this.IsBindingContainer)//判斷控制項是不是數據綁定容器,實際上就是判斷控制項類是不是實現了INamingContainer

{

bool flag2;

object obj1 = DataBinder.GetDataItem(this, out flag2);//這個方法是判斷控制項是不是有DataItem屬性,並把它取出來。

if (flag2 && (this.Page != null))//如果控制項有DataItem

{

this.Page.PushDataBindingContext(obj1);//把DataItem壓棧,PushDataBindingContext就是調用_dataBindingContext的Push方法

flag1 = true;

}

}

try

{

if (raiseOnDataBinding)//這里是判斷是不是觸發DataBinding事件的。

{

this.OnDataBinding(EventArgs.Empty);

}

this.DataBindChildren();//對子控制項進行數據綁定,如果這個控制項有DataItem,則上面會將DataItem壓入棧頂,這樣,在子控制項裡面調用Eval或者GetDataItem方法,就會把剛剛壓進去的DataItem給取出來。

}

finally

{

if (flag1)//如果剛才有壓棧,則現在彈出來。

{

this.Page.PopDataBindingContext();//PopDataBindingContext就是調用_dataBindingContext的Pop方法

}

}

}

❸ asp.net中 Eval()和Bind()是什麼意思

綁定表達式
<%# Eval("欄位名") %>
<%# Bind("欄位名") %>
區別 1。eval是只讀數據,Bind是可更新的.
2.當再次表達式操作時候,必須用Eval 如<%# Eval("欄位名").ToString().Trim()%>
3.若GridView中綁定列裡面 設置 內容格式 DataFormateString ={0:d} ,則 必須把 屬性 HtmlCode 設置為false,否則無法起作用;
Eval 單向綁定:數據是只讀的
Bind雙向綁定:數據可以更改,並返回伺服器端,伺服器可以處理更改後的數據,如存入資料庫.
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:D}")%> //----2006年10月27日
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:F}")%>//----2006年10月27日 8:31:44
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:G}")%>//----2006-10-27 8:31:44
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:M}")%>//----10月27日
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:R}")%>//----Fri, 27 Oct 2006 08:31:44GMT
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:T}")%>//----8:31:44
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:U}")%>//----2006年10月27日 0:31:44
<%# DataBinder.Eval(Container.DataItem,"dateandtime","{0:Y}")%>//----2006年10月
對於程序員來說最根本的區別是:
1.Bind是可更新的,是Bind綁定列可編輯,並且可以和數據源控制項交互,直接和資料庫交互,但是用Bind的話,程序端的自定義操作就不能用了,比如Convert,ToString()等,或自己寫的函數,在程序端都不可以
2.eval是只讀數據,用eval的話不可以和數據源控制項交互,是單向的,但是可以自定義操作
比如上面的<%# Eval("欄位名").ToString().Trim()%>
本人從來和資料庫交互自己寫代碼,所以對我來說操作的Eval更方便,基本不用Bind,而且以前寫過,綁定泛型的時候
Bind都不支持嵌套類

以前從網上搜到的,不知道能不能幫到你

sqleval是什麼

你說的是不是資料庫的?sqleval是個sqlserver安裝的壓縮包.
先安裝sqleval,在安裝的sqleval下找到autorun.exe,點擊執行,才能真正的安裝sqlserver。安裝sqleval其實就是解壓縮安裝包,解壓萬後才能真正安裝!

❺ 請問大家ASP.NET的aspx頁面數據綁定<%# Eval(" 這裡面是資料庫的欄位還是實體層的欄位屬性")%> 謝謝

1、<%# Eval(" 這裡面是資料庫的欄位")%>
2、<%= 實體層的欄位屬性 %>
3、<% 這樣相當是後台 %>,如:
<% if (!string.IsNullOrEmpty(base.StrCompanyName))
{ %>
<span style="font-size: 10pt; font-weight: bold;">
<br />
<%= base.StrCompanyName%>
</span>
<% } %>

❻ 關於ASP.NET中 Eval用法

先取得數據然後再substring 也就是<%# Eval("photoname").Substring(0,5)%>
或者直接在sql語句那控制 比如
select substring(ColumnA,0,5) from TableA ---------這是sqlserver的。。。