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) |
編輯 收藏