首页 > 编程技术 > php

SQL Server根据查询结果,生成XML文件

发布时间:2016-11-25 16:41

/*
'bcp' 不是内部或外部命令,也不是可运行的程序?
看看在C:Program FilesMicrosoft SQL Server80ToolsBinn里面有没有bcp.exe这个文件
然后看看path里面加C:Program FilesMicrosoft SQL Server80ToolsBinn这个目录没有.
右键我的电脑--属性--高级--环境变量--在系统变量中找到path--编辑
在变量值的最后加上:
C:Program FilesMicrosoft SQL Server80ToolsBINN
*/
/**********************************************************************
存储过程: P_SaveXML
功能: 生成XML文件
参数: 表名
返回: 指定目录的XML文件
调用方法: 传递中间表TB_TABLECOLUMN_T存在的表名
exec P_ZehuaSavexml 'WQ_STINFO_B,WQ_PHY_D','D:xx.xml'
最后更改日期: 2005-8-17
联系方式: zlp@zehua.com.cn
备注: 根据中间表生成符合标准格式的XML文件
www.111cn.net
**********************************************************************/
/*
exec P_ZehuaSavexml 'WQ_STINFO_B,WQ_PHY_D','D:xx.xml'
*/
go
create proc P_ZehuaSavexml
@TableCodeS varchar(8000),
@fname varchar(1000)='c: mp.xml' --默认保存的XML文件地址
as
declare @sql nvarchar(200),@sql1 varchar(400)
declare @cnt int,@Table_Name varchar(20)
declare @i int,@TableCode varchar(20)
declare @err int,@src varchar(255),@desc varchar(255)
create table ##t(re nvarchar(4000))
insert ##t
select Re='<?xml version="1.0" encoding="gb2312"?>'
union all select '<ZehuaTableInfoXml>'
set @i=charindex(',',@TableCodeS)
while @i>0
begin
set @TableCode=left(@TableCodeS,@i-1)
set @sql=''
set @sql=N'select @cnt=count(*),@Table_Name=max(Table_Name) from '
set @sql=@sql N'('
set @sql=@sql N'select top 100 percent * from TB_TABLECOLUMN_T where '
set @sql=@sql N'TABLE_CODE=''' @TableCode ''' and COLUMNS_ISKEY=''√'' '
set @sql=@sql N'order by COLUMNS_SORT '
set @sql=@sql N')'
 
      数据表都已经创建起来了,假设我们已经插入了许多的数据,我们就可以用自己喜欢的方式对数据表里面的信息进行检索和显示了,比如说:可以象下面这样把整个数据表内的内容都显示出来
            select * from president;
      也可以只选取某一个数据行里的某一个数据列
            select birth from president where last_name=’Eisenhower’;
      select语句的通用形式如下:
            select 你要的信息
            from 数据表(一个或多个)
            where 满足的条件
      select语句有几个子句,他们的各种搭配能帮你查出最感兴趣的信息,这些子句可以很简单,也可以很复杂,看看作者是如何详细讲解的
1,            用各种操作符来设定检索条件
      要想让select语句只把满足特定条件的记录检索出来,就必须给它加上where字句来设置数据行的检索条件。只有这样,才能有选择地把数据列的取值满足特定要求的那些数据行挑选出来。可以针对任何类型的值进行查找,比如说,对数值进行搜索
select * from score where score>95; //显示所有分数在95分以上的信息
      也可以针对字符串值进行查找
select last_name,first_name from president where last_name=’Tom’; //找出所有姓tom的总统
      还可以对不同类型的值进行组合查找
select last_name,first_name,birth,state from president
where birth<’1950-1-1’ and (state=’VA’ or state=’BA’);
      //找出1950年前出生于VA州或BA州的总统
      可见 where子句中可以使用的是算术操作符(+-*/%),比较操作符(<>=)以及逻辑运算符,我们应该熟练理解这些操作符的含义(都很简单)
安装篇
PHP MySQL Linux目前已逐渐成为小型web服务器的一种经典组合。在indows环境下构筑和调试MySQL数据库是许多网站开发者的一种首选。本人在Windows98环境下初学MySQL,现将学习过程与经验总结出来供大家参考。
1、下载mysql-3.23.35-win.zip并解压;
2、运行setup.exe;选择d:mysql,"tyical install"
3、启动mysql,有如下方法:
方法一:使用winmysqladmin
1)、进入d::mysqlin目录,运行winmysqladmin.exe,在屏幕右下角的任务栏内会有一个带红色的图符
2)、鼠标左键点击该图符,选择“show me”,出现“WinMySQLAdmin”操作界面;首次运行时会中间会出现一个对话框要求输入并设置你的用户名和口令
3)、选择“My.INI setup”
4)、在“mysqld file”中选择“mysqld-opt”(win9x)或“mysqld-nt”(winNT)
5)、选择“Pick-up or Edit my.ini values”可以在右边窗口内对你的my.ini文件进行编辑
6)、选择“Save Modification”保存你的my.ini文件
7)、如果你想快速使用winmysqladmin(开机时自动运行),选择“Create ShortCut on Start Menu”
8)、测试:
进入DOS界面;
在d:mysqlin目录下运行mysql,进入mysql交互操作界面
输入show databases并回车,屏幕显示出当前已有的两个数据库mysql和test

方法二:不使用winmysqladmin
1)、在DOS窗口下,进入d:/mysql/bin目录
2)、win9X下)运行:
mysqld
在NT下运行:
mysqld-nt --standalone
3)、此后,mysql在后台运行
4)、测试mysql:(在d:/mysql/bin目录下)
a)、mysqlshow
正常时显示已有的两个数据库mysql和test
b)、mysqlshow -u root mysql
正常时显示数据库mysql里的五个表:
columns_priv
db
host
tables_priv
user
c)、mysqladmin version status proc
显示版本号、状态、进程信息等
d)、mysql test
进入mysql操作界面,当前数据库为test
5)、mysql关闭方法:
mysqladmin -u root shutdown
4、至此,MySQL已成功安装,接着可以熟悉MySQL的常用命令并创建自己的数据库了。

先创建一个与原表一样的表,
然后在表上创建 ignore_dup_key 索引,如下:
CREATE UNIQUE INDEX removedups
ON  #table_copy (name)
WITH IGNORE_DUP_KEY
然后在导入原表数据,简单吧


在SQL Server 2000中,我们想在数据库表中直接修改数据,一般的操作方法是:在SQL Server 企业管理中,选择相应的表,点击右键,在“打开表”中选择“查询”,在SQL编辑窗口中输入SQL语句找到要修改的记录,然后在结果窗口中直接修改相应的字段。
那在SQL Server 2005中,需要怎样操作呢?
在SQL Server Management Studio中,找到相应的表,点击右键,选择“Open Table”,然后点击“Show Sql Pane”按钮,在Sql Pane窗口中输入SQL语句找到要修改的记录,然后在结果窗口中直接修改相应的字段。
也许你觉得SQL Server 2005与SQL Server 2000的操作没什么区别。
但问题就出在选择“Open Table”时,当“Open Table”,SQL Server Management Studio会执行查询表中所有记录的操作,如果表中数据很多,就会有个等待查询的时间,你会为这个等待很恼火,因为你只是想修改某个记录,这个查询根本是多余的。在SQL Server 2000中也有“Open Table”,也是查询所有记录,但SQL Server 2000还提供了“查询”操作,就是文章开始讲到的操作方法。
你也许会说SQL Server Management Studio中提供了“Script Table as”操作,但通过Script Table as的Select To查询的结果是只读的,无法进行修改。如果通过“Update to”进行操作也不方便,因为多数情况下,在修改数据之前,先要看一下原来的数据。如果直接Update,可能会由于SQL语句中输错了条件而进行了不是期望的修改。
我也是刚刚接触SQL Serve r2005,也许SQL Server 2005提供了其他方便的操作方法,但我没找到。如果你知道,欢迎你告诉我。
出处:dudu-快乐程序员


标签:[!--infotagslink--]

您可能感兴趣的文章: