reference : http://www.dotnetperls.com/regex-escape

You want to see an example of using the Regex.Escape method in the C# programming language found in the System.Text.RegularExpressions namespace. This is a powerful method that helps convert user-specified strings into escaped strings to match in a regular expression. Here we examine the Regex.Escape method in the .NET Framework, first seeing an example and then discussing possible uses, using the C# language.

Example

The Regex.Escape method is a static method on the Regex type that receives one parameter of string type. The string reference is received and internally the Escape method allocates a new string containing the escaped character sequence and returns its reference. This example shows the use of Regex.Escape on user input.

Program that uses Regex.Escape [C#]

using System;
using System.Text.RegularExpressions;

class Program
{
    static void Main()
    {
	// User specified to remove this string.
	string value1 = @"\123";

	// Escape the input.
	value1 = Regex.Escape(value1);

	// Write the escaped input.
	Console.WriteLine(value1);

	// The string we are changing.
	string input1 = @"This is\123a string";

	// Remove the user-specified pattern.
	string output1 = Regex.Replace(input1, value1, "");

	// Write the output.
	Console.WriteLine(output1);
    }
}

Output
    (The backslash character was replaced.)

\\123
This isa string

String variables used. The example shows three strings: the first string value1 is the input that the user specifies. The user in this example specified the exact string "\123". This value is then escaped with Regex.Escape and becomes "\\123". Finally the Regex.Replace method is called and replaces the pattern "\\123".

Regex.Replace call result. Because the escaped string has two backslashes and not just one, the backslash is treated as a character in the regular expression and not an escape code. The Replace method then can match the character group "\123" and remove it from the final result.

Note (please read)

Uses

Here we note some of the uses the Regex.Escape method has in programs targeting the .NET Framework. Because you can always escape strings in the source code that you type in, you will not need to use it in most programs. If your program retrieves input from a user or file that has certain characters in it, you can use Escape to eliminate the chance that those characters will be used incorrectly.

Summary

We looked at an example of using the Regex.Escape method in the C# programming language. This is a powerful static method that can be useful when preparing dynamic input for use in a regular expression method such as Replace or Split. However, we noted that in most programs where the expressions are specified in the source, this method is not required or useful.

Posted by 노을지기

크리스탈 리포트에 연결하기 위해서 dataset을 이용하였다.

하지만 찾지 못해서 그냥 sql 문으로 사용했는데..

마침 내가 찾는 자료가..ㅎㅎ


출처: http://kojaedoo.tistory.com/640


새항목 추가에서 데이터집합을 만듭니다.

image

 

서버탐색기에서 엑세스하고자하는 DataSet1.xsd 에다가 테이블을 끌어옵니다.

image

 

image

 

DataSet1TableAdapters.CustomersTableAdapter adater = new DataSet1TableAdapters.CustomersTableAdapter();

DataSet1.CustomersDataTable dt = adater.GetData();
//foreach (var item in dt)
//{
// Response.Write(item.CompanyName+"<br>");

//}
this.DataList1.DataSource = dt;
this.DataList1.DataBind();

 

DataList에 바인딩해보기

image

 

잘나온다.!

image

 

 

특정 행만 가져오기

 

image

image

image

 

image

이름을 지정하고

image

image

image

 

 

/// <summary>
/// customerID 를 이용해서 하나의 Customers 불러옵니다.
/// </summary>
/// <param name="customerID"></param>
private void GetCustomersData(string customerID)
{
    DataSet1.CustomersDataTable dt = adater.GetDataByCustomers(customerID);
    if (dt.Count > 0)
    {
        Response.Write("ALFKI 회사의 이름은 :" + dt[0].CompanyName);
    }
}

수정

DataSet1.CustomersDataTable dt = adater.GetDataByCustomers(customerID);
if (dt.Count > 0)
{
    dt[0].CompanyName = "kojaedoo Company";
}
this.adater.Update(dt);

 

image

 

추가

DataSet1.CustomersDataTable dt = new DataSet1.CustomersDataTable();
DataSet1.CustomersRow row =  dt.NewCustomersRow();
row.CustomerID = "KJD";
row.CompanyName = "New kojaedoo Company";
row.ContactName = "kojaedoo";
row.ContactTitle = "고객센터";
// .. 등등삽입

dt.AddCustomersRow(row);

this.adater.Update(dt);

image

 

 

삭제

특정행 가져오기에서 처럼 쿼리구성 마법사를 실행합니다. 여기서 Delete 선택

image

 

image

 

image

 

Delete Query가 추가 되었습니다.

image

 

 

 

 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace WebApplication2
{
    public partial class _Default : System.Web.UI.Page
    {
        //ALFKI

        DataSet1TableAdapters.CustomersTableAdapter adater = new DataSet1TableAdapters.CustomersTableAdapter();
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!IsPostBack)
            {
                GetCustomersData();
                //UpdateCustomers("ALFKI");
                //NewCustomers();
            }
        }

        /// <summary>
        /// Customers 리스트를 불러옵니다.
        /// </summary>
        private void GetCustomersData()
        {

            DataSet1.CustomersDataTable dt = adater.GetData();
            //foreach (var item in dt)
            //{
            //    Response.Write(item.CompanyName+"<br>");

            //}
            this.DataList1.DataSource = dt;
            this.DataList1.DataBind();
        }

        /// <summary>
        /// customerID 를 이용해서 하나의 Customers 불러옵니다.
        /// </summary>
        /// <param name="customerID"></param>
        private void GetCustomersData(string customerID)
        {
            DataSet1.CustomersDataTable dt = adater.GetDataByCustomers(customerID);
            if (dt.Count > 0)
            {
                Response.Write("ALFKI 회사의 이름은 :" + dt[0].CompanyName);
            }
        }

        /// <summary>
        /// Customers를 수정합니다.
        /// </summary>
        /// <param name="customerID"></param>
        private void UpdateCustomers(string customerID)
        {
            DataSet1.CustomersDataTable dt = adater.GetDataByCustomers(customerID);
            if (dt.Count > 0)
            {
                dt[0].CompanyName = "kojaedoo Company";
            }
            this.adater.Update(dt);
        }

        /// <summary>
        /// Customers를 삭제합니다.
        /// </summary>
        /// <param name="customerID"></param>
        private void DeleteCustomers(string customerID)
        {
            int i = this.adater.DeleteQueryCustomerID(customerID);
            Response.Write(i.ToString() + "개가 삭제되었습니다.");
        }

        /// <summary>
        /// 새로운 Customers 를 만듭니다.
        /// </summary>
        private void NewCustomers()
        {
            DataSet1.CustomersDataTable dt = new DataSet1.CustomersDataTable();
            DataSet1.CustomersRow row =  dt.NewCustomersRow();
            row.CustomerID = "KJD";
            row.CompanyName = "New kojaedoo Company";
            row.ContactName = "kojaedoo";
            row.ContactTitle = "고객센터";
            // .. 등등삽입
            
            dt.AddCustomersRow(row);

            this.adater.Update(dt);

        }
    }
}
Posted by 노을지기
출처 : http://dongz.tistory.com/entry/MYSQL-%EC%9E%90%EB%8F%99%EC%A6%9D%EA%B0%80%EA%B0%92-%EA%B0%80%EC%A0%B8%EC%98%A4%EA%B8%B0

출처 : http://whiteship.tistory.com/tag/selectKey
         http://theeye.pe.kr/entry/MySQL-LASTINSERTID-%EA%B0%80%EC%9E%A5-%EC%B5%9C%EA%B7%BC%EC%9D%98Auto-Increment%EA%B0%92%EC%9D%84-%EA%B0%80%EC%A0%B8%EC%98%A4%EA%B8%B0

데이터를 추가하는 경우에 다음과 같은 경우가 많이 있다.

"하나 의 글을 작성하는데 다수의 첨부파일을 작성할 수 있는 경우"
사용자 삽입 이미지

위의 ERD로 스크립트를 생성해 보면 다음과 같을 것이다.

CREATE TABLE POST (
  POST_IDX
int(11) AUTO_INCREMENT,
  SUBJECT varchar
(2000),
  NAME varchar
(200),
  CONTENT text
,
  WRITTEN datetime
,
  PRIMARY KEY
(POST_IDX)
)

CREATE TABLE ATTACHMENT
(
  ATTACH_IDX
int(11) AUTO_INCREMENT,
  POST_IDX
int(11),
  FILE_NAME varchar
(200),
  FILE_PATH varchar
(2000),
  UPLOADED datetime
,
  PRIMARY KEY
(ATTACH_IDX ),
  FOREIGN KEY POST_IDX REFERENCES POST
(POST_IDX)
)


글 이 작성된 후 저장될때 POST테이블에 하나의 값을 추가한후, 다수의 ATTACHMENT를 추가하여야 할것이다.

하지 만 어떻게 정확한 POST_IDX를 알아올 수 있는가?

POST를 저장할때 POST_IDX는 자동증가 인덱스를 가지고 있기 때문에 어떤 값을 부여받게 될지 알 수 없다.

다음과 같은 방법으로 처리할 수 있다.

INSERT INTO POST (
  SUBJECT
, NAME, CONTENT, WRITTEN
) VALUES (
 
"제목", "이름", "글내용", NOW()
);

INSERT INTO ATTACHMENT
(
  POST_IDX
, FILE_NAME, FILE_PATH, UPLOADED
) VALUES (
  LAST_INSERT_ID
(), "file.jpg", "/tmp/file.jpg", NOW()
);


위 와 같이 LAST_INSERT_ID()를 사용하면 가장 최근에 INSERT시에 입력된 INCREMENT ID값을 가져올 수 있다.

중간에 다른 사용자에 의해 글이 추가되더라도 내가 작성할때 부여된 INCREMENT값이 나온다.

단, 당연하겠지만 같은 커넥션 안에서만 정상적인 결과가 나온다.

------------------------------------------------------------

또 다른 참고 글 : http://reid.tistory.com/32

MySQL에서 데이터를 삽입 후 AUTO_INCREMENT 컬럼의 증가값을 가져오기 위해 last_insert_id()를 호출하는 경우, 걱정되는 점 중 하나는 멀티 쓰레드 환경에서 컨넥션들이 서로 race condition을 유발하지 않을까 하는 점이다. 즉, 두 컨넥션이 동시에 insert를 하고 last_insert_id()를 호출하였을 때, 우연히 두 번의 삽입 작업이 먼저 이루어지고 나서 last_insert_id()가 동작하여 같은 정수값을 가져오지 않을까 하는 우려이다. 하지만 이 점에 대해 MySQL은 분명히 명시하고 있다.

The ID that was generated is maintained in the server on a per-connection basis. This means that the value returned by the function to a given client is the first AUTO_INCREMENT value generated for most recent statement affecting an AUTO_INCREMENT column by that client. This value cannot be affected by other clients, even if they generate AUTO_INCREMENT values of their own. This behavior ensures that each client can retrieve its own ID without concern for the activity of other clients, and without the need for locks or transactions.

즉, ID를 생성해서 유지하는 것은 컨넥션 별로 따로 관리되며, 각각의 클라이언트가 정확한 수치를 가져오기 위해 테이블에 락을 걸거나 트랜잭션을 사용 할 필요가 없다는 것이다. 고로, 그냥 연달아 쿼리 날려주면 된다.

MySQL 매뉴얼, LAST_INSERT_ID(), LAST_INSERT_ID(expr) 항목을 참조

Posted by 노을지기
private void chkFolder(string sPath)
        {
            DirectoryInfo di = new DirectoryInfo(sPath);
            if (di.Exists == false)
            {
                di.Create();
            }
        }


파일 확인
출처: http://joyfather.blogspot.com/2010/03/c_4983.html
System.IO 참조

_strFile = "C:\\test.txt"; //파일경로

FileInfo _finfo = new FileInfo(_strFile);

파일 있는지 확인 _finfo.Exists

있을때 true 없으면 당근 false

**폴더 일경우는 FileInfo 대신에 DirectoryInfo 사용한다.

Posted by 노을지기

@""" 으로 시작하면 된다.
pInfo.Arguments =
@"""C:\Wolf Lair\WorkDeskTemp\" + username + @"\WolfDeskApp2k3.mdb"" /runtime /x _AutoExec";

변수에 대입할 경우
  1. string n=@"C:\Documents and Settings\My Test Folder\TestDoc.doc";
  2. string nn="\""+n+"\"";


Posted by 노을지기