网站建设资讯

NEWS

网站建设资讯

mysql列级约束怎么写 sql列级约束

mysql这个列级权限用GRANT怎么写,高手来

mysql这个列级权限用GRANT怎么写

成都创新互联公司主营叶县网站建设的网络公司,主营网站建设方案,app软件定制开发,叶县h5微信小程序开发搭建,叶县网站营销推广欢迎叶县等地区企业咨询

grant 权限 on 数据库对象 to 用户

一、grant 普通数据用户,查询、插入、更新、删除 数据库中所有表数据的权利。

grant select on testdb.* to common_user@’%’

grant insert on testdb.* to common_user@’%’

grant update on testdb.* to common_user@’%’

grant delete on testdb.* to common_user@'%'

或者

grant select, insert, update, delete on testdb.* to common_user@’%’

MYsql 怎么约束列的取值范围

MYsql 怎么约束列的取值范围

一般是建立check约束。例如设置sex一列取值只能为'男'或'女' 建表tab10时命令为create table tabl0 (sex char(2) check(sex in ('男','女'))..

mysql基础数据类型118-124

#常见的数据类型

/*

数值型:

整形

小数:

    定点数

    浮点数

字符型:

较短的文本:char、varchar

较长的文本:text、blob(较长的二进制数据)

日期型:

*/

#一、整形

/*

分类:

tinyint、smallint、mediumint、int/integer、bigint

1            2                3                        4                8

特点:

-如果不设置无符号还是有符号,默认是有符号,如果想设置无符号,需要添加unsigned关键字

-如果插入的数值超出了整形的范围,会报out of range异常,并且插入临界值

-如果不设置长度,会有默认的长度

-长度代表了显示的最大宽度,如果不够会用0在左边填充,但是必须搭配zerofill使用

*/

#1.如何设置无符号和有符号

CREATE TABLE tab_int(

t1 INT

t2 INT ZEROFILL  【无符号】

);

#二、小数

/*

浮点型

float(M, D)

double(M, D)

定点型

dec(M, D)

decimal(M, D)

特点:

-M:整数部位+小数部位

-D:小数部位

-M和D都可以省略

如果是decimal,则M默认为10,D默认为0

如果是float和double,则会根据插入的数值的精度来决定精度

定点型的精确度较高,如果要求插入数值的精度较高如货币运算等则考虑使用

*/

CREATE TABLE tab_float (

f1 FLOAT(5, 2)

f2 DOUBLE (5, 2)

f3 DECIMAL(5, 2)

)

#原则:

/*

所选择的类型越简单越好,能保存数值的类型越小越好

*/

#三、字符型

/*

较短的文本:

char

varchar

较长的文本:

text

blob(较大的二进制)

特点:

                写法                M的意思                                         特点                       空间的耗费                    效率        

char            char(M)       最大的字符数,可以省略         固定长度的字符            比较耗费                        高

varchar      carchar(M)    最大的字符数,不可以省略    可变长度的字符            比较节省                        低

*/

CREATE TABLE tab_char(

c1 ENUM('a','b','c')

)

CREATE TABLE tab_set(

s1    SET ('a','b','c','d')

)

#四、日期型

特点:

                 字节                        范围                    时区等的影响

datetime                          8                            10000-9999            不受

timestamp                        4                        1970-2038                    受

CREATE TABLE tab_date(

t1    DATETIME,

t2    TIMESTAMP

)

#常见约束

/*

含义:一种限制,用于限制表中的数据,为了保证表中的数据的准确和可靠性

分类:六大约束

NOT NULL:非空,用于保证该字段的值不能为空,比如姓名、学号等

default:默认,用于保证该字段有默认值,比如性别

primary key:主键,用于保证该字段的值具有唯一性,并且非空,比如学号等

unique:唯一,用于保证该字段的值具有唯一性,可以为空,比如座位号

check:检查约束【mysql中不支持】,比如年龄、性别

foreign key:外键,用于限制两个表的关系,用于保证该字段的值必须来自于主表的关联列的值,在从表添加外键约束,用于引用主表中某列的值,比如员工表的部门编号,员工表的工种编号

添加约束的时机:

1.创建表时

2.修改表时

约束的添加分类:

列级约束:

    六大约束语法上都支持,但外键约束没有效果

表级约束:

    除了非空、默认,其他的都支持

*/

CREATE TABLE 表名(

字段名    字段类型    列级约束,

表级约束

)

#一、创建表时添加约束

/*

语法:

直接在字段名和类型后面追加 约束类型即可

只支持:

*/

#1.添加列级约束

create table stuinfo (

id int primary key,  #主键

stuName  varchar(20) not null,   #非空

gender char(1)  check(gender='男' OR gender ='女'),  #检查约束

seat int unique,  #唯一约束

age  int  default  18,  #默认约束

majorId int foreign key references major (id)  #外键

)

create table major (

id int primary key,

majorName  varchar (20)

)

desc stuinfo   #查看表结构

show index from stuinfo  #查看stuinfo表中所有的索引,包括主键、外键、唯一

#2、添加表级约束

create table stuinfo (

id int

stuName  varchar(20) 

gender char(1) 

seat int,

age  int  , 

majorId int

constraint pk primary key (id),  #主键

constraint  uq unique (seat),  #唯一键

constraint  ck check (gender = '男' or gender = '女'),   #检查

constraint  fk_stuinfo_major foreign key(majorid) references major(id)  #外键

)

SQL中规定某列值只能是0或者1的约束该怎么写?

SQL CHECK 约束。

CHECK 约束用于限制列中的值的范围。

如果对单个列定义 CHECK 约束,那么该列只允许特定的值。

如果对一个表定义CHECK约束,那么此约束会在特定的列中对值进行限制。

--删除表

drop table temp;

--创建表

CREATE TABLE temp (flag NUMBER(1));

--增加约束

ALTER TABLE temp ADD CONSTRAINT ck_temp_flag CHECK

(flag=1 or flag=0);

--测试效果版

insert into temp values(1);

insert into temp values(0);

insert into temp values(1);

--测试效果(约束禁止插入数据),提示权:违反检查约束条件

insert into temp values(2);

insert into temp values(3);

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_P0)

)

扩展资料:

不同数据库的约束写法:

SQL Server / Oracle / MS Access:

CREATE TABLE Persons

(

Id_P int NOT NULL CHECK (Id_P0),

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_P0 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_P0)

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

MySQL / SQL Server / Oracle / MS Access:

ALTER TABLE Persons

ADD CONSTRAINT chk_Person CHECK (Id_P0 AND City='Sandnes')

撤销 CHECK 约束。

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

SQL Server / Oracle / MS Access:

ALTER TABLE Persons

DROP CONSTRAINT chk_Person


分享标题:mysql列级约束怎么写 sql列级约束
文章URL:http://njwzjz.com/article/ddggpdj.html