XML数据从数据库中读取(XML参考YTBank.Xml)

本文展示了一段将SQL查询结果转换为XML格式并输出的C#代码示例,涉及数据库连接、SQL语句执行、XML元素创建及数据填充。

XML文件

ExpandedBlockStart.gif 代码
class  Program
    {
        
static   void  Main( string [] args)
        {
            
string  dataDir  =  AppDomain.CurrentDomain.BaseDirectory;
            
if  (dataDir.EndsWith( @" \bin\Debug\ " )
                
||  dataDir.EndsWith( @" \bin\Release\ " ))
            {
                dataDir 
=  System.IO.Directory.GetParent(dataDir).Parent.Parent.FullName;
                AppDomain.CurrentDomain.SetData(
" DataDirectory " , dataDir);
            }       
            
using  (IDbConnection conn  =   new  SqlConnection( @" Data Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\YTBank.mdf;Integrated Security=True;User Instance=True " ))
            {
                conn.Open();
                IDbCommand cmd 
=  conn.CreateCommand();
                
                cmd.CommandText 
=   " select * from T_Records " ;
                
using  (IDataReader reader  =  cmd.ExecuteReader())
                {
                    XElement cfx 
=   new  XElement( " CFX " );
                    
while  (reader.Read())
                    {
                        XElement msg 
=   new  XElement( " MSG " );
                        XElement e交易码 
=   new  XElement( " 交易码 " );
                        e交易码.SetAttributeValue(
" val " ,reader[ " TradeNo " ]);
                        msg.Add(e交易码);

                        XElement e流水号 
=   new  XElement( " 流水号 " );
                        e流水号.SetAttributeValue(
" val " , reader[ " SeqNo " ]);
                        msg.Add(e流水号);

                        XElement e金额 
=   new  XElement( " 金额 " );
                        e金额.SetAttributeValue(
" val " , reader[ " Amount " ]);
                        msg.Add(e金额);

                        XElement e付款机构 
=   new  XElement( " 付款机构 " );
                        e付款机构.SetAttributeValue(
" val " , reader[ " PayCompany " ]);
                        msg.Add(e付款机构);

                        XElement e付款单位账号 
=   new  XElement( " 付款单位账号 " );
                        e付款单位账号.SetAttributeValue(
" val " , reader[ " PayAccount " ]);
                        msg.Add(e付款单位账号);

                        XElement e收款机构 
=   new  XElement( " 收款机构 " );
                        e收款机构.SetAttributeValue(
" val " , reader[ " RecvCompany " ]);
                        msg.Add(e收款机构);

                        XElement e收款单位账号 
=   new  XElement( " 收款单位账号 " );
                        e收款单位账号.SetAttributeValue(
" val " , reader[ " RecAccount " ]);
                        msg.Add(e收款单位账号);

                        cfx.Add(msg);
                    }

                    Console.WriteLine(cfx.ToString());
                }
            }

            Console.ReadKey();
        }
    }

转载于:https://www.cnblogs.com/caoshuai/archive/2010/07/13/1776704.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值