• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 124,  comments - 29,  trackbacks - 0
            1:把(tuxedo安裝目錄)D:\Program Files\tuxedo10.0_VS2005\bin 下面的DLL都考到應(yīng)用程序所在目錄,即CMT.exe  所在的同一目錄,同時(shí)把D:\Program Files\tuxedo10.0_VS2005下面的locale和udataobj目錄也考到應(yīng)用程序所在目錄。
            2:  string nlsPath = Application.StartupPath + "\\locale\\C";
                        string curPath = Application.StartupPath;
                        Bea.Tuxedo.ATMI.Utils.tuxputenv("NLSPATH=" + nlsPath);
                        Bea.Tuxedo.ATMI.Utils.tuxputenv("TUXDIR=" + curPath);
                        Bea.Tuxedo.ATMI.Utils.tuxputenv("APPDIR=" + curPath);
                        Bea.Tuxedo.ATMI.Utils.tuxputenv("WSNADDR=//10.5.0.3:9300");   (這個(gè)最好讀配置文件因?yàn)樗皇枪潭ǖ模?/div>
            posted @ 2009-09-24 14:38 天書(shū) 閱讀(428) | 評(píng)論 (0)編輯 收藏
            posted @ 2009-07-03 16:19 天書(shū) 閱讀(753) | 評(píng)論 (0)編輯 收藏
            posted @ 2009-06-22 16:57 天書(shū) 閱讀(1054) | 評(píng)論 (0)編輯 收藏
            posted @ 2009-04-19 11:22 天書(shū) 閱讀(1205) | 評(píng)論 (1)編輯 收藏

              private void InstructorTree_Load(object sender, EventArgs e)
                    {
                        xmlfile = Application.StartupPath + "\\CC08Help.xml";
                        GetInsEvent += new GetInstructorHandle(HelpForm_GetInsEvent);
                        GetHtmlEvent += new GetNodeHtml(InstructorTree_GetHtmlEvent);
                        ReadXMLGetFileName();
                        this.tvHelp.ImageList = this.imgLHelp;
                     
                        //由Excel導(dǎo)出的XML文檔動(dòng)態(tài)生成樹(shù)
                        if (xmlfile != "")
                        {
                            InitTreeView(xmlfile, this.tvHelp);
                        }
                        foreach (TreeNode tn in tvHelp.Nodes)
                        {
                            SetLeafNodeImageIndex(tn);
                        }
                        this.tvHelp.Nodes[0].Expand();
                    }

                    private TreeNode curTn = null;
                
                    private void InitTreeView(string xmlfileName, TreeView tv)
                    {
                        XmlDocument xdoc = new XmlDocument();
                        xdoc.Load(xmlfileName);
                        XmlNode xn = xdoc.SelectSingleNode("Help");
                        TreeNode tn = new TreeNode();
                        tn.Text = xn.ChildNodes[0].Attributes[0].Value;//命令聯(lián)機(jī)幫助
                        tv.Nodes.Add(tn);
                        makeOutTreeView(xn.ChildNodes[0], tn);  //遞歸
                    }

                    private void makeOutTreeView(XmlNode xn,TreeNode tn)
                    {
                        if (xn.ChildNodes.Count != 0)
                        {
                            for (int i = 0; i < xn.ChildNodes.Count; i++)
                            {
                                curTn = new TreeNode();
                                curTn.Text = xn.ChildNodes[i].Attributes[0].Value;
                                tn.Nodes.Add(curTn);

                                makeOutTreeView(xn.ChildNodes[i], curTn);
                            }
                        }
                    }

            posted @ 2009-02-20 15:21 天書(shū) 閱讀(1127) | 評(píng)論 (0)編輯 收藏

            using System;
            using System.Collections.Generic;
            using System.ComponentModel;
            using System.Data;
            using System.Drawing;
            using System.Text;
            using System.Windows.Forms;
            using System.Xml;


            namespace ExcelToXml
            {
                public partial class Form1 : Form
                {
                    public Form1()
                    {
                        InitializeComponent();
                    }
                    private string xmlFile = "";
                    private DataSet ds = null;
                    private string excelFileName = "";
                    private void ReadXMLGetFileName()
                    {
                        XmlDocument xdoc = new XmlDocument();
                        string file = Application.StartupPath + "http://excelFile.xml";
                        xdoc.Load(file);
                        XmlNode xno = xdoc.SelectSingleNode("excelFile");
                        for (int i = 0; i < xno.ChildNodes.Count; i++)
                        {
                            if (xno.ChildNodes[i].Name == "FileName")
                            {
                                excelFileName = xno.ChildNodes[i].InnerText;
                                break;
                            }
                        }
                    }
                    private void Form1_Load(object sender, EventArgs e)
                    {
                        xmlFile = Application.StartupPath + "\\CC08Help.xml";
                        ReadXMLGetFileName();
                        ds = ReadExcelToTree.ExcelToDataSet(@excelFileName);
                        if (ds != null)
                        {
                            xmlFormExcel(ds.Tables[0], xmlFile);
                        }
                    }
                    private XmlNode curNode = null;
                    private string curNodeName = "";
                    private XmlDocument xdoc = null;
                    void xmlFormExcel(DataTable dt,string xmlFile)
                    {
                       
                        xdoc = new XmlDocument();
                        xdoc.Load(xmlFile);
                        curNodeName = "Help";
                        curNode = xdoc.SelectSingleNode(curNodeName);
                       
                        int colums = dt.Columns.Count;
                        XmlNode[] curNodeLevel = new XmlNode[colums];
                        for (int i = 0; i < dt.Rows.Count; i++)
                        {
                            DataRow dr = dt.Rows[i];
                            for (int j = 1; j <= colums; j++)
                            {
                                if (j == 1 && dr[j].ToString() != String.Empty)
                                {
                                    XmlElement xe = xdoc.CreateElement("tn");
                                    xe.SetAttribute("value",dr[j].ToString());
                                    curNode.AppendChild(xe);
                                    curNodeLevel[0] = xe;
                                    break;
                                }
                                else if (j >= 2)
                                {
                                    if (dr[j].ToString() != string.Empty)
                                    {
                                        XmlElement xe = xdoc.CreateElement("tn");
                                        xe.SetAttribute("value", dr[j].ToString());
                                     
                                        curNodeLevel[j - 2].AppendChild(xe);
                                        curNodeLevel[j - 1] = xe;
                                        break;
                                    }
                                }
                            }
                        }
                        xdoc.Save(xmlFile);
                    }
                }
            }

            posted @ 2009-02-20 15:16 天書(shū) 閱讀(1439) | 評(píng)論 (1)編輯 收藏

            觸發(fā)器是一種特殊的存儲(chǔ)過(guò)程,類(lèi)似于事件函數(shù),SQL Server™ 允許為 INSERT、UPDATE、DELETE 創(chuàng)建觸發(fā)器,即當(dāng)在表中插入、更新、刪除記錄時(shí),觸發(fā)一個(gè)或一系列 T-SQL語(yǔ)句。

            觸發(fā)器可以在查詢分析器里創(chuàng)建,也可以在表名上點(diǎn)右鍵->“所有任務(wù)”->“管理觸發(fā)器”來(lái)創(chuàng)建,不過(guò)都是要寫(xiě) T-SQL 語(yǔ)句的,只是在查詢分析器里要先確定當(dāng)前操作的數(shù)據(jù)庫(kù)。

            創(chuàng)建觸發(fā)器用 CREATE TRIGGER

            CREATE TRIGGER 觸發(fā)器名稱(chēng)
            ON 表名
            FOR INSERT、UPDATE 或 DELETE
            AS
                T-SQL 語(yǔ)句

            注意:觸發(fā)器名稱(chēng)是不加引號(hào)的。

            如下是聯(lián)機(jī)叢書(shū)上的一個(gè)示例,當(dāng)在 titles 表上更改記錄時(shí),發(fā)送郵件通知 MaryM。
            CREATE TRIGGER reminder
            ON titles
            FOR INSERT, UPDATE, DELETE
            AS
               EXEC master..xp_sendmail 'MaryM',
                  'Don''t forget to print a report for the distributors.'

            posted @ 2009-02-19 15:48 天書(shū) 閱讀(455) | 評(píng)論 (0)編輯 收藏
              觸發(fā)器是一種特殊的存儲(chǔ)過(guò)程,它在插入,刪除或修改特定表中

            的數(shù)據(jù)時(shí)觸發(fā)執(zhí)行,它比數(shù)據(jù)庫(kù)本身標(biāo)準(zhǔn)的功能有更精細(xì)和更復(fù)雜的

            數(shù)據(jù)控制能力。
            數(shù)據(jù)庫(kù)觸發(fā)器有以下的作用:

                * 安全性。可以基于數(shù)據(jù)庫(kù)的值使用戶具有操作數(shù)據(jù)庫(kù)的某種權(quán)

            利。

                  # 可以基于時(shí)間限制用戶的操作,例如不允許下班后和節(jié)假日

                  修改數(shù)據(jù)庫(kù)數(shù)據(jù)。

                  # 可以基于數(shù)據(jù)庫(kù)中的數(shù)據(jù)限制用戶的操作,例如不允許股票

                  的價(jià)格的升幅一次超過(guò)10%。

                * 審計(jì)。可以跟蹤用戶對(duì)數(shù)據(jù)庫(kù)的操作。

                  # 審計(jì)用戶操作數(shù)據(jù)庫(kù)的語(yǔ)句。

                  # 把用戶對(duì)數(shù)據(jù)庫(kù)的更新寫(xiě)入審計(jì)表。

                * 實(shí)現(xiàn)復(fù)雜的數(shù)據(jù)完整性規(guī)則。

                  # 實(shí)現(xiàn)非標(biāo)準(zhǔn)的數(shù)據(jù)完整性檢查和約束。觸發(fā)器可產(chǎn)生比規(guī)則

                  更為復(fù)雜的限制。與規(guī)則不同,觸發(fā)器可以引用列或數(shù)據(jù)庫(kù)對(duì)

                  象。例如,觸發(fā)器可回退任何企圖吃進(jìn)超過(guò)自己保證金的期貨。

                  # 提供可變的缺省值。

                * 實(shí)現(xiàn)復(fù)雜的非標(biāo)準(zhǔn)的數(shù)據(jù)庫(kù)相關(guān)完整性規(guī)則。觸發(fā)器可以對(duì)數(shù)

            據(jù)庫(kù)中相關(guān)的表進(jìn)行連環(huán)更新。例如,在auths表author_code列上的

            刪除觸發(fā)器可導(dǎo)致相應(yīng)刪除在其它表中的與之匹配的行。

                  # 在修改或刪除時(shí)級(jí)聯(lián)修改或刪除其它表中的與之匹配的行。

                  # 在修改或刪除時(shí)把其它表中的與之匹配的行設(shè)成NULL值。

                  # 在修改或刪除時(shí)把其它表中的與之匹配的行級(jí)聯(lián)設(shè)成缺省值。

                  # 觸發(fā)器能夠拒絕或回退那些破壞相關(guān)完整性的變化,取消試

                  圖進(jìn)行數(shù)據(jù)更新的事務(wù)。當(dāng)插入一個(gè)與其主健不匹配的外部鍵

                  時(shí),這種觸發(fā)器會(huì)起作用。例如,可以在books.author_code

                  列上生成一個(gè)插入觸發(fā)器,如果新值與auths.author_code列

                  中的某值不匹配時(shí),插入被回退。

                * 同步實(shí)時(shí)地復(fù)制表中的數(shù)據(jù)。

                * 自動(dòng)計(jì)算數(shù)據(jù)值,如果數(shù)據(jù)的值達(dá)到了一定的要求,則進(jìn)行特

            定的處理。例如,如果公司的帳號(hào)上的資金低于5萬(wàn)元?jiǎng)t立即給財(cái)務(wù)人

            員發(fā)送警告數(shù)據(jù)。


            觸發(fā)器是一種特殊的存儲(chǔ)過(guò)程,類(lèi)似于事件函數(shù),SQL Server™ 允許為 INSERT、UPDATE、DELETE 創(chuàng)建觸發(fā)器,即當(dāng)在表中插入、更新、刪除記錄時(shí),觸發(fā)一個(gè)或一系列 T-SQL語(yǔ)句。

            觸發(fā)器可以在查詢分析器里創(chuàng)建,也可以在表名上點(diǎn)右鍵->“所有任務(wù)”->“管理觸發(fā)器”來(lái)創(chuàng)建,不過(guò)都是要寫(xiě) T-SQL 語(yǔ)句的,只是在查詢分析器里要先確定當(dāng)前操作的數(shù)據(jù)庫(kù)。

            創(chuàng)建觸發(fā)器用 CREATE TRIGGER

            CREATE TRIGGER 觸發(fā)器名稱(chēng)
            ON 表名
            FOR INSERT、UPDATE 或 DELETE
            AS
                T-SQL 語(yǔ)句

            注意:觸發(fā)器名稱(chēng)是不加引號(hào)的。

            如下是聯(lián)機(jī)叢書(shū)上的一個(gè)示例,當(dāng)在 titles 表上更改記錄時(shí),發(fā)送郵件通知 MaryM。
            CREATE TRIGGER reminder
            ON titles
            FOR INSERT, UPDATE, DELETE
            AS
               EXEC master..xp_sendmail 'MaryM',
                  'Don''t forget to print a report for the distributors.'

            posted @ 2009-02-19 15:42 天書(shū) 閱讀(3619) | 評(píng)論 (1)編輯 收藏

            參考答案:
            執(zhí)行效率的大幅提高
            ASP以源碼形式存放,以解釋方式運(yùn)行,每次ASP網(wǎng)頁(yè)調(diào)用都需要對(duì)源碼進(jìn)行解釋?zhuān)\(yùn)行效率不高.  ASP.net是把基于通用語(yǔ)言的程序在服務(wù)器上運(yùn)行。不像以前的ASP即時(shí)解釋程序,而是將程序在服務(wù)器端首次運(yùn)行時(shí)進(jìn)行編譯,這樣的執(zhí)行效果,當(dāng)然比一條一條的解釋強(qiáng)很多.
            強(qiáng)大的開(kāi)發(fā)工具支持
            ASP.net可以使用VS Studio 系列的強(qiáng)大的開(kāi)發(fā)工具,只是所見(jiàn)即所得的開(kāi)發(fā)支持。
            可擴(kuò)充的適應(yīng)性
            Asp.net可以完美支持windows平臺(tái),也可以通過(guò)mono來(lái)支持linux的平臺(tái)。而且,asp.Net是語(yǔ)言獨(dú)立的,也就是說(shuō)不但可以用C#編寫(xiě)相關(guān)的代碼,你也可以使用vb,jscript等語(yǔ)言來(lái)編寫(xiě)。
            多處理器環(huán)境的可靠性
            ASP.net已經(jīng)被刻意設(shè)計(jì)成為一種可以用于多處理器的開(kāi)發(fā)工具,它在多處理器的環(huán)境下用特殊的無(wú)縫連接技術(shù),將很大的提高運(yùn)行速度。即使你現(xiàn)在的ASP.net應(yīng)用軟件是為一個(gè)處理器開(kāi)發(fā)的,將來(lái)多處理器運(yùn)行時(shí)不需要任何改變都能提高他們的效能,但現(xiàn)在的ASP確做不到這一點(diǎn)。
            安全型
            AspNet內(nèi)置了強(qiáng)大的安全型管理機(jī)制,相對(duì)asp,安全型得到了很大的提高。

            點(diǎn)評(píng):

            和asp相比,asp.net確實(shí)有了很大的飛躍,特別是這種代碼分類(lèi)的方式,給編程人員帶來(lái)了很大的方便,了解asp.net的進(jìn)步,可以讓我們更有信心學(xué)習(xí)asp。net.。

            posted @ 2009-02-19 15:29 天書(shū) 閱讀(1743) | 評(píng)論 (1)編輯 收藏

            C#可否對(duì)內(nèi)存進(jìn)行直接的操作 ?
            可以使用指針
            在這篇文章中將描述C#的一個(gè)特性指針和所謂的不安全代碼。

            非安全代碼

                   非安全代碼就是不在 CLR 完全控制下執(zhí)行的代碼,它有可能會(huì)導(dǎo)致一些問(wèn)題,因此他們必須用 “unsafe” 進(jìn)行表明:

                   unsafe
                   {
                   ...
                   // unsafe context: can use pointers here
                   ...
                   }

                   在其他一些地方也可以使用關(guān)鍵字 ‘unsafe’,例如我們可以將類(lèi)或方法表明為非安全的:

                   unsafe class Class1 {}
                   static unsafe void FastMove ( int* pi, int* pdi, int length) {...}

            ‘unsafe’ 關(guān)鍵字的必要性是它可以防止程序員的一些意外的用法。你可能會(huì)問(wèn)既然是不安全的為什么還有人要用它。答案就是有時(shí)候,在有些情況下,還需要用到指針。

            指針

                   指針是一種用來(lái)存儲(chǔ)其他變量地址的特殊的變量,如果你把第一個(gè)變量的地址賦給第二個(gè)變量,你可以說(shuō)第一個(gè)變量是指向第二個(gè),CLR支持3種指針類(lèi)型:受托管指針, 非托管指針和非托管函數(shù)指針。受托管指針存儲(chǔ)在堆上的托管塊的引用,一個(gè)非托管指針是傳統(tǒng)的C++指針并且每次使用必須要放在unsafe代碼塊中,一個(gè)非托管函數(shù)指針也是指向函數(shù)地址的傳統(tǒng)的C++指針(delegates 可以被看做是非托管函數(shù)指針).

                   你可以像下面這樣的聲明來(lái)創(chuàng)建指針:類(lèi)型* 變量_名稱(chēng);

                   既然類(lèi)型可以是任意一個(gè)非引用類(lèi)型并且不包含引用類(lèi)型字段,它只能是:sbyte, byte, short, ushort, int, uint, long, ulong, char, float, double, decimal, bool 和枚舉類(lèi)型以及其他指針類(lèi)型,也可以是任何用戶自定義的包括非托管類(lèi)型字段的結(jié)構(gòu)體.

                   下面是不同類(lèi)型指針聲明的示例:

                   int* pi //declaration a pointer to integer variable
                   float* pf, pq // two pointers to float variables. Not *pf, *pq
                   char* pz // pointer to char

                   就像前面說(shuō)的非托管代碼CLR是不能驗(yàn)證的,為了編譯你需要指定 /unsafe 編譯選項(xiàng),如果你是使用的是Microsoft Visual Studio你需要在項(xiàng)目選項(xiàng)中把 'Allow unsafe code block'設(shè)置成 True。



            指針的基本用法

            還有一些與指針緊密聯(lián)系的操作符,那就是 & 操作符,& 返回它所操作對(duì)象的地址。

            例如:
            unsafe
            {
            int* pi;
            int x = 1;
            pi = &x;
            System.Console.WriteLine("Value of x is: " + *pi);
            }

            在這個(gè)例子中我們創(chuàng)建了2個(gè)變量,’pi’是指向int的指針,’x’是int,然后我們將’x’在內(nèi)存中的地址賦予’pi’,理解我們放在 ’pi’ 變量中的是 ’x’的地址而不是’x’的值非常重要 (使用: pi = x 將返回錯(cuò)誤 "Cannot implicitly convert type 'int' to 'int*'")

            編譯后執(zhí)行將會(huì)輸出:

            Value of x is: 1

            指針可以接受 null 值,也可能使用 void 指針類(lèi)型,下面的代碼可以正常編譯:

            unsafe
            {
            nt x = 10;
            void* px = &x;
            double *pd = (double*)px;
            }

            fixed 關(guān)鍵字和垃圾回收

            在 C# 中使用指針需要比在 C++種更加注意。這是因?yàn)槔厥掌?g.c.)會(huì)運(yùn)行內(nèi)存清理,在清理的過(guò)程中,g.c.會(huì)改變對(duì)象的物理內(nèi)存位置,如果 g.c.改變了對(duì)象的位置指針將指向錯(cuò)誤的內(nèi)存位置。為了避免這樣的問(wèn)題(已經(jīng)與垃圾回收器連接),C# 包含 'fixed' 關(guān)鍵字. 它通知系統(tǒng)不要讓垃圾回收器重新部署對(duì)象。

                   如果我們忘了 ’fixed’ 關(guān)鍵字編譯器會(huì)給我們相應(yīng)的警告,但它沒(méi)有智能到在下面的情況中也會(huì)警告我們。下面的代碼有一個(gè)嚴(yán)重的Bug盡管編譯很正常。

            C# 指針和 WinApi

                   使用指針最重要的好處就是可以與其他二進(jìn)制代碼進(jìn)行交互。許多 WinApi 函數(shù)都使用指針,例如GetComputerName (Kernel32.lib.)可以提供我們的計(jì)算機(jī)的名稱(chēng)。

            BOOL GetComputerName(LPTSTR lpBuffer, // computer name
            LPDWORD lpnSize // size of name buffer);

            下面的程序演示如何使用GetComputerName:

            [System.Runtime.InteropServices.DllImport("Kernel32")]
            static extern unsafe bool GetComputerName(byte* lpBuffer,long* nSize);
            static void Main()
            {
            byte[] buffor = new byte[512];
            long size = buffor.Length;
            unsafe
            {
            long* pSize = &size;
            fixed (byte* pBuffor = buffor)
            {
            GetComputerName(pBuffor,pSize);
            }
            }
            System.Text.Encoding textEnc = new System.Text.ASCIIEncoding();
            System.Console.WriteLine("Computer name: {0}",textEnc.GetString(buffor));
            }

            結(jié)論

                   我們已經(jīng)看到指針是C#語(yǔ)言中非常有用的部分,使用指針并不難但是要非常小心,因?yàn)橛锌赡軙?huì)導(dǎo)致難以診斷的問(wèn)題,使用指針會(huì)擾亂垃圾回收器的功能,特別當(dāng)我們?cè)诔绦蛑写罅渴褂弥羔槨R虼嗽谥弥羔樦拔覀儜?yīng)該多考慮,或者嘗試其他的解決辦法。

            posted @ 2009-02-19 15:22 天書(shū) 閱讀(2313) | 評(píng)論 (1)編輯 收藏
            僅列出標(biāo)題
            共13頁(yè): 1 2 3 4 5 6 7 8 9 Last 

            <2010年10月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(5)

            隨筆檔案

            文章分類(lèi)

            文章檔案

            好友的Bolg

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            久久久精品日本一区二区三区| A级毛片无码久久精品免费| 无码人妻少妇久久中文字幕| 久久精品国产欧美日韩| 中文字幕无码免费久久| 久久亚洲精品视频| 伊人久久综合无码成人网 | 久久久国产精品| 熟妇人妻久久中文字幕| 久久青草国产精品一区| 性高湖久久久久久久久AAAAA| 国产精品一区二区久久国产| 欧美激情精品久久久久久久九九九| 亚洲午夜久久久影院| 久久无码国产| 99热都是精品久久久久久| 欧美午夜精品久久久久免费视| 久久久久亚洲av成人无码电影 | 久久综合久久久| 色欲综合久久中文字幕网| 久久91这里精品国产2020| 国产一久久香蕉国产线看观看 | 久久无码一区二区三区少妇| 99精品久久久久中文字幕| 综合网日日天干夜夜久久| 久久综合给合综合久久| 久久黄色视频| 国产99久久久国产精免费| 久久99国内精品自在现线| 亚洲AV无码久久精品狠狠爱浪潮| 亚洲人成网站999久久久综合 | 精品多毛少妇人妻AV免费久久| 久久精品国产网红主播| 久久亚洲AV成人无码国产| 青青草原精品99久久精品66| 久久综合亚洲色HEZYO社区| 久久无码专区国产精品发布 | 国产成人久久AV免费| 久久精品国产99国产精品导航 | 亚洲国产另类久久久精品小说 | 亚洲综合婷婷久久|