创建数据库:

CREATE DATABASES 数据库名;

选择数据库:

USE 数据库名;

删除数据库:

DROP DATAVBASE 数据库名;

创建表:

CREATE TABLE IF NOT NULL EXISTS 表名 (字段1 数据类型 【字段属性|约束|索引|注释】,
.............); 字段的约束及属性
CREATE TABLE IF NOT NULL 表名(字段1 数据类型 PRIMARY KEY //单字段主键);

多字段联合主键:

CREATE TABLE IF NOT NULL 表名
  ( 字段1 数据类型 ,
   字段2 数据类型
   PRIMARY KEY (字段1,字段2)//多联合复合主键
);

注释:

 CREATE TABLE TEXT ( `id` int(11) UNSIGNED COMMENT'编号')COMMENT'测试表';

编码格式设置:

CREATE TABLE TEXT( `id` int(11) UNSIGNED COMMENT'编号')CHARSET=字符集名;

查看表:

SHOW TABLES;

查看表定义:

DESCRIBE 表名;或 DESC 表名;

如果是在DOC窗口下执行,最好先执行 SET NAMES gbk;避免产生乱码

删除表:

DROP TABLE IF EXISTS 表名;

查看默认存储引擎:

SHOW VARIABLES LIKE `storage_engine%`;

指定表的存储引擎:

CREATE TANLE 表名(#省略代码)ENGINE=存储引擎;

常用引擎:InnoDB 和 MyISAM
安装板MySQL5.5默认存储引擎是InnoDB

常用修改语法:

#修改表名:

ALTER TABLE 旧表明 RENAME [TO] 新表明; TO:可选项

#添加字段:

ALTER TABLE 表名 ADD 字段名 数据类型 [属性]; 属性:可选项

#修改字段:

ALTER TABLE 表名 CHANGE 原字段名 新字段名 数据类型 [属性];

#删除字段:

ALTER TABLE 表名 DROP 字段名;

mysql中replace函数直接替换mysql数据库中某字段中的特定字符串:

UPDATE `ts_weibo` SET

 `weibo_id` = replace (`weibo_id`,'19782687','14204277'),
`uid` = replace (`uid`,'19782687','14204277'
.....
WHERE
`weibo_id` LIKE '%19782687%' or
`uid` LIKE '%19782687%'

非空约束(NOT NULL):添加非空约束

1)建表时直接添加

CREATE TABLE t_user(user_id INT(10) NOT NULL);

2)通过ALTER 语句

ALTER TABLE t_user MODIFY user_id INT(10) NOT NULL;
ALTER TABLE t_user CHANGE user_id user_id INT(10) NOT NULL;

删除非空约束

1):ALTER TABLE t_user MODIFY user_id INT(10);
2):ALTER TABLE t_user CHANGE user_id user_id INT(10);

删除主键和唯一约束:在mysql中删除主键需要两步

(1):如果有auto_increment自增,先删除之;

(2):删除主键约束 primary key;

首先要删除auto_increment语法如下:

alter table 表名 modify id int(11);

这里用的modify,只改变数据类型,也可以用change,改变列名的同时输入新的数据类型。

下一步就是删除主键:语法如下:

alter table 表名 drop primary key;

 添加唯一约束:

1)建表时直接添加

CREATE TABLE t_user(user_id INT(10) UNIQUE);

CREATE TABLE t_user(
  user_id INT(10),
  user_name VARCHAR(30),
  CONSTRAINT UN_PHONE_EMAIL UNIQUE(user_id,user_name)#复合约束
); CREATE TABLE t_user (user_id INT(10),UNIQUE KEY(user_id) );

通过ALTER语句添加:

ALTER TABLE t_user MODIFY user_id INT(10) UNIQUE;

ALTER TABLE t_user CHANGE user_id user_id INT(10) UNIQUE;

这里用的modify,只改变数据类型,也可以用change,改变列名的同时输入新的数据类型。

删除唯一性约束:

ALTER TABLE t_user DROP INDEX user_id;//指定要删除的字段名称

ALTER TABLE `a` DROP INDEX UN_Name ;//指定要删除的索引名称

注:唯一但是可以为空(空和空不相等)

PRIMARY KEY(主键约束):

1)建表时直接添加
CREATE TABLE text(`user_id` INT(10) PRIMARY KEY);
CREATE TABLE `text`
(`user_id` INT(10),
user_name` VARCHAR(30),
CONSTRAINT PK_ID_NAME PRIMARY KEY(user_id,user_name)#复合约束
);
CREATE TABLE `text`
(`user_id` INT(10),
PRIMARY KEY(user_id)
);

通过ALTER语句添加:

ALTER TABLE t_user MODIFY user_id INT(10) PRIMARY KEY;

ALTER TABLE t_user CHANGE user_id user_id INT(10) PRIMARY KEY;

ALTER TABLE t_user ADD PRIMARY KEY(user_id);

ALTER TABLE t_user ADD CONSTRAINT PK_ID PRIMARY KEY(user_id);

这里用的modify,只改变数据类型,也可以用change,改变列名的同时输入新的数据类型。

ALTER TABLE  text  ADD  CONSTRAINT  pk_textId  PRIMARY KEY  `text`(`textId`); 

删除主键约束:

ALTER TABLE  `text`  DROP PRIMARY KEY

FOREIGN KEY(外键约束):

首先创建两张表:A,B
从表A
CREATE TABLE `A`
(
`textId` INT PRIMARY KEY,
`textId1` INT(30),
`textName` NVARCHAR(30)
CONSTRAINT FK_A_B FOREIGN KEY(`textId1`) REFERENCES `b`(`textId1`)#添加外键约束
); 主表B
CREATE TABLE `B`
(
`textId1` INT PRIMARY KEY,
`textName` NVARCHAR(30)
);

另外一种写法:

ALTER TABLE `a` ADD CONSTRAINT fk_a_b FOREIGN KEY (`textId1`) REFERENCES `b`(`textId1`);

删除外键约束:

第一步:
ALTER TABLE `a` DROP FOREIGN KEY fk_a_b; 第二步:
DROP INDEX fk_a_b ON `a`;

注意事项: 删除外键约束的时候需要先删除外键约束,在删除索引才可以

键中的级联关系有以下几种情况:

#ON DELETE CASCADE 删除主表中的数据时,从表中的数据随之删除

#ON UPDATE CASCADE 更新主表中的数据时,从表中的数据随之更新

#ON DELETE SET NULL 删除主表中的数据时,从表中的数据置为空

#默认 删除主表中的数据前需先删除从表中的数据,否则主表数据不会被删除

CREATE TABLE students(
  stu_id INT(10) AUTO_INCREMENT PRIMARY KEY,
  stu_name VARCHAR(30) NOT NULL,
  stu_score FLOAT(5,2) DEFAULT 0.0,
  cla_id INT(10),
  CONSTRAINT FK_CLA_ID FOREIGN KEY(cla_id) REFERENCES class(cla_id) ON DELETE CASCADE
);
CREATE TABLE students(
  stu_id INT(10) AUTO_INCREMENT PRIMARY KEY,
  stu_name VARCHAR(30) NOT NULL,
  stu_score FLOAT(5,2) DEFAULT 0.0,
  cla_id INT(10),
  CONSTRAINT FK_CLA_ID FOREIGN KEY(cla_id) REFERENCES class(cla_id) ON UPDATE CASCADE
);
CREATE TABLE students(
  stu_id INT(10) AUTO_INCREMENT PRIMARY KEY,
  stu_name VARCHAR(30) NOT NULL,
  stu_score FLOAT(5,2) DEFAULT 0.0,
  cla_id INT(10),
  CONSTRAINT FK_CLA_ID FOREIGN KEY(cla_id) REFERENCES class(cla_id) ON DELETE SET NULL
);

注:插入数据时,先插入主表中的数据,再插入从表中的数据。删除数据时,先删除从表中的数据,再删除主表中的数据

AUTO_INCREMENT(自增长):

在创建表的时候添加:

CREATE TABLE t_user(user_id INT(10) AUTO_INCREMENT PRIMARY KEY); 

通过ALTER语句:

ALTER TABLE t_user MODIFY user_id INT(10) AUTO_INCREMENT;

ALTER TABLE t_user CHANGE user_id user_id INT(10) AUTO_INCREMENT;

删除自增长:

ALTER TABLE t_user MODIFY user_id INT(10);

ALTER TABLE t_user CHANGE user_id user_id INT(10);

注意:每张表只能有一列自增列,这里用的modify,只改变数据类型,也可以用change, 改变列名的同时输入新的数据类型。

DEFAULT(默认属性值) :

1)在创建表的时候添加

CREATE TABLE t_user(user_id INT(10) DEFAULT  3); 

2)通过ALTER语句

ALTER TABLE t_user MODIFY user_id INT(10) DEFAULT  2;

ALTER TABLE t_user CHANGE user_id user_id INT(10) DEFAULT  2;

删除默认约束:

ALTER TABLE t_user MODIFY user_id INT(10);

ALTER TABLE t_user CHANGE user_id user_id INT(10);

这里用的modify,只改变数据类型,也可以用change, 改变列名的同时输入新的数据类型。

UNSIGNED(无符号位):

1)在创建表的时候添加

CREATE TABLE t_user(user_id INT(10) UNSIGNED); 

2)通过ALTER语句

ALTER TABLE t_user MODIFY user_id INT(10) UNSIGNED;
ALTER TABLE t_user CHANGE user_id user_id INT(10) UNSIGNED;

删除无符号:

ALTER TABLE t_user MODIFY user_id INT(10);
ALTER TABLE t_user CHANGE user_id user_id INT(10);

无符号作用于数值类型

ZEROFILL(零填充):

添加零填充

1)在创建表的时候添加

CREATE TABLE t_user(user_id INT(10) ZEROFILL);

2)通过ALTER语句

ALTER TABLE t_user MODIFY user_id INT(10) ZEROFILL;
ALTER TABLE t_user CHANGE user_id user_id INT(10) ZEROFILL;

3)删除零填充:

ALTER TABLE t_user MODIFY user_id INT(10);
ALTER TABLE t_user CHANGE user_id user_id INT(10);

注:零填充会将未将有效位以外的位用零来显示,比如某字段数据类型为INT(5),而插入的值为2,那么零填充会显示00002;但是,这个效果在Navicat for MySQL中显示不出来,只有在DOS窗口下才能显示

 

分享知识-快乐自己:MySQL中的约束,添加约束,删除约束,以及一些其他修饰的更多相关文章

  1. 使用sql语句实现添加、删除约束

    --主键约束(Primary Key constraint):要求主键列的数据唯一,并且不允许为空. --唯一约束(Unique Constraint):要求该列唯一,允许为空,但只能出现一个空值. ...

  2. ylb:使用sql语句实现添加、删除约束

    ylbtech-SQL Server:SQL Server-使用sql语句实现添加.删除约束 --主键约束(Primary Key constraint):要求主键列的数据唯一,并且不允许为空. -- ...

  3. MySQL中添加、删除约束

    MySQL中6种常见的约束:主键约束(primary key).外键约束(foreign key).非空约束(not null).唯一性约束(unique).默认值约束(defualt).自增约束(a ...

  4. LINUX中查看、添加、删除PATH以及永久添加PATH

    1.查看PATH变量 echo $PATH 会出现: 路径1:路径2:路径3 2.添加PATH变量 export PATH=$PATH:新添加的路径 用此方法添加的PATH,在关闭或者重启LINUX后 ...

  5. 给MySQL中数据表添加字段

    添加一个char字段: mysql> alter table stock add src char(20); Query OK, 3766 rows affected (0.65 sec) Re ...

  6. mysql中给表添加字段

    添加字段: 格式:alter table 表名 add 字段名 字段类型 ; 如:给表stu_info 添加一个字段type,类型为varchar(30) alter table stu_info a ...

  7. mysql中注释的添加修改

    1 创建表的时候写注释,在使用comment关键字语法:create table 表名 (字段名 类型 comment '字段的注释' )comment='表的注释'; 查看一下 2 修改表的注释al ...

  8. viewpager中彻底性动态添加、删除Fragment

    为了解决彻底删除fragment,我们要做的是:1.将FragmentPagerAdapter 替换成FragmentStatePagerAdapter,因为前者只要加载过,fragment中的视图就 ...

  9. 为SQL Server表中的列添加/修改/删除注释属性(sp_addextendedproperty、sp_updateextendedproperty、sp_dropextendedproperty)

    本篇基本完全参考:sql--sp_addextendedproperty和sp_updateextendedproperty (Transact-SQL) 三个存储过程用法一样,以sp_addexte ...

  10. oracle表中字段的添加、删除

    在oracle数据库中为一张表添加一个字段: alter table tableName add ClIENT_OS varchar2(20) default '0' not null ; 在orac ...

随机推荐

  1. 新版本号的tlplayer for android ,TigerLeapMC for windows公布了

    tlplayer for android 新版本号修正了图像倾斜等等问题,添加了动态水印功能. 支持hls(m3u8),http,rtsp,mms,rtmp等网络协议. 声明tlplayer 上的变速 ...

  2. LOL英雄联盟代打外挂程序-java实现

    相信非常多程序员都玩游戏,比方LOL :有时候想打人机对战(玩家对战小心别人举报你! ),纯属为了拿经验和金币,而本身不想玩,但假设玩家不操作.那么非常快就会被系统觉得是挂机,从而得不到经验和金币.所 ...

  3. html用jquery获取屏幕宽度与滚动条的关系

    当内容高度超过屏幕高度时,获取的屏幕宽度不包括滚动条.即使是浮动,也要显式设置高度,才会全屏. 未超过时,获取的宽度包括滚动条.

  4. php 导出CSV抽象类

    php 导出CSV抽象类,依据总记录数与每批次记录数,计算总批次.循环导出.避免内存不足的问题. ExportCSV.class.php <? php /** php Export CSV ab ...

  5. CSS3 实现背景透明,文字不透明,兼容所有浏览器

    <!DOCTYPE html><html><head><meta charset="utf-8"><title>opac ...

  6. 开源监控软件ganglia

    开源监控软件ganglia安装手册 Ganglia是一个监控服务器,集群的开源软件,能够用曲线图表现最近一个小时,最近一天,最近一周,最近一月,最近一年的服务器或者集群的cpu负载,内存,网络,硬盘等 ...

  7. 允许局域网内其他主机访问本地MySql数据库

    mysql的root账户,我在连接时通常用的是localhost或127.0.0.1,公司的测试服务器上的mysql也是localhost所以我想访问无法访问,测试暂停. 解决方法如下: 1,修改表, ...

  8. 【虚拟机】WIN8.1系统安装虚拟机win7环境

    一.虚拟机的安装 1.准备 VMware Workstation 的软硬件支持,请查看 http://www.vmware.com/cn/products/workstation.html#techs ...

  9. java和erlang之间的DES加解密

    app登录,登录的密码要用DES加密,服务器是用erlang,客户端要同时支持多平台(Android.iOS).首先,Java端的DES加密的实现方式, 少说废话了,直接上代码,如下: public ...

  10. Python学习笔记18:标准库之多进程(multiprocessing包)

    我们能够使用subprocess包来创建子进程.但这个包有两个非常大的局限性: 1) 我们总是让subprocess执行外部的程序,而不是执行一个Python脚本内部编写的函数. 2) 进程间仅仅通过 ...