هذا لا يعمل في SQL Server 2008:
ALTER TABLE Employee ALTER COLUMN CityBorn SET DEFAULT 'SANDNES'
الخطأ هو:
بناء جملة غير صحيح بالقرب من الكلمة الأساسية "SET".
ما الخطأ الذي افعله؟
سيعمل هذا في SQL Server:
ALTER TABLE Employee ADD CONSTRAINT DF_SomeName DEFAULT N'SANDNES' FOR CityBorn;
ALTER TABLE Employee ADD DEFAULT 'SANDNES' FOR CityBorn
لا يمكن استخدام عمود التغيير لذلك ، استخدم الإضافة بدلاً من ذلك
ALTER TABLE Employee
ADD DEFAULT('SANDNES') FOR CityBorn
الطريقة الصحيحة للقيام بذلك هي كما يلي:
قم بتشغيل الأمر:
sp_help [table name]
انسخ اسم CONSTRAINT
.
إسقاط DEFAULT CONSTRAINT
:
ALTER TABLE [table name] DROP [NAME OF CONSTRAINT]
قم بتشغيل الأمر أدناه:
ALTER TABLE [table name] ADD DEFAULT [DEFAULT VALUE] FOR [NAME OF COLUMN]
كان حل Hoodaticus مثاليًا ، شكرًا لك ، ولكني كنت بحاجة أيضًا إلى إعادة تشغيله ووجدت هذه الطريقة للتحقق مما إذا كان قد تم ...
IF EXISTS(SELECT * FROM information_schema.columns
WHERE table_name='myTable' AND column_name='myColumn'
AND Table_schema='myDBO' AND column_default IS NULL)
BEGIN
ALTER TABLE [myDBO].[myTable] ADD DEFAULT 0 FOR [myColumn] --Hoodaticus
END
هناك سيناريوهان يمكن فيه تغيير القيمة الافتراضية لعمود ،
سؤال
create table table_name
(
column_name datatype default 'any default value'
);
في هذه الحالة ، لا يسمح خادم SQL بتعديل قيمة القيد الافتراضية الحالية. لذلك لتغيير القيمة الافتراضية ، نحتاج إلى حذف القيد الافتراضي الذي تم إنشاؤه أو إنشاء المستخدم بواسطة القيد الافتراضي. وبعد ذلك يمكن تعيين القيمة الافتراضية لعمود معين.
اتبع بعض الخطوات:
تنفيذ إجراء قاعدة بيانات النظام هذا ، فإنه يأخذ اسم الجدول كمعلمة. تقوم بإرجاع قائمة بجميع القيود لكل الأعمدة داخل الجدول.
execute [dbo].[sp_helpconstraint] 'table_name'
بناء الجملة:
alter table 'table_name' drop constraint 'constraint_name'
بناء الجملة:
alter table 'table_name' add default 'default_value' for 'column_name'
في صحتك @!!!
وجدت فقط 3 خطوات بسيطة لتغيير العمود الموجود بالفعل الذي كان فارغًا من قبل
update orders
set BasicHours=0 where BasicHours is null
alter table orders
add default(0) for BasicHours
alter table orders
alter column CleanBasicHours decimal(7,2) not null
ALTER TABLE [dbo].[Employee] ADD DEFAULT ('N') FOR [CityBorn]
حاول اتباع الأوامر ؛
ALTER TABLE Person11
ADD CONSTRAINT col_1_def
DEFAULT 'This is not NULL' FOR Address
أول انخفاض القيود
https://stackoverflow.com/a/49393045/2547164
DECLARE @ConstraintName nvarchar(200)
SELECT @ConstraintName = Name FROM SYS.DEFAULT_CONSTRAINTS
WHERE PARENT_OBJECT_ID = OBJECT_ID('__TableName__')
AND PARENT_COLUMN_ID = (SELECT column_id FROM sys.columns
WHERE NAME = N'__ColumnName__'
AND object_id = OBJECT_ID(N'__TableName__'))
IF @ConstraintName IS NOT NULL
EXEC('ALTER TABLE __TableName__ DROP CONSTRAINT ' + @ConstraintName)
ثانيا إنشاء القيمة الافتراضية
ALTER TABLE [table name] ADD DEFAULT [default value] FOR [column name]
مثل إجابة Yuck مع التحقق للسماح بتشغيل البرنامج النصي أكثر من مرة دون خطأ. (أقل سلاسل التعليمات البرمجية/المخصصة من استخدام information_schema.columns)
IF object_id('DF_SomeName', 'D') IS NULL BEGIN
Print 'Creating Constraint DF_SomeName'
ALTER TABLE Employee ADD CONSTRAINT DF_SomeName DEFAULT N'SANDNES' FOR CityBorn;
END
في حالة وجود قيود بالفعل باسمه الافتراضي:
-- Drop existing default constraint on Employee.CityBorn
DECLARE @default_name varchar(256);
SELECT @default_name = [name] FROM sys.default_constraints WHERE parent_object_id=OBJECT_ID('Employee') AND COL_NAME(parent_object_id, parent_column_id)='CityBorn';
EXEC('ALTER TABLE Employee DROP CONSTRAINT ' + @default_name);
-- Add default constraint on Employee.CityBorn
ALTER TABLE Employee ADD CONSTRAINT df_employee_1 DEFAULT 'SANDNES' FOR CityBorn;