1:把(tuxedo安裝目錄)D:\Program Files\tuxedo10.0_VS2005\bin 下面的DLL都考到應用程序所在目錄,即CMT.exe 所在的同一目錄,同時把D:\Program Files\tuxedo10.0_VS2005下面的locale和udataobj目錄也考到應用程序所在目錄。
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"); (這個最好讀配置文件因為它不是固定的)
posted @
2009-09-24 14:38 天書 閱讀(430) |
評論 (0) |
編輯 收藏
posted @
2009-07-03 16:19 天書 閱讀(756) |
評論 (0) |
編輯 收藏
posted @
2009-06-22 16:57 天書 閱讀(1057) |
評論 (0) |
編輯 收藏
posted @
2009-04-19 11:22 天書 閱讀(1207) |
評論 (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導出的XML文檔動態生成樹
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;//命令聯機幫助
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 天書 閱讀(1132) |
評論 (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 天書 閱讀(1448) |
評論 (1) |
編輯 收藏
觸發器是一種特殊的存儲過程,類似于事件函數,SQL Server™ 允許為 INSERT、UPDATE、DELETE 創建觸發器,即當在表中插入、更新、刪除記錄時,觸發一個或一系列 T-SQL語句。
觸發器可以在查詢分析器里創建,也可以在表名上點右鍵->“所有任務”->“管理觸發器”來創建,不過都是要寫 T-SQL 語句的,只是在查詢分析器里要先確定當前操作的數據庫。
創建觸發器用 CREATE TRIGGER
CREATE TRIGGER 觸發器名稱
ON 表名
FOR INSERT、UPDATE 或 DELETE
AS
T-SQL 語句
注意:觸發器名稱是不加引號的。
如下是聯機叢書上的一個示例,當在 titles 表上更改記錄時,發送郵件通知 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 天書 閱讀(461) |
評論 (0) |
編輯 收藏
觸發器是一種特殊的存儲過程,它在插入,刪除或修改特定表中
的數據時觸發執行,它比數據庫本身標準的功能有更精細和更復雜的
數據控制能力。
數據庫觸發器有以下的作用:
* 安全性。可以基于數據庫的值使用戶具有操作數據庫的某種權
利。
# 可以基于時間限制用戶的操作,例如不允許下班后和節假日
修改數據庫數據。
# 可以基于數據庫中的數據限制用戶的操作,例如不允許股票
的價格的升幅一次超過10%。
* 審計。可以跟蹤用戶對數據庫的操作。
# 審計用戶操作數據庫的語句。
# 把用戶對數據庫的更新寫入審計表。
* 實現復雜的數據完整性規則。
# 實現非標準的數據完整性檢查和約束。觸發器可產生比規則
更為復雜的限制。與規則不同,觸發器可以引用列或數據庫對
象。例如,觸發器可回退任何企圖吃進超過自己保證金的期貨。
# 提供可變的缺省值。
* 實現復雜的非標準的數據庫相關完整性規則。觸發器可以對數
據庫中相關的表進行連環更新。例如,在auths表author_code列上的
刪除觸發器可導致相應刪除在其它表中的與之匹配的行。
# 在修改或刪除時級聯修改或刪除其它表中的與之匹配的行。
# 在修改或刪除時把其它表中的與之匹配的行設成NULL值。
# 在修改或刪除時把其它表中的與之匹配的行級聯設成缺省值。
# 觸發器能夠拒絕或回退那些破壞相關完整性的變化,取消試
圖進行數據更新的事務。當插入一個與其主健不匹配的外部鍵
時,這種觸發器會起作用。例如,可以在books.author_code
列上生成一個插入觸發器,如果新值與auths.author_code列
中的某值不匹配時,插入被回退。
* 同步實時地復制表中的數據。
* 自動計算數據值,如果數據的值達到了一定的要求,則進行特
定的處理。例如,如果公司的帳號上的資金低于5萬元則立即給財務人
員發送警告數據。
觸發器是一種特殊的存儲過程,類似于事件函數,SQL Server™ 允許為 INSERT、UPDATE、DELETE 創建觸發器,即當在表中插入、更新、刪除記錄時,觸發一個或一系列 T-SQL語句。
觸發器可以在查詢分析器里創建,也可以在表名上點右鍵->“所有任務”->“管理觸發器”來創建,不過都是要寫 T-SQL 語句的,只是在查詢分析器里要先確定當前操作的數據庫。
創建觸發器用 CREATE TRIGGER
CREATE TRIGGER 觸發器名稱
ON 表名
FOR INSERT、UPDATE 或 DELETE
AS
T-SQL 語句
注意:觸發器名稱是不加引號的。
如下是聯機叢書上的一個示例,當在 titles 表上更改記錄時,發送郵件通知 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 天書 閱讀(3626) |
評論 (1) |
編輯 收藏
參考答案:
執行效率的大幅提高
ASP以源碼形式存放,以解釋方式運行,每次ASP網頁調用都需要對源碼進行解釋,運行效率不高. ASP.net是把基于通用語言的程序在服務器上運行。不像以前的ASP即時解釋程序,而是將程序在服務器端首次運行時進行編譯,這樣的執行效果,當然比一條一條的解釋強很多.
強大的開發工具支持
ASP.net可以使用VS Studio 系列的強大的開發工具,只是所見即所得的開發支持。
可擴充的適應性
Asp.net可以完美支持windows平臺,也可以通過mono來支持linux的平臺。而且,asp.Net是語言獨立的,也就是說不但可以用C#編寫相關的代碼,你也可以使用vb,jscript等語言來編寫。
多處理器環境的可靠性
ASP.net已經被刻意設計成為一種可以用于多處理器的開發工具,它在多處理器的環境下用特殊的無縫連接技術,將很大的提高運行速度。即使你現在的ASP.net應用軟件是為一個處理器開發的,將來多處理器運行時不需要任何改變都能提高他們的效能,但現在的ASP確做不到這一點。
安全型
AspNet內置了強大的安全型管理機制,相對asp,安全型得到了很大的提高。
點評:
和asp相比,asp.net確實有了很大的飛躍,特別是這種代碼分類的方式,給編程人員帶來了很大的方便,了解asp.net的進步,可以讓我們更有信心學習asp。net.。
posted @
2009-02-19 15:29 天書 閱讀(1746) |
評論 (1) |
編輯 收藏
C#可否對內存進行直接的操作 ?
可以使用指針
在這篇文章中將描述C#的一個特性指針和所謂的不安全代碼。
非安全代碼
非安全代碼就是不在 CLR 完全控制下執行的代碼,它有可能會導致一些問題,因此他們必須用 “unsafe” 進行表明:
unsafe
{
...
// unsafe context: can use pointers here
...
}
在其他一些地方也可以使用關鍵字 ‘unsafe’,例如我們可以將類或方法表明為非安全的:
unsafe class Class1 {}
static unsafe void FastMove ( int* pi, int* pdi, int length) {...}
‘unsafe’ 關鍵字的必要性是它可以防止程序員的一些意外的用法。你可能會問既然是不安全的為什么還有人要用它。答案就是有時候,在有些情況下,還需要用到指針。
指針
指針是一種用來存儲其他變量地址的特殊的變量,如果你把第一個變量的地址賦給第二個變量,你可以說第一個變量是指向第二個,CLR支持3種指針類型:受托管指針, 非托管指針和非托管函數指針。受托管指針存儲在堆上的托管塊的引用,一個非托管指針是傳統的C++指針并且每次使用必須要放在unsafe代碼塊中,一個非托管函數指針也是指向函數地址的傳統的C++指針(delegates 可以被看做是非托管函數指針).
你可以像下面這樣的聲明來創建指針:類型* 變量_名稱;
既然類型可以是任意一個非引用類型并且不包含引用類型字段,它只能是:sbyte, byte, short, ushort, int, uint, long, ulong, char, float, double, decimal, bool 和枚舉類型以及其他指針類型,也可以是任何用戶自定義的包括非托管類型字段的結構體.
下面是不同類型指針聲明的示例:
int* pi //declaration a pointer to integer variable
float* pf, pq // two pointers to float variables. Not *pf, *pq
char* pz // pointer to char
就像前面說的非托管代碼CLR是不能驗證的,為了編譯你需要指定 /unsafe 編譯選項,如果你是使用的是Microsoft Visual Studio你需要在項目選項中把 'Allow unsafe code block'設置成 True。
指針的基本用法
還有一些與指針緊密聯系的操作符,那就是 & 操作符,& 返回它所操作對象的地址。
例如:
unsafe
{
int* pi;
int x = 1;
pi = &x;
System.Console.WriteLine("Value of x is: " + *pi);
}
在這個例子中我們創建了2個變量,’pi’是指向int的指針,’x’是int,然后我們將’x’在內存中的地址賦予’pi’,理解我們放在 ’pi’ 變量中的是 ’x’的地址而不是’x’的值非常重要 (使用: pi = x 將返回錯誤 "Cannot implicitly convert type 'int' to 'int*'")
編譯后執行將會輸出:
Value of x is: 1
指針可以接受 null 值,也可能使用 void 指針類型,下面的代碼可以正常編譯:
unsafe
{
nt x = 10;
void* px = &x;
double *pd = (double*)px;
}
fixed 關鍵字和垃圾回收
在 C# 中使用指針需要比在 C++種更加注意。這是因為垃圾回收器(g.c.)會運行內存清理,在清理的過程中,g.c.會改變對象的物理內存位置,如果 g.c.改變了對象的位置指針將指向錯誤的內存位置。為了避免這樣的問題(已經與垃圾回收器連接),C# 包含 'fixed' 關鍵字. 它通知系統不要讓垃圾回收器重新部署對象。
如果我們忘了 ’fixed’ 關鍵字編譯器會給我們相應的警告,但它沒有智能到在下面的情況中也會警告我們。下面的代碼有一個嚴重的Bug盡管編譯很正常。
C# 指針和 WinApi
使用指針最重要的好處就是可以與其他二進制代碼進行交互。許多 WinApi 函數都使用指針,例如GetComputerName (Kernel32.lib.)可以提供我們的計算機的名稱。
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));
}
結論
我們已經看到指針是C#語言中非常有用的部分,使用指針并不難但是要非常小心,因為有可能會導致難以診斷的問題,使用指針會擾亂垃圾回收器的功能,特別當我們在程序中大量使用指針。因此在之用指針之前我們應該多考慮,或者嘗試其他的解決辦法。
posted @
2009-02-19 15:22 天書 閱讀(2317) |
評論 (1) |
編輯 收藏