跳到主要內容

LINQ 讀取 DB Table 內容

LINQ 可用來讀取 Object 、 SQL 、 XML 等各種不同的資料種類, 這裡寫個範例介紹有關讀取 MSSQL 抓取 Table 欄位值的方法。

SQL: 

Table Name => TS_TestTable;

欄位內容如下前為欄位名,後面為型態:
ID:                  tinyint
Name:            string
Address:        string 

這裡要注意 Linq 對到 SQL 彼此之間對數值的型別轉換

 //  LINQ    SQL
 //  byte       tinint
 //  int32      int
 //  int16      smallint
 //  int64      bigint

C#:

using System.Data.Linq;
using System.Data.Linq.Mapping;
using System.Data;
using System.Linq;

[Table]
public class TS_TestTable    // C# 程式中先建立一個類Table 的類別
{
        [Column(IsPrimaryKey = true)]      //  可宣告此為唯一鍵值
        public byte ID;

        [Column]
        public string Name;

        [Column]
        public string Address;
}

// 透過物件類別建立來連接 DB 及 取得 Table< >
public class CTableClass: DataContext
{
        public CTableClass(string strConnect) : base(strConnect) { }
        public Table<TS_TestTable> TS_TestTables;
}

  try
  {
           // 連接資料庫字串(包括 DBName 、Password )
string connectionString = @"Data Source=TEST_DB;Initial Catalog=TSDATA;Persist Security Info=True;User ID=UU;Password=XX;"  

          CCategory ccategory = new CCategory(connectionString);

          var rows = from row in ccategory.TS_TestTables  select row;

         foreach (var cc in rows)
         {
              Console.Write("ID: cc.ID.ToString() + "Name:" +  cc.Name +  "Address:" = cc.Address);
          }
   }
   catch(Exception ex)
   {
        Console.Write("Error ==>" + ex.Message);
        return;
   }




留言

這個網誌中的熱門文章

C# 中 List 複製內容到另一個 List 的幾種方法

簡單又實用 ^ ^ * 第一種透過 .ToList( ) 方法:  List<string> List1 = new List<string>();  List<string> List2 = new List<string>();  List1.Add("A");  List1.Add("B");  List1.Add("C");  List1.Add("D"); List2 = List1.ToList( ); * 第二種方式在建立物件時複製前一個 List  List<string> List1 = new List<string>();  List1.Add("A");  List1.Add("B");  List1.Add("C");  List1.Add("D"); List<string> List2 = new List<string>(List1); * 第三種方法新的List 中使用 AddRange( ) 方法  List<string> List1 = new List<string>();  List<string> List2 = new List<string>();  List1.Add("A");  List1.Add("B");  List1.Add("C");  List1.Add("D"); List2.AddRange(List1); 另可使用 List1.GetRange(Start, End) 來複製不固定大小(但不包含End)的內容

無效的回傳或回呼引數。已在組態中使用 或在網頁中使用 <%@ Page EnableEventValidation="true" %> 啟用事件驗證

寫手機網頁 使用 Client 端的 jquery mobile 時 button 都會比較長,但改用 asp::Button 時發現按鈕大小卻變了,W3C 建議使用 jquery mobile Button 時,儘量使用<a href="#" data-role="button" > ,因此改用 asp::LinkButton 後果然解決了 Button 長度問題,只可惜按下去後,依然有點淚流滿面如下。後來拜求 google 大大,找到了原因及解法如下: 開啓了資料回傳安全驗證功能(EnableEventValidation 為 true),導致錯誤訊息產生。如果必須要驗證資料,則必須使用 ClientScriptManager.RegisterForEventValidation 註冊控制項或直接在頁面.aspx上端 <%Page ... EnableEventValidation = "false"> ,那如果全部頁面都不想驗證,那請在 web.config 下找到 <configuration>      <system.web>       <pages  enableEventValidation ="false" >        ....       </page>       .... </configuration> 嗯  博大精深  ^^ 收工回家去............................

JQUERY 中使用 val( ) 或 text( ) 來改變內容

就字眼看來兩者差別不太... 簡單的說 TextBox 利用 val( ),而其它的控制項元件則用 text( ) 底下範例可跑跑看或ID 對調實驗,很快就看出差別了... HTML: <input type="text" id="txtinupt" value="TEXTBOX"/> <label id="lblid">LABEL</label> <button onclick="TestFunc()">OK</button> JS: function TestFunc(){   $('#lblid').text("12345")   $('#txtinput').val("99999");   $('#lblid').focus();   console.log('Function End') }