{"id":2052,"date":"2011-02-18T00:11:42","date_gmt":"2011-02-17T15:11:42","guid":{"rendered":"http:\/\/www.moonmile.net\/blog\/archives\/2052"},"modified":"2011-02-18T00:14:26","modified_gmt":"2011-02-17T15:14:26","slug":"nunit-%e3%81%a7-dbunit-%e3%82%82%e3%81%a9%e3%81%8d%e3%82%92%e4%bd%bf%e3%81%86","status":"publish","type":"post","link":"http:\/\/www.moonmile.net\/blog\/archives\/2052","title":{"rendered":"NUnit \u3067 DBUnit \u3082\u3069\u304d\u3092\u4f7f\u3046"},"content":{"rendered":"<p>\n\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30a2\u30af\u30bb\u30b9\u304c\u3042\u308b\u5834\u5408\u306f\u3001DBUnit \u3092\u4f7f\u3046\u306e\u304c\u30d9\u30b9\u30c8\u306a\u3093\u3067\u3057\u3087\u3046\u304c\u3001\u3072\u3068\u307e\u305a\u3001\u521d\u671f\u30c7\u30fc\u30bf\u306e\u6295\u5165\u3060\u3051\u3067\u304d\u308c\u3070\u3044\u3044\u3084\u3001\u3063\u3066\u6c17\u6301\u3061\u3067\u4f5c\u3063\u305f\u306e\u304c\u3053\u308c\u3067\u3059\u3002\n<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\npublic class DBTest\n{\n    public static void DataSetup( IDataTable tbl, SqlConnection cn )\n    {\n        Type RowType = tbl.GetRowType();\n        string TableName = tbl.GetTableName();\n\n\n        PropertyInfo&#x5B;] pis = typeof(XProductRow).GetProperties();\n\n        string sql_columns = &quot;(&quot;;\n        string sql_values = &quot;(&quot;;\n        foreach (PropertyInfo pi in pis)\n        {\n            sql_columns += pi.Name + &quot;,&quot;;\n            sql_values += &quot;@&quot; + pi.Name + &quot;,&quot;;\n        }\n        \/\/ \u6700\u5f8c\u306e\u30ab\u30f3\u30de\u3092\u524a\u9664\n        sql_columns = sql_columns.Substring(0, sql_columns.Length - 1);\n        sql_values = sql_values.Substring(0, sql_values.Length - 1);\n        string sql = &quot;insert into &quot; + TableName+ &quot; &quot;\n            + sql_columns + &quot;) values &quot;\n            + sql_values + &quot;)&quot;;\n\n\n        SqlCommand cmd = new SqlCommand(sql, cn);\n        foreach (PropertyInfo pi in pis)\n        {\n            SqlParameter param = new SqlParameter();\n            param.ParameterName = pi.Name;\n            cmd.Parameters.Add(param);\n        }\n\n        cmd.Connection.Open();\n        foreach ( object item in tbl.GetList())\n        {\n            foreach( PropertyInfo pi in pis ) {\n                cmd.Parameters&#x5B;pi.Name].Value = pi.GetValue(item,null);\n            }\n            cmd.ExecuteNonQuery();\n        }\n        cmd.Connection.Close();\n    }\n}\n<\/pre>\n<p>\n\u4f8b\u306e\u3054\u3068\u304f\u3001\u30ea\u30d5\u30ec\u30af\u30b7\u30e7\u30f3\u3092\u4f7f\u3063\u3066\u30d7\u30ed\u30d1\u30c6\u30a3\u540d\uff1d\u30c6\u30fc\u30d6\u30eb\u306e\u30ab\u30e9\u30e0\u540d\u3068\u60f3\u5b9a\u3057\u3066\u3001INSERT \u6587\u3092\u4f5c\u6210\u3057\u307e\u3059\u3002Visual Studio \u3067\u4f5c\u6210\u3055\u308c\u308b\u578b\u4ed8 DataSet \u3092\u4f7f\u3063\u3066\u3082\u826f\u3044\u306e\u3067\u3059\u304c\u3001\u30c7\u30fc\u30bf\u6295\u5165\u3092\u3059\u308b\u305f\u3073\u306b\u3001\u5225\u306e DataAdapter \u3092\u547c\u3073\u51fa\u3055\u306a\u3044\u3068\u3044\u3051\u306a\u3044\u3057\u3001\u306a\u3093\u304b\u3044\u307e\u3044\u3061\u306a\u306e\u3067\u3001\u3063\u3066\u306e\u3068\u3001\u30c6\u30b9\u30c8\u30c7\u30fc\u30bf\u306e\u6295\u5165\u306a\u306e\u3067 INSERT \u6587\u3068\u3001\u30c6\u30fc\u30d6\u30eb\u306e\u4e2d\u8eab\u3092 DELETE \u3059\u308b\u90e8\u5206\u3060\u3051\u304c\u6b32\u3057\u3044\u8a33\u3067\u3001\u578b\u4ed8 DataSet \u3060\u3068\u5197\u9577\u306a\u3093\u3067\u3059\u3088\u306d\u3002\n<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\n\/\/\/ &lt;summary&gt;\n\/\/\/ \u30ea\u30d5\u30ec\u30af\u30b7\u30e7\u30f3\u304c\u7c21\u5358\u306b\u306a\u308b\u305f\u3081\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\n\/\/\/ &lt;\/summary&gt;\npublic interface IDataTable\n{\n    string GetTableName();\n    Type GetRowType();\n    System.Collections.IList GetList();\n}\n\n\/\/\/ &lt;summary&gt;\n\/\/\/ \u5546\u54c1\u30af\u30e9\u30b9(\u30ab\u30e9\u30e0)\n\/\/\/ &lt;\/summary&gt;\npublic class XProductRow\n{\n    public string id { get; set; }\n    public string name { get; set; }\n    public int price { get; set; }\n    public int cateid { get; set; }\n}\n\/\/\/ &lt;summary&gt;\n\/\/\/ \u5546\u54c1\u30af\u30e9\u30b9(\u30c6\u30fc\u30d6\u30eb)\n\/\/\/ &lt;\/summary&gt;\npublic class XProduct : IDataTable\n{\n    public XProduct() \n    {\n        Rows = new List&lt;XProductRow&gt;();\n    }\n    public List&lt;XProductRow&gt; Rows { get; set; }\n    public Type GetRowType() { return typeof(XProductRow); }\n    public System.Collections.IList GetList() { return this.Rows; }\n    public string GetTableName() { return &amp;quot;XProduct&amp;quot;; }\n    public XProductRow NewRow() { return new XProductRow(); }\n}\n<\/pre>\n<p>\n\u3056\u3063\u304f\u308a\u3068\u3001POJO \u30bf\u30a4\u30d7\u306e DataRow \u3068\u3001\u5358\u306a\u308b\u30b3\u30ec\u30af\u30b7\u30e7\u30f3\u3092\u96c6\u3081\u305f\u3060\u3051\u306e DataTable \u3092\u4f5c\u3063\u3066\u304a\u304d\u307e\u3059\u3002\n<\/p>\n<p>\n\u305d\u3046\u3057\u3066\u3001\u30c7\u30fc\u30bf\u6295\u5165\u3092\u3059\u308b\u5834\u5408\u306f\u3001\n<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\nprivate void button1_Click(object sender, EventArgs e)\n{\n    \/\/ \u81ea\u52d5\u3067insert\u6587\u3092\u4f5c\u308b\n    SqlConnection cn = new SqlConnection(@&quot;Data Source=.\\sqlexpress;Initial Catalog=mvcdb;Integrated Security=True;MultipleActiveResultSets=True&quot;);\n\n    XProduct table = new XProduct();\n    XProductRow it = table.NewRow();\n    it.id = &quot;A8000&quot;;\n    it.name = &quot;\u65b0\u5546\u54c1XXX&quot;;\n    it.price = 2000;\n    it.cateid = 2;\n    table.Rows.Add(it);\n\n    it = table.NewRow();\n    it.id = &quot;A8001&quot;;\n    it.name = &quot;\u65b0\u5546\u54c1YYY&quot;;\n    it.price = 2000;\n    it.cateid = 2;\n    table.Rows.Add(it);\n\n    DBTest.DataSetup(table, cn);\n}\n<\/pre>\n<p>\n\u3053\u3093\u306a\u98a8\u306b\u3001DataRow\/DataTable \u306b\u30c7\u30fc\u30bf\u3092\u8a70\u3081\u3066\u304a\u3044\u3066\u3001\u4e00\u6c17\u306b\u30bb\u30c3\u30c8\u30a2\u30c3\u30d7\u3067\u304d\u307e\u3059\u3002\n<\/p>\n<p>\nC# v3.0 \u306e\u5834\u5408\u306f\u3001\u3053\u3093\u306a\u98a8\u306b\u521d\u671f\u5316\u3057\u306a\u304c\u3089\u3068\u3044\u3046\u3053\u3068\u3082\u3067\u304d\u307e\u3059\u3002<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\ntable.Rows.Add(\n    new XProductRow\n    {\n        id = &quot;A8002&quot;,\n        name = &quot;\u65b0\u5546\u54c1ZZZ&quot;,\n        price = 20000,\n        cateid = 1\n    });\n<\/pre>\n<\/p>\n<p>\n\u307e\u3042\u3001\u3053\u308c\u3067\u826f\u3044\u304b\u306a\u3041\u3068\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30a2\u30af\u30bb\u30b9\u304c\u3042\u308b\u5834\u5408\u306f\u3001DBUnit \u3092\u4f7f\u3046\u306e\u304c\u30d9\u30b9\u30c8\u306a\u3093\u3067\u3057\u3087\u3046\u304c\u3001\u3072\u3068\u307e\u305a\u3001\u521d\u671f\u30c7\u30fc\u30bf\u306e\u6295\u5165\u3060\u3051\u3067\u304d\u308c\u3070\u3044\u3044\u3084\u3001\u3063\u3066\u6c17\u6301\u3061\u3067\u4f5c\u3063\u305f\u306e\u304c\u3053\u308c\u3067\u3059\u3002 public class DBTest { public s &hellip; <a href=\"http:\/\/www.moonmile.net\/blog\/archives\/2052\">\u7d9a\u304d\u3092\u8aad\u3080 <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[23,24],"tags":[],"class_list":["post-2052","post","type-post","status-publish","format-standard","hentry","category-csharp","category-xunit"],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/2052","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/comments?post=2052"}],"version-history":[{"count":1,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/2052\/revisions"}],"predecessor-version":[{"id":2053,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/2052\/revisions\/2053"}],"wp:attachment":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/media?parent=2052"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/categories?post=2052"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/tags?post=2052"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}