随笔 - 172  文章 - 0  评论 - 0  阅读 - 11939

操作数据库表

创建数据库表

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
CREATE DATABASE school
-- 使用英文() ,表的名称和字段尽量使用``括起来
-- AUTO——INCREMENT自增
-- 字符串使用单引号括起来
-- 所有语句后面加逗号,英文的,最后一个字段不用加
-- primary key 一个表只有一个主键
CREATE TABLE IF NOT EXISTS `student`(
    `id` INT(4) NOT NULL AUTO_INCREMENT COMMENT '学号',
    `name` VARCHAR(30) NOT NULL DEFAULT '匿名' COMMENT'姓名',
    `pwd` VARCHAR(20) NOT NULL DEFAULT '123456' COMMENT'密码',
    `sex` VARCHAR(2) NOT NULL DEFAULT '女' COMMENT'性别',
    `birthday` DATETIME DEFAULT NULL COMMENT'出生日期',
    `address` VARCHAR(100) DEFAULT NULL COMMENT'家庭住址',
    `email` VARCHAR(50) DEFAULT NULL COMMENT'邮箱',
    PRIMARY KEY(`id`)  
)ENGINE INNODB DEFAULT CHARSET=utf8

show create database school --查看创建数据库的语句

show create table student --查看创建数据库表的语句  

desc student --显示表的结构

 

数据表的类型

--关于数据引擎

 INNODB 默认使用

 MYISAM 早些年使用的

  MYISAM INNODB
事务支持 不支持 支持
数据行锁定 不支持 支持
外键约束 不支持 支持
全文索引 支持 不支持
表空间 较小  

常规使用操作:

  MYISAM:节约空间,速度较快

  INNODB:安全性高,事务的处理,多表多用户操作

在物理空间存在的位置:

  所有的数据库文件,都存在data目录下,本质还是文件存储

MySQL引擎在物理文件上的区别:

  INNODB 在数据库表中只有一个*.frm文件,以及上级目录下的ibdata1文件

  MYISAM对应文件

    *.frm  表结构定义文件

    *.MYD  数据文件

    *.MYI   索引文件 

设置数据库表的字符集编码:

  charset=utf8

如果不设置的话,会是mysql默认的字符集编码(不支持中文)

 

修改删除表

···修改

复制代码
-- 修改表名 ALTER TABLE 旧表名 RENAME AS 新表名
ALTER TABLE student RENAME AS students
-- 增加字段 ALTER TANLE 表名 ADD 字段名 列属性
ALTER TABLE students ADD age INT(11)
-- 修改字段(重命名,修改约束)
ALTER TABLE students MODIFY age VARCHAR(11)-- 修改约束
ALTER TABLE students CHANGE age age1 INT(11)-- 重命名

-- 删除表的字段
ALTER TABLE students DROP age1
复制代码

···删除

-- 删除表
DROP TABLE IF EXISTS students

所有的创建和删除操作尽量加上判断以免报错

 

posted on   键盘敲烂的朱  阅读(16)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示