文章分類

C# (27) ASP.NET (13) SQL (7) ORACLE (5) JAVA (2) SQLSERVER2008 (2) 大家都在問的事 (2) ACCESS (1) ANDRIOD (1) JQUERY (1) python (1) 雜談 (1)

關於我自己

我的相片
程式初心者 JAVA, ASP.NET, C# ,SQL

2011年11月30日 星期三

【C#】使用ORACLE兩種寫SQL傳參數的方法

1.使用string.format方法

#region 寫法1
    DataTable ddt = new DataTable();
    string ss = string.Format("SELECT * FROM  UI_USER_GROUP WHERE USER_NAME='{1}'", "SHENG");
    //{1}表示逗號後的第一個引數,{2}可以表示為逗號後第二個引數,以此類推

            ddt = ExcuteForQuery(ss);
            if (ddt.Rows.Count > 0)
            {
                MsgBox("大於0");//自訂messagebox方法

            }
            else { MsgBox("等於0"); }
#endregion

ExcuteForQuery方法
public DataTable ExcuteForQuery(string sql)
{
    DT = new DataTable();//建立datatable接收query的資料
   using (OracleConnection conn = new OracleConnection("Data Source=orcl;User=SHENG;Password=1234"))
//建立連線物件aaa, Data Source=IP/DB_NAME;User=XXXX;Password=XXXX
      {
                conn.Open();//開始連線
                //建立od物件接收select結果
                OracleDataAdapter OD = new OracleDataAdapter(sql, conn);

                OD.Fill(DT);
                //指定datagridview的datasource

                conn.Close();//結束連線
            }
            return DT;
        }

2.使用command的物件
#region 寫法2
            DataTable ddt2 = new DataTable();
            
            string l_strExeSQL = "SELECT * FROM UI_USER_GROUP WHERE USER_NAME = :USERNAME";
            OracleCommand g_scSql = new OracleCommand(l_strExeSQL);
            g_scSql.Parameters.Add("USERNAME", OracleType.VarChar).Value = "SHENG";
            ddt2 = ExcuteForQuery(g_scSql);
            if (ddt2.Rows.Count > 0)
            {
                MsgBox("大於0");//自訂messagebox方法

            }
            else { MsgBox("等於0"); }
            #endregion


ExcuteForQuery方法
public DataTable ExcuteForQuery(OracleCommand o_cmd)
        {
            DT = new DataTable();//建立datatable接收query的資料
            using (OracleConnection conn = new OracleConnection("Data Source=orcl;User=SHENG;Password=1234"))//建立連線物件aaa, Data Source=IP/DB_NAME;User=XXXX;Password=XXXX
            {
               
                conn.Open();//開始連線
                o_cmd.Connection = conn;
                //建立od物件接收select結果
                OracleDataAdapter OD = new OracleDataAdapter(o_cmd);

                OD.Fill(DT);
                //指定datagridview的datasource

                conn.Close();//結束連線
            }
            return DT;
        }

【ASP.NET】自訂MESSAGEBOX方法

asp.net沒有messagebox.show可以用
不過沒關係, 可以自己寫一個
網路上看到一個vb版, 改成c#版分享給大家

public void MsgBox(string Message)
{
    string sScript = null;
    string sMessage = null;

    sMessage = Message.Replace("'", "\'");
    //處理單引號
    sMessage = sMessage.Replace(Environment.NewLine, "\\n");
    //處理換行
    sScript = string.Format("alert('{0}');", sMessage);
    ScriptManager.RegisterStartupScript(this, this.GetType(), "alert", sScript, true);
}

2011年11月24日 星期四

【ASP.NET】存取LOGINVIEW內的物件

將LOGIN物件放進LOGINVIEW後,在.CS檔內就存取不到Login的物件
要存取的話的話要使用以下的方式來存取

Login aa = (Login)LoginView1.FindControl("Login1");
string Username=aa.UserName;
string UserPassWord=aa.Password;

2011年10月27日 星期四

【JAVA】連線ORACLE資料庫

先下載ODBC.JAR, 並安裝它
1.IMPORT以下幾個API
import java.sql.*;
import javax.sql.*;
import oracle.jdbc.driver.*;
import oracle.jdbc.pool.*;
2.程式碼範例
public void oracle_connect() throws SQLException {

Connection conn=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl","SHENG","1234");
Statement st=conn.createStatement();

String str="Select * FROM TEST_TABLE";
ResultSet rs=st.executeQuery(str);//執行sql並將結果丟至ResultSet接收

ResultSetMetaData rsmd = rs.getMetaData();//取得欄位控制項
String str2="";
while(rs.next())//一列一列讀取傳回值
{
int Ccount=  rsmd.getColumnCount();//取得欄位總數
for(int i=1;i<=Ccount;i++)//第幾欄從1開始算
            {
               str2+= rs.getString(i);//取得內容值
               str2+="\r\n";//換行
            }
             
         }
    JOptionPane.showMessageDialog(null, str2);//顯示MESSAGEBOX
    }
3.執行結果

2011年10月25日 星期二

【SAP】NETWEAVER簡介

我為大家先簡單的介紹一下SAP NetWeaver和企業級的面向服務的架構(Enterprise SOA)。
NetWeaver是 SAP的產品,它本身是SAP現在的企業應用軟件的底層技術平台,即SAP所有新的應用跑在一個相當於在系統之上的、類似於中間件的支持平台。 SAP在2004年正式推出NetWeaver這個產品。 在此之後SAP所有的新的產品都是跑在NetWeaver這個平台之上的, 這個平台也可單獨採購。
NetWeaver為 SAP所有的企業應用提供了一個公共的、基礎的平台,包括提供了Web應用服務器的支持、數據的存取和各種系統之間的功能等。NetWeaver還提供了 許多企業級功能,包括了在人員方面、信息方面、流程方面提供集成服務,這是由很多諸如交換架構XI、主數據管理MDM等組件組成的。 NetWeaver把企業應用最常用的IT需求都定製化成產品,提供相關的功能。NetWeaver還提供了各種相應的基於Java和ABAP的開放的軟 件開發環境和工具。
這就是SAP NetWeaver這個產品,是目前支持所有SAP應用的基礎產品,是最好的企業應用軟件的開發平台、同時又為企業搭建一個基於NetWeaver的面向服務的IT架構。

企業級的面向服務的架構(Enterprise SOA),又可簡稱作企業服務架構。 大家在主題演講中已經聽過介紹,我想再通過比較的方式講一講我們的Enterprise SOA是什麼,和其他廠商談的SOA區別在哪裡。
SOA這 個概念大家聽的比較熟了,是面向服務的架構,實際上它的背景是基於最新的互聯網的技術,把各種應用都做成Web Service,做成網上服務。 這些服務可以分散在互聯網的不同地方,調動這些服務來實現IT的功能。 SOA這個概念雖然推出一段時間了,不過其他廠商通常談的是IT底層基礎架構,是一個網絡的技術名詞。
SAP企 業服務架構增加了豐富的、實質性的內容。SAP把我們從1972年開始34年在企業應用方面的全部積累和豐富的業務知識,做成企業服務 (Enterprise Service),成為企業服務架構的基礎。 基於但不止於SOA, SAP在企業應用這個環境, 以NetWeaver為基礎,加上企業服務庫,加上復合應用組合成業務流程平台(Business Process Platform), 成為第一家和唯一一家實現了企業服務架構的軟件供應商。SAP使SOA從理念性、技術性的東西變成在企業層面、在現實IT中確實被使用的東西。 它的背後體現在SAP將近上萬名工程技術人員花了兩三年的時間,把我們的在各個行業都佔據領先地位的ERP、CRM、SRM等企業應用都在這企業服務架構 基礎上重新改寫。與之相比,我們的競爭對手雖然隨後也匆忙提出了類似的規劃,但其實施和退出還需要約二年的時間。
企業服務架構的推出在業界產生了廣泛深遠的影響,特別是在比較發達國家IT業 形成一股旋風,大家對此刮目相看。分析家評論說據此企業應用將進入一個新的發展時期,企業服務架構將成為下一階段主要軟件公司競爭的焦點,誰要是在這上面 佔據領先地位就有可能成為下一代軟件業的霸主。所以我才戲說用三國來形容SOA是軟件業競爭的荊州。這是關於企業服務架構Enterprise SOA的概念。
企業服務架構的意義是非常重要的。 現在我們把它推出來,一方面是SAP用 它來搭建我們自己的軟件,一方面是要建立一個生態圈,客戶可以在這之上,在同一個平台上共享很多組件,靈活地搭建企業應用,獨立軟件開發商可以成為SAP 的合作夥伴,也做同樣的事情。這樣可以形成非常高效、非常有活力的生態圈。 這樣就解決了企業IT管理上的長期難題,到底是自主開發軟件還是買現成的軟件。 以前一旦選擇朝東走就很難朝西走了, 而現在不需要做一個選擇了,魚和熊掌可以兼得了。現在在同樣一個平台上有可能儘量採用各種商業用的軟件,又同時為自己開發或者是採用其他獨立軟件商的軟 件。從這個意義來講軟件業確實進入了新的時代,這也是我們在今天向中國軟件業隆重推介NetWeaver平台,進一步闡述企業服務架構的意義所在。
我給大家講一個我的觀察。 大概在半年前,當我到國外出差收集一些有關資料時,發現在那個時候可能有幾本SOA的 書,在闡述在技術底層SOA是怎麼回事、Web Service怎麼用等等, 但是基本上沒有人談Enterprise SOA。 一個月之前我再去新加坡的書店,突然發現在國外已經有了五本書,它的名字裡全都有Enterprise SOA。後來我發現有兩本書在中國已經翻譯準備出版了。從去年開始我們開始著重講企業服務架構Enterprise SOA,其後迅速成為業界大家關注的焦點。這五本書裡有兩本是與SAP有關的人員寫的,其他幾本並不是SAP的人寫的,而是其他軟件從業人員看到了企業服 務架構帶來的衝擊寫了這些書, 我想很快會有更多的書問世。 我想用這個故事跟大家分享一下企業服務架構的快速發展以及可能帶來的影響。
最後我給大家介紹一下SAP產品進展的情況。
首先按照我們的技術路線圖,SAP各 個方面的產品都在不斷地前進,在過去半年中,我們推出了好幾個新產品,我們推出了在線的客戶關係管理(CRM On Demand),又和微軟合作推出DUET(二重奏)產品。 二重奏是把SAP後台企業應用的數據通過微軟的辦公環境展現給業務用戶,這個產品是今年5月份推出的。
除此之外,SAP於 8月份正式推出了基於企業服務架構復合應用的企業分析軟件(xApp Analytics)。 這類軟件的功能是把信息交給業務用戶,讓信息能夠直接為企業的經營、運營、決策做支持的軟件,傳統上屬於商務智能(BI)的範疇。但是我們提供的這類復合 應用分析軟件,它和別的傳統商務智能軟件不同點在於我們的分析軟件是內嵌在業務流程內的,可以直接影響業務流程,不是說事後看一看這些數,而是這些數直接 在過程中可以直接影響控制你的業務流程。這些都是相當有意義的發展。
企業應用是軟件類非常大的門類,對整個行業有深遠的影響。最近SAP已 包裝了500個高端的企業服務Enterprises Service,如財務服務、人力資源的服務。以後客戶可以直接調用這些包裝好的服務,客戶和其他廠商也可以調用這些服務。剛才我和祥麟在講,一個非常恰 當的比喻是將軟件的企業服務架構化類比於電路的集成化。集成塊(IC)本身也是功能模塊化設計的,但它是更複雜電路的基本組件。集成電路的出現從根本上改 變了電子行業。設計一個個的集成塊,把他們組成電子設備,而不是再從電阻、電容、電感、晶體管等基本元件來組建電路。以後軟件業的工作就是要設計這些「集 成塊」和利用這些「集成塊」,這些「集成塊」就是企業服務(Enterprise Service)。 老的軟件行業正在合併和兼併中死去,一個基於企業服務架構的新的軟件行業正在誕生中。

2011年9月28日 星期三

【C#】傳值呼叫與傳祉呼叫使用時機

傳祉呼叫寫法 
CallRef(ref a, ref b);
public void CallRef(ref int a, ref int b) {
...
}
 
傳值呼叫寫法 
CallRef( a, b);
 
public void  CallRef( int a,  int b) {
...
}
 
應用面: 
寫法很簡單, 但是時機呢?什麼時候該用傳值或傳祉
 
1.當呼叫的方法是處理原本主程式中的參數時
使用傳值的話,不會改變原本的a,與b的數值, 
 如下列,在呼叫CallRef後還是a=10,b=10
ex:
 
int a =10,b=10;
CallRef( a, b); 
 
public void  CallRef( int a,  int b) 
{
  a=a+b;
  b=b+a; 
}
 








若使用傳祉,則呼叫CallRef後是a=20,b=20
 ex:
 
int a =10,b=10;
CallRef(ref a,ref b);

public void  CallRef(ref int a, ref int b) 
{
  a=a+b;
  b=b+a; }
 
 
2.但是如果你呼叫的方法傳入的參數,和回傳的東西
是兩種不一樣的東西, 傳值傳祉都可以,但傳祉似乎會好一點
 public Datatable  CallRef( string SQL_CMD) { 
...
 DataTable DT=null;
return DT://傳回的為DataTable物件
}
 
string sql_cmd="SELECT * FROM MAIN";


DataTable dt=CallRef(sql_cmd);//傳入的參數為STRING 
 
還有人想到什麼可以補充的嘛

2011年9月15日 星期四

【JAVA】使用NETBEAN開發ANDRIOD APP(轉貼)

http://job.achi.idv.tw/2009/11/17/%E4%BB%8B%E7%B4%B9netbeans%E4%B8%8B%E7%9A%84android%E9%96%8B%E7%99%BC/

2011年9月14日 星期三

【ASP.NET】設定GRIDVIEW欄位與置中

'設定欄位寬度
        GridView1.Columns[0].ItemStyle.Width = 80;
GridView1.Columns[0].ControlStyle.Width = 80;
 
'設定文字置中
         GridView1.Columns[0].ItemStyle.HorizontalAlign = HorizontalAlign.Center;
 
ItemStyle.Width:普通模式欄位寬度
ControlStyle.Width :編輯模式欄位寬度

設定後結果:
2010-02-25_205627  

2011年9月13日 星期二

【ASP.NET】動態產生TREEVIEW


NoteId:節點代碼
ParnetId:父層節點代碼
sText:節點的Text
sValue:節點的Value
sURL:超鏈結
sTarget:超鏈結Target
updateName:資料修改者
updateTime:資料修改時間
//初始化
    protected void InitTree()
    {
        TreeView Tree1 = new TreeView();
        TreeNode tmpNode = new TreeNode();
        tmpNode.Text = "首頁";
        tmpNode.Value = "0";
        tmpNode.NavigateUrl = "http://www.yahoo.com.tw";
        tmpNode.Target = "_Top";
        Tree1.Nodes.Add(tmpNode);
        Session["Tree1"] = Tree1;
    }
   
//建立Tree
protected void BuildTree()
    {
        TreeView Tree1 = new TreeView();
        if (Session["Tree1"] == null)
        {
            InitTree();
        }
        Tree1 = (TreeView)Session["Tree1"];
        TreeNode RootNode;
        RootNode = Tree1.Nodes[0];
        string rc;
        rc = AddNodes(RootNode, 0);
        Session["Tree1"] = Tree1;
               
    }
    protected void GetDataTable()
    {
        string ConnStr;
        SqlConnection Conn;
        SqlDataAdapter Da;
        DataSet Ds;
        DataTable dt;
        string sqlTxt;
        try
        {
            //取得web.config的連線字串
            ConnStr = System.Web.Configuration.WebConfigurationManager.ConnectionStrings["ConnString"].ToString();
            Conn = new SqlConnection(ConnStr);
            Conn.Open();
            sqlTxt = "Select * from tb_TreeView ";
            Da = new SqlDataAdapter(sqlTxt, Conn);
            Ds = new DataSet();
            Da.Fill(Ds);
            dt = new DataTable();
            dt = Ds.Tables[0];
            Session["dt"] = dt;
            Conn.Close();
        }
        catch (Exception ex)
        {
            this.Label1.Text = ex.Message.ToString();
        }

    }
    protected string  AddNodes(TreeNode tNode, decimal PID)
    {
        try
        {
            if (Session["dt"] == null)
            {
                GetDataTable();
            }
            DataTable dt;
            dt = (DataTable)Session["dt"];
            DataRow[] rows;
            string filterExpr;
            filterExpr = "ParentId =" + PID;
            rows = dt.Select(filterExpr);
            if (rows.GetUpperBound(0) >=0)
            {
                DataRow row;
                decimal  tmpNodeId;
                string tmpsText;
                string tmpsValue;
                string tmpsUrl;
                string tmpsTarget;
                TreeNode NewNode;
                string rc;
                for (int i = 0; i < rows.Length ; i++)
                {
                    row = rows[i];
                    tmpNodeId = (decimal)row[0];
                    tmpsText = (string)row[2];
                    tmpsValue = (string)row[3];
                    tmpsUrl = (string)row[4];
                    tmpsTarget = (string)row[5];
                    NewNode = new TreeNode();
                    NewNode.Text = tmpsText;
                    NewNode.Value = tmpsText;
                    NewNode.NavigateUrl = tmpsUrl;
                    NewNode.Target = tmpsTarget;
                    tNode.ChildNodes.Add(NewNode);
                    rc = AddNodes(NewNode,tmpNodeId);
                                     
                }
            }
            return "Success";
        }
        catch(Exception ex)
        {
            this.Label1.Text = ex.Message.ToString();
            return "False";
        }
    }
    protected void Page_Load(object sender, EventArgs e)
    {
         if (Session["Tree1"] == null)
            {
                InitTree();
                BuildTree();
            }
            TreeView Tree1;
            Tree1 = (TreeView)Session["Tree1"];
            Tree1.ImageSet = TreeViewImageSet.XPFileExplorer;
            this.PlaceHolder1.Controls.Add(Tree1);      

    }



轉載自 :http://tw.myblog.yahoo.com/jw!Iki8rGaBGAJfeU4uFKvazeLG8Mo-/article?mid=158&prev=184&next=52&l=f&fid=16&sc=1

2011年9月12日 星期一

【SQL2008】打開遠端連接

1. 執行「開始」\「所有程式」\「Microsoft SQL Server 2008」\「組態工具」\「SQL Server 組態管理員」。
2. 在「SQL Server Configuration Manager」視窗,執行以下的選項:
在左邊窗格,點選「SQL Server 網路組態」。
點選「SQLEXPRESS 的通訊協定」。

01_選擇「SQL Server 網路組態」
在右邊的窗格,在「通訊協定名稱」方塊下,選擇「TCP/IP」。
滑鼠右鍵,選擇「啟用」。

02_啟用 TCPIP
在「警告」視窗,點選「確定」。
03_警告視窗
3. 重新啟動 SQL Server。
工作2. 啟動「SQL Server Browser」服務
1. 在「SQL Server Configuration Manager」視窗,執行以下的選項:
在左邊窗格,點選「SQL Server 服務」。
在右邊窗格,點選「SQL Server Browser」。
滑鼠右鍵,選擇「啟動」。

建議,可以設定「SQL Server Browser」服務為「自動」啟動模式。
 4. 如果還是有問題, 則記得將防火強打開1433PORT



轉載自:http://sharedderrick.blogspot.com/2009/05/sql-server-2008-express-enable-remote.html

【SQLSERVER2008】18456登入失敗

網路解1.SA密碼設太短,改密碼

網路解2.




2.切換驗證模式後按確定, 服務重啓SQLSERVER_EXPRESS

2011年9月4日 星期日

【ASP.NET】DROPLIST加入新項目KEY VALUE

 System.Web.UI.WebControls.ListItem test =
 new System.Web.UI.WebControls.ListItem("Key", "Value");

  DropDownList1.Items.Add(test);

2011年9月1日 星期四

[ASP.NET] 頁面跳轉中傳值

Default1.aspx中拉一個TextBox1與Button1
在Button1 Click的事件中這樣寫

       Response.Redirect("Default2.aspx?id="+this.TextBox1.Text);

這樣子就能在網祉中傳值

在Default2.aspx中拉一個TextBox1來接值
寫在Form_Load事件裡
   this.TextBox1.Text = Request["id"];

就結束了, 超簡單入門

2011年8月25日 星期四

【C#】刪除ACCESS資料列後, ACCESS容量太大

因為從C#內刪除資料後, 只是暫時的刪除, 所以你會看到一個什麼資料都沒有的DB還有100多MB的大小..所以DELETE後要從程式中再進行處理

首先先引用

using System.IO;
using JRO;
接下來在程式裡撰寫以下程式



 string mdbPath = "C:\\DB_EQP.mdb";//資料庫路徑
 if( !File.Exists(mdbPath) ) //检查数据库是否已存在
{
throw new Exception("資料庫不存在,無法壓縮");
}
//定義臨資料庫名稱
string temp = DateTime.Now.ToString("HH:mm:ss") + ".bak";
 temp = temp.Split(':')[0].ToString() + temp.Split(':')[1].ToString() + temp.Split(':')[2].ToString();
temp = mdbPath.Substring(0, mdbPath.LastIndexOf("\\")+1) + temp;
//定義臨時資料庫路徑連接字串
string temp2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + temp;
//定義目標資料庫路徑連接字串
string mdbPath2 = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + mdbPath;
//新增一個JetEngineClass物件
JRO.JetEngineClass jt = new JRO.JetEngineClass();
//使用JetEngineClass物件的CompactDatabase方法壓縮資料庫
          
jt.CompactDatabase( mdbPath2, temp2 );
//覆蓋原本資料庫
File.Copy( temp, mdbPath, true );
//刪除臨時資料庫
File.Delete( temp );

2011年8月9日 星期二

[C#]開啟EXE檔並輸入EXE檔的參數

先USING System.Diagnostics;

在程式裡放入下列程式
System.Diagnostics.Process.Start("路徑", "參數");

2011年8月2日 星期二

2011年7月26日 星期二

[C#]checkedListBox 範例


1.
添加項目

checkedListBox1.Items.Add("
藍色");
checkedListBox1.Items.Add("
紅色");
checkedListBox1.Items.Add("
黃色");
2.
判斷第i項是否選中,選中為true,否則為false

if
checkedListBox1.GetItemChecked(i)
{
     return true;
}
else
{
     return false;
}
3.
設置第i項是否選中
checkedListBox1.SetItemChecked(i, true); //true改為false為沒有選中。

4.
設置全選
添加一個名為select_allcheckbox控制項,由其控制checkedListBox是全選還是全不選。
private void select_all_CheckedChanged(object sender, EventArgs e)
{
     if(select_all.Checked)
{
          for (int j = 0; j < checkedListBox1.Items.Count; j++)
               checkedListBox1.SetItemChecked(j, true);
}
else
{
for (int j =0; j < checkedListBox1.Items.Count; j++)
      checkedListBox1.SetItemChecked(j, false);
}
}

5.
得到全部選中的值 ,並將選中的項的文字組合成為一個字串。

string strCollected = string.Empty;
for (int i = 0; i < checkedListBox1.Items.Count; i++)
{
      if (checkedListBox1.GetItemChecked(i))
      {
          if (strCollected == string.Empty)
          {
               strCollected = checkedListBox1.GetItemText(
checkedListBox1.Items[i]);
          }
          else
          {
               strCollected = strCollected + "/" + checkedListBox1.
GetItemText(checkedListBox1.Items[i]);
           }
       }
}
6.
設置CheckedListBox中第i項的Checked狀態
checkedListBox1.SetItemCheckState(i, CheckState.Checked);
7.
private void checkBoxAll_CheckedChanged(object sender, EventArgs e)
{
     if (checkBoxAll.Checked)
     {
         //
被選擇了則將CheckedListBox中的所有條目都變為Checked狀態
         for (int i = 0; i < checkedListBoxLayerControl.Items.Count;
                  i++)
         {    
checkedListBoxLayerControl.SetItemCheckState(i,
        CheckState.Checked);
}
}
else
{
     //
否則變成Unchecked狀態
    for (int i = 0;
i < checkedListBoxLayerControl.Items.Count; i++)
{
checkedListBoxLayerControl.SetItemCheckState(i, CheckState.Unchecked);
}             
}
}
8.
checkedListBox
單選設置(代碼實現)

private void chkl_ItemAuditing_ItemCheck(object sender,  
ItemCheckEventArgs e)
{
     if (chkl_ItemAuditing.CheckedItems.Count > 0)
    {
         for (int i = 0; i < chkl_ItemAuditing.Items.Count; i++)
         {
if (i != e.Index)
{
this.chkl_ItemAuditing.SetItemCheckState(i,
System.Windows.Forms.CheckState.Unchecked);
}
}
}
}
9.
checkedListBox1
顯示一個資料庫中關鍵字對應的所有記錄

for (int i = 0; i < table.Rows.Count; i++)
{
    string name = table.Rows["myname"].ToString();
    string paw = table.Rows["mypaw"].ToString();
    checkedListBox1.Items.Add(name + paw);
}

10.
for(i=0;i<CheckedListBox.Items.Count;i++)  
{  
   if(CheckedListBox.GetItemText(
CheckedListBox.Items)=="你得到的值")  
{  
      CheckedListBox.SetItemChecked(i,true);  
}  
}

11.
清除checkedListBox1中所有的選項

for (int i = 0; i < checkedListBox1.Items.Count; i++)
{
    checkedListBox1.Items.Clear();
}
12.
//設置索引為index的項為選中狀態

for (int i = 0; i < checkedListBox1.Items.Count; i++)
{
    checkedListBox1.SetItemChecked(i, true);
}

13.  
for (int i = 0; i < checkedListBox1.Items.Count; i++)
{
if (checkedListBox1.GetSelected(i))
{
MessageBox.Show(checkedListBox1.CheckedItems.ToString());
}
}

14.
//選中checkedListBox1所有的選項

for (int i = 0; i < checkedListBox1.Items.Count; i++)        
{
checkedListBox1.SetItemCheckState(i, CheckState.Checked);
}

15.            
for (int i = 0; i < checkedListBox1.Items.Count; i++)
{
//如果checkedListBox1的第i項被選中,
//則顯示checkedListBox1對應的值
if (checkedListBox1.GetItemChecked(i))
{
     MessageBox.Show(checkedListBox1.Items.ToString());
}
}

16.
//反向選擇checkedListBox1的選項

for (int i = 0; i < checkedListBox1.Items.Count; i++)
{
    if (checkedListBox1.GetItemChecked(i))
   {
       checkedListBox1.SetItemChecked(i, false);
   }
   else
   {
       checkedListBox1.SetItemChecked(i, true);
   }
}
17.
//checkedListBox1中選定的項->checkedListBox2

for (int i = 0; i < checkedListBox1.CheckedItems.Count; i++)
{
     checkedListBox2.Items.Add(this.checkedListBox1.CheckedItems);

//remove
是除去一個具體的值,不是index,注意了
     this.checkedListBox1.Items.Remove(
         this.checkedListBox1.CheckedItems);      
}
18.
CheckedlistBox控制項比較有用到兩個屬性分別為CheckOnClickTrue:表示單擊就選中當前行,為False:要點兩下才 可以選中。(預設值為False)。還有一個屬性為ThreeDCheckBoxesTrue:表示三維的選中標記,為False:表示表面的顯示標 記。(預設值為False)
19.
for (int i = 0; i < checkedListBox1.Items.Count; i++)
            {
                if (checkedListBox1.GetItemChecked(i))
                {
                    checkedListBox1.SelectedIndex = i;//
利用SelectedValue取得Value值時,只能取得當前焦點項的值。所以要對整個CheckedListBox中的所有勾選項,讓其都 做一次焦點項才能取得所有勾選的項的值。
                    str+= checkedListBox1.SelectedValue;
                }
            }
20.綁定數據
checkedListBox1.DataSource = dt;
checkedListBox1.DisplayMember = "item";
checkedListBox1.ValueMember = "code";

2011年7月25日 星期一

[C#]button.PerformClick() 失效

PerformClick()
呼叫這個方法, 可以不用點擊BUTTON就執行寫在BUTTON內的程式碼。

但今天早上一進公司就遇到一個BUG, 不管我怎麼呼叫這個方法都沒有反應,

後來總算找到了, 原來是我把BUTTON的ENABLE屬性設成FALSE, 只要設成FALSE,

再呼叫PerformClick(),等同於沒有點擊按鈕的意思,找這個BUG找了我一小時= =...

2011年7月21日 星期四

[ORACLE]建資料表時使用自動編號

ORACLE 並沒有像ACCESS和MS-SQL等資料庫有提供自動編號功能,
讓習慣用流水號當主鍵的我覺得十分不習習慣
爬了文發現了其實可以用別的方式來達成
在ORACLE裡下以下的語法

    CREATE SEQUENCE MySEQUENCE
    INCREMENT BY 1  -- 每次加幾個
    START WITH 1    -- 從1開始計數
    NOMAXVALUE      -- 不設置最大值
    NOCYCLE         -- 一直累加,不循環
    CACHE 10;

或自行定義最大最小值

CREATE SEQUENCE MySEQUENCE
MINVALUE 1                        --最小值
MAXVALUE 10000000      -最大值
START WITH 1                     -- 從1開始計數
INCREMENT BY 1               -每次加1
NOCACHE







接下來只要帶INSERT SQL時動手腳就好了,就可以自動編號了!

INSERT INTO emp VALUES 
(MySEQUENCE.nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20);

2011年7月20日 星期三

[C#]移除字串最後一個字元

 string op="01234";

 op= op.Substring(0, op.Length - 2);

Messagebox.show(op);

結果==>012

2011年7月19日 星期二

[C#]DATAGRIDVIEW--CHECKBOX取消勾選

在DATAGRIDVIEW內的CHECKBOX勾選時取消勾選
1.在DATAGRIDVIEW上加入兩個事件
    CellValueChanged以及CurrentCellDirtyStateChanged

2. 在CurrentCellDirtyStateChanged裡加入以下程式碼
            if (this.dataGridView1.IsCurrentCellDirty) //有未提交的更//改
            {
                this.dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit);
            }
           
3. 在CellValueChanged事件里加入以下程式碼

   DataGridViewCheckBoxCell dgvCheckBoxCell = null;
            if (this.dataGridView1.Columns[e.ColumnIndex].Name.Equals("選取"))
            //我的CHECKBOX欄位名稱為選取
            {
                dgvCheckBoxCell = this.dataGridView1.Rows[e.RowIndex].Cells[e.ColumnIndex] as DataGridViewCheckBoxCell;/取得checkbox的ROW欄位
            }

 if (dgvCheckBoxCell.Value.ToString() == "True")
//以下程式碼會將CHECKBOX從勾選變成未勾選
            {               
                     DataGridViewCheckBoxCell cell = dataGridView1.Rows[e.RowIndex].Cells["選取"]  as DataGridViewCheckBoxCell;
                     cell.EditingCellFormattedValue = false;
                     cell.EditingCellValueChanged = true;
                     cell.Value = cell.EditingCellFormattedValue;
                     return;                
                 }

[C#]執行緒寫log錯誤

寫程式難免要寫LOG檔來紀錄一些ERROR或流程
但是如果寫在多執行緒裡面的時候, 就會造成兩隻執行緒同時開啟同一個檔案的困境
程式會因為這樣子死掉, 爬了一下文, C#裡有內鍵LOCK這個東西, 來確保, 同時只能有一支程式
來讀寫文字檔寫入LOG

範列如下:

static object lockMe = new object();
public static void WriteLog(string sErrMsg) 
{
lock (lockMe) 
{
using (StreamWriter sw = 
new StreamWriter(pathName + sErrorTime + extName, true)) 
{
sw.WriteLine(sErrMsg);
sw.Close();
}
}
}

2011年7月18日 星期一

[C#] 好用的BACKGROUNDWORKER

C#裡面可以執行背景程式的元件, 可以當作多執行緒使用(看有幾隻要RUN就建幾個)
相當的EASY直覺化的元件。

步驟1.拉出一個BACKGROUNDWORKER到你的FORM上
步驟2.在BACKGROUNDWORKER上按右鍵=>屬性, 切換事件頁, 新增兩個事件Dowork以及RunWorkerCompleted
步驟3.加入一個class, 裡面置放你所需要執行的背景程式

class FUNCTION
{
public int ADDNUM(int x )
{
X=X+1;
return X;
}
}
步驟4.在Dowork的事件裡新增以下程式碼

private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
//執行FUNCTION
FUNCTION fn= (FUNCTION)e.Argument;

e.Result = fn.ADDNUM(this.x);

}

步驟5.在RunWorkerCompleted事件裡增加以下程式碼
private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{ //當作業完成後要做的事放這裡
int value = (int)e.Result;//取得函數回傳值
Messagebox.Show(value.Tostring());
}
步驟6.在需要開始執行背景程式的地方, 加入以下的程式碼
FUNCTION fn= new FUNCTION();
backgroundWorker_1.RunWorkerAsync(fn);
步驟7. ENJOY

2011年4月12日 星期二

【C# 】字串處理

顧名思意,String 類別就是來處理字串的應用
它提供了一堆靜態方法 (Static Method) 來處理字串相關
以下介紹一些平時很實用的功能

字串的比較
Compare 方法會回傳整數值,來表示兩個字串的關聯性
正數表示第一個字串大於第二個字串
負數表示第一個字串小於第二的字串
零值表示兩個字串相等
string.Compare("字串", "測試"); // result = -1
string.Compare("字串測試", "字串測試"); // result = 0
string.Compare("字串", "測試"); // result = -1
string.Compare("字串測試", "字串測試"); // result = 0


字串中搜尋字元或子字串
當我們必須想知道某字串中是否有特定字串或字元時
可以使用 String 類別的 IndexOf 方法來傳回特定字串 (字元) 在字串中的索引位置
另外,我們也可以利用 LastIndexOf 方法於字串中從後往前找到特定字串並回傳索引位置
PS. 索引位置由 0 開始
PS. 在 .NET Framework 下每個中文字都算一字元,而不再是 ASCII 時代的兩字元了
PS. LastIndexOf 方法和 IndexOf 一樣回傳索引位置,一樣搜尋特定字串,只不過 IndexOf 方法是由前往後找,但 LastIndexOf 方法是由後往前找
"字串測試字串測試".IndexOf("串"); // result = 1
"字串測試字串測試".IndexOf("串測"); // result = 1
"字串測試字串測試".LastIndexOf("串測"); // result = 5
"字串測試字串測試".IndexOf("串"); // result = 1
"字串測試字串測試".IndexOf("串測"); // result = 1
"字串測試字串測試".LastIndexOf("串測"); // result = 5


字串轉換大小寫
ToUpper 及 ToLower 方法可以將字串全部轉換成大寫或小寫
並將結果回傳成新的字串
"abcdABCD".ToUpper(); // result = "ABCDABCD"
"abcdABCD".ToLower(); // result = "abcdabcd"
"abcdABCD".ToUpper(); // result = "ABCDABCD"
"abcdABCD".ToLower(); // result = "abcdabcd"


去除或添加字串前後空白字元或特定字元
我們可以用 Trim 方法去除字串前後的空白字元
而 TrimStart 及 TrimEnd 可以只移除前後的空白字元
另外 Trim, TrimStart, TrimEnd 方法除了可以移除空白字元外,還可以移除一個或多個字元
"字字串串測測試試".Trim("字試".ToCharArray()); // result = "串串測測"
"字串測試".Trim("串字試".ToCharArray()); // result = "測"
"字串測試".TrimStart(new char[] { '試', '字', '串' }); // result = "測試"
"字串測試".TrimEnd("串試字".ToCharArray()); // result = "字串測"
"字字串串測測試試".Trim("字試".ToCharArray()); // result = "串串測測"
"字串測試".Trim("串字試".ToCharArray()); // result = "測"
"字串測試".TrimStart(new char[] { '試', '字', '串' }); // result = "測試"
"字串測試".TrimEnd("串試字".ToCharArray()); // result = "字串測"


字串前後添加空白字元或特定字元
PadLeft 及 PadRight 方法則和上例功能相反 - 將字串前後補上空白字元或特定字元
方法中第一個參數則是決定補上字元後的總長度
如果原字串就比第一個參數小了,則就不補上字元了
// 字串前補上 '@' 字元到長度 10
"字串測試".PadLeft(10, '@'); // result = "@@@@@@字串測試"
// 字串長度比 2 小,則不補上 '@' 字元
"字串測試".PadRight(2, '@'); // result = "字串測試"
// 字串前補上 '@' 字元到長度 10
"字串測試".PadLeft(10, '@'); // result = "@@@@@@字串測試"
// 字串長度比 2 小,則不補上 '@' 字元
"字串測試".PadRight(2, '@'); // result = "字串測試"


在字串中插入字串、移除字串和取代字串
我們可以用 Insert, Remove, Replace 來處理字串的插入、移除、取代
這三個方法用法還滿直覺簡單
PS. Remove 只可以移除指定位置的指定長度字串,而無法帶入要移除的字串
但是其實可以利用 Replace 來做指定字串的移除
"字串測試".Insert(2, "ABCD"); // result = "字串ABCD測試"
"字串測試".Remove(1, 2); // result = "字試"
"字串測試".Replace("串測", "ABCD"); // result = "字ABCD試"
"字串測試".Replace("串測", string.Empty); // result = "字試"
"字串測試".Insert(2, "ABCD"); // result = "字串ABCD測試"
"字串測試".Remove(1, 2); // result = "字試"
"字串測試".Replace("串測", "ABCD"); // result = "字ABCD試"
"字串測試".Replace("串測", string.Empty); // result = "字試"


串連字串陣列及分隔
這兩個方法 Join 及 Split 但很少人用但很實用
尤其是 join 方法,因為有許多組合方法可以取代它的功能
雖然 Join 其有所限制,如串連前必須得知所有的字串,而不能將字串持續串連下去
但其實在某些場合之下還滿好用的
PS. Join 方法遇到字串陣列中有空字串時,還是會串連進回傳的字串中
string.Join("+", new string[] { "一", "二", "三", "四", "五" }); // result = "一+二+三+四+五"
"一+二+三+四+五".Split("+"); // result = 字串陣列
string.Join("+", new string[] { "一", "二", "三", "四", "五" }); // result = "一+二+三+四+五"
"一+二+三+四+五".Split("+"); // result = 字串陣列


取得子字串
最後一個方法,也是很常用很實用的方法 - 取出子字串 Substring 方法
"字串測試".Substring(1, 2); // result = "串測"

2011年3月21日 星期一

datagridview的checkbox列,当修改checkbox状态时实时获得其状态值

datagridview的checkbox列,当修改checkbox状态时实时获得其状态值

不知道大家有没有这样的经验,当点击或者取消datagridview的checkbox列时,比较难获得其状态是选中还是未选中,进而不好进行其它操作,下面就列出它的解决办法:

主要用到了datagridview的CurrentCellDirtyStateChanged和CellValueChanged两个事件

CurrentCellDirtyStateChanged事件是提交对checkbox状态的修改

CellValueChanged事件是当状态提交后,也就是单元格值改变后做一些其它的操作,这里是将checkbox列的true或false状态作为tooptiptext属性设置到同一行的button列

CurrentCellDirtyStateChanged事件代码 :


private void dataGridView1_CurrentCellDirtyStateChanged(object sender, EventArgs e)
{
if (this.dataGridView1.IsCurrentCellDirty) //有未提交的更//
{
this.dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit);
}
}

CellValueChanged事件代码 :


private void dataGridView1_CellValueChanged(object sender, DataGridViewCellEventArgs e)
{
if (this.dataGridView1.Columns[e.ColumnIndex].Name.Equals("gender"))
{
DataGridViewButtonCell dgvButtonCell
= this.dataGridView1.Rows[e.RowIndex].Cells["btn"] as DataGridViewButtonCell;//获得button列单元格
DataGridViewCheckBoxCell dgvCheckBoxCell = this.dataGridView1.Rows[e.RowIndex].Cells[e.ColumnIndex] as DataGridViewCheckBoxCell;//获得checkbox列单元格
dgvButtonCell.ToolTipText = dgvCheckBoxCell.Value.ToString();//赋值
}
}