惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - 灵魂边缘

Detecting the File Download Dialog In the Browser The IE 'non-disappearing content' bug 10个强大的Javascript表单验证插件推荐 使用javascript检测客户端是否是mobile的类型,如果是就跳转到另外一个页面 在javascript中对一个对象数组进行排序 Devenv /ResetSkipPkgs - 灵魂边缘 Invalid Viewstate error and how to fix it? 在asp.net中如何管理cache 用Javascript取得URL参数(Get URL parameters/query string using Javascript) - 灵魂边缘 用JavaScript对表格排序 - 灵魂边缘 使用 jQuery 简化 Ajax 开发 Localization/Globalization in ASP.Net 2.0 Redirecting to custom 401 page when "Access denied" occures within an ASP.NET application - 灵魂边缘 .net中完成海量数据的批量插入和更新 - 灵魂边缘 - 博客园 存储过程跨系统跨数据库操作 - 灵魂边缘 ASP.NET 2.0 中配合Master Page 使用CSS - 灵魂边缘 正则表达式全部符号解释 - 灵魂边缘 - 博客园 [转]asp.net导出数据到Excel的三种方法 ASP.NET:创建Linked ValidationSummary, 深入理解ASP.NET的Validation (转)
Generating change scripts in SQL Server 2005 Management Studio
灵魂边缘 · 2009-10-14 · via 博客园 - 灵魂边缘

In the typical dev environment, there is a development server, a functional testing server, a quality assurance server, and one or more production servers. Let's suppose that your mandate is to modify a table on the development server, adding a column or changing a column's name or data type, and yet you still have 50 or so more changes to make. Now it's time to roll out the changes to the other servers in cascading order.

SQL Server 2005 Management Studio comes to the rescue with its handy Generate Change Script button, which you can see in Figure A. The Generate Change Script button appears after you right-click a table and choose Modify from the shortcut menu. The code attached to the button analyzes the current table definition, compares it to your changed definition, and writes a script that will alter the old table to conform to the new definition. By running this script on a remote database, you can make changes to databases installed at client or branch sites.

Figure A

Figure A: Generate Change Script button

Now you're asked to change all nchar and nvarchar columns to char and varchar respectively. This could be a minefield, particularly where foreign keys are concerned. (For the moment, we will sidestep the issue of using such columns as primary keys, as opposed to identity columns.)

Weekly SQL tips in your inbox

TechRepublic's free SQL Server newsletter, delivered each Tuesday, contains hands-on tips that will help you become more adept with this powerful relational database management system.

Automatically sign up today!

When you begin to make these changes, you'll discover another cool hidden feature in SQL Server 2005 Management Studio: the Data Type Change. The dialog box will appear if you change the data type or anything else on a column that is a foreign key. For example, after changing all instances of nchar to char and nvarchar to varchar, the Data Type Change Required dialog box (see Figure B) popped up. After reading the warning that I might lose data due to the conversion, I clicked the Yes button to proceed.

Figure B

Figure B: SQL Server 2005 Management Studio detects that the CustomerID column is a foreign key elsewhere, and notifies you that all instances will be changed.

SQL Server 2005 Management Studio generated the code to perform all these changes and presented me with a preview for my verification. (Note: In the preview window, you can't see all the code, but you can select it all and paste it into an editor for easier viewing.) Listing C contains the generated code.

If you are faced with this type of change request and it reverberates through your entire database, then generating individual scripts like the one presented above can be quite tedious. You can save time by using various solutions, such as data-modeling tools or Red Gate Software's SQL Compare, which can "diff" two databases and update one from the changes made to the other. But, when your tasks are less monumental, SQL Server 2005 Management Studio does a wonderful job.

Miss a column?

Check out the SQL Server archive, and catch up on the most recent editions of Arthur Fuller's column.