ms_sql_check

转自http://www.w3school.com.cn/sql/sql_check.asp



SQL CHECK Constraint on CREATE TABLE

下面的 SQL 在 "Persons" 表创建时为 "Id_P" 列创建 CHECK 约束。CHECK 约束规定 "Id_P" 列必须只包含大于 0 的整数。

My SQL:

CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CHECK (Id_P>0)
)

SQL Server / Oracle / MS Access:

CREATE TABLE Persons
(
Id_P int NOT NULL CHECK (Id_P>0),
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
)

如果需要命名 CHECK 约束,以及为多个列定义 CHECK 约束,请使用下面的 SQL 语法:

MySQL / SQL Server / Oracle / MS Access:

CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')
)

SQL CHECK Constraint on ALTER TABLE

如果在表已存在的情况下为 "Id_P" 列创建 CHECK 约束,请使用下面的 SQL:

MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ADD CHECK (Id_P>0)

如果需要命名 CHECK 约束,以及为多个列定义 CHECK 约束,请使用下面的 SQL 语法:

MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons
ADD CONSTRAINT chk_Person CHECK (Id_P>0 AND City='Sandnes')

撤销 CHECK 约束

如需撤销 CHECK 约束,请使用下面的 SQL:

SQL Server / Oracle / MS Access:

ALTER TABLE Persons
DROP CONSTRAINT chk_Person
使用ck数据库,帮我优化下面这个sqlSELECT pc.aid AS aid, mpjiv.name AS proName, mpjiv.companyName AS companyName, pc.contract_no AS contractNo, pc.contract_status AS contractStatus, pc.service_mode AS serviceMode, pc.contract_url AS contractUrl, pc.contract_file_name AS contractFileName, pp.productTypes AS productTypes, bp.businessTypes AS businessTypes, pc.contract_amount AS contractAmount, pc.collection_unit AS collectionUnit, pcs.user_id AS salesId, pcs.dept_id AS deptId, CASE WHEN pc.service_mode = 2 THEN pc.service_year ELSE pcq.qa_year END AS serviceYear, CASE WHEN pc.service_mode = 2 THEN pc.service_end_time ELSE pcq.qa_end_time END AS endTime, pc.focus_info AS focusInfo, pc.documentation_status AS documentationStatus, csm.modelTypes AS modelTypes, pc.contract_scale AS contractScale, pc.customer_check_accept AS customerCheckAccept, t.constructor_type AS constructorValue, pcq.amount AS amount, pc.pro_manager_id AS proManagerId, pc.solve_user_id AS solveUserId, pc.create_by AS createBy, pc.create_time AS createTime FROM `ms_pt_contract` pc LEFT JOIN ms_pt_contract_business pcb ON pc.contract_no = pcb.contract_no LEFT JOIN ms_pt_contract_qa pcq ON pc.contract_no = pcq.contract_no LEFT JOIN ms_pt_contract_product pcp ON pc.contract_no = pcp.contract_no LEFT JOIN ms_pt_contract_sales pcs ON pc.contract_no = pcs.contract_no LEFT JOIN ms_pt_contract_sales_model pcsm ON pcs.aid = pcsm.pt_contract_sales_id LEFT JOIN ms_pro_jbxx_info_view mpjiv ON pc.pro_id = mpjiv.aid LEFT JOIN ( SELECT pcb.contract_no AS contract_no, SUM(if(pcb.business_type = 1, pcb.constructor_type, NULL)) AS constructor_type FROM ms_pt_contract_business pcb GROUP BY pcb.contract_no) t ON t.contract_no = pc.contract_no LEFT JOIN ( SELECT pcb.contract_no AS contract_no, arrayStringConcat(arraySort(groupArray(DISTINCT pcb.business_type)), ',') AS businessTypes FROM ms_pt_contract_business pcb GROUP BY pcb.contract_no) bp on bp.contract_no = pc.contract_no LEFT JOIN ( SELECT mpcp.contract_no AS contract_no, arrayStringConcat(arraySort(groupArray(mpcp.product_type)), ',') AS productTypes FROM ms_pt_contract_product mpcp GROUP BY mpcp.contract_no) pp on pp.contract_no = pc.contract_no LEFT JOIN ( SELECT mpcs.contract_no AS contract_no, arrayStringConcat(arraySort(groupArray(DISTINCT mpcsm.model_type)), ',') AS modelTypes FROM ms_pt_contract_sales mpcs left join ms_pt_contract_sales_model mpcsm on mpcs.aid = mpcsm.pt_contract_sales_id GROUP BY mpcs.contract_no) csm on pc.contract_no = csm.contract_no WHERE pc.is_del = 0 AND pcsm.model_type = 1 AND mpjiv.use_type = 1 GROUP BY pc.aid, pc.company_id, pc.pro_id, pc.contract_no, pc.contract_status, pc.service_mode, pc.contract_amount, pc.collection_unit, pcs.user_id, pcs.dept_id, pc.focus_info, pc.documentation_status, pc.contract_scale, pc.customer_check_accept, pcq.amount, pc.pro_manager_id, pc.solve_user_id, pc.create_by, pc.create_time, pc.contract_url, pc.contract_file_name, serviceYear, endTime, proName, companyName, t.constructor_type,bp.businessTypes,pp.productTypes,csm.modelTypes ORDER BY pc.create_time DESC
03-08
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值