zoukankan      html  css  js  c++  java
  • 数据库基本操作

    一、库的基本操作

    # 前提: 连接上数据库
    
    1)查看已有数据库
    mysql>: show databases;
    
    2)选择某个数据库
    mysql>: use 数据库名
    
    3)查看当前所在数据库
    mysql>: select database();
    
    4)创建数据库
    mysql>: create database 数据库名 [charset=编码格式];
    eg>: create database owen;
    eg>: create database zero charset=utf8;
        
    5)查看创建数据库的详细内容
    mysql>: show create database 数据库名;
    eg>: show create database owen;
    
    6) 修改数据库编码集
    mysql>: alter database 数据库名 charset="字符集";
    eg>: alter database db1 charset="utf8";
        
    6)删除数据库
    mysql>: drop database 数据库名;
    eg>: drop database db1;
    

    二、表的基本操作

    # 前提:先选取要操作的数据库
    
    1)查,查看表信息
    纵观所有数据库: show tables;
    详细信息: show create table 表名;
    查看创建表的结构: desc 表名;
    
    2)增,创建表
    mysql>: create table 表名(字段们);
    eg>: create table student(name varchar(16), age int);
    
    3)改,修改表结构
    修改字段属性: alter table 表名 modify 字段名 字段属性;
    eg>: alter table t1 modify name char(20);
    修改字段名: alter table 表名 change 旧字段名 新字段名 新字段属性;
    eg>: alter table t1 change name usr char(16);
    修改表名: alter table 表名 rename 新表名;
    eg>: alter table t1 rename t2;
    # 添加一个新字段: 根据相对位置添加新字段:
    mysql>: alter table 表名 add 字段名 类型[(长度) 约束];  # 末尾
    eg>: alter table tf1 add z int unsigned;
    mysql>: alter table 表名 add 字段名 类型[(宽度) 约束] first;  # 首位
    eg>: alter table tf1 add a int unsigned first;
    mysql>: alter table 表名 add 字段名 类型[(宽度) 约束] after 旧字段名; # 添加在表已有字段之后
    eg>: alter table tf1 add xx int unsigned after x; 
    # 删除字段
    mysql>: alter table 表名 drop 字段名;
    eg>: alter table tf1 drop a;
    
    4)删, 删除表
    mysql>: drop table 表名;
    eg>: drop table teacher;
    
    # 删除表字段
    mysql>: alter table 表名 drop 字段名;  # 删除字段
    eg>: alter table tf1 drop a;
    

    三、字段的基本操作

    1)查,查看某个数据库中的某个表的所有记录,如果在对应数据库中,可以直接查找表
    mysql>: select * from [数据库名.]表名;
    注:*代表查询所有字段
    模糊查询:like,_代表任意一个字符,%0个或多个任意字符
    mysql>: select * from [数据库名.]表名 where 字段名 like "模糊查询的内容";
    eg:  select * from t2 where name like "xc%";
    
    
    2)增,给表的所有字段插入数据
    mysql>: insert [into] [数据库名.]表名 values (值1,...,值n);
    eg:如果给有name和age两个字段的student表插入数据
    1条>:insert into student values ('Bob', 18);
    多条>:insert into student values ('张三', 18), ('李四', 20);
    指定库>:insert owen.student values ('张三', 18), ('李四', 20);
    
    3)改,根据条件修改指定内容
    mysql>: update [数据库名.]表名 set 字段1=新值1, 字段n=新值n where 字段=旧值;
    eg:> update student set name='王五', age='100' where name='张三';
    注:i) 可以只修改部分字段 ii) 没有条件下,所有记录都会被更新
    eg:> update student set name='呵呵';
    
    4)删,根据条件删除记录
    mysql>: delete from [数据库名.]表名 where 条件;
    eg:> delete from student where age<30;
    

    四、数据库表的引擎:驱动数据的方式 - 数据库优化

    可以通过设置myisam来优化数据库

    # 前提: 引擎是建表是规定, 提供给表使用的, 不是数据库
    
    # 展示所有引擎
    mysql> show engines; 
    
    # innodb(默认): 支持事务, 行级锁, 外键
    mysql>: create table t11(id int)engine=innodb;
    
    # myisam: 查询效率要优于innodb, 当不需要支持事务, 行级锁, 外键, 可以通过设置myisam来优化数据库
    mysql>: create table t12(id int)engine=myisam;
    
    # blackhole:黑洞,存进去的数据都会消失(可以理解不存数据)
    mysql>: create table t13(id int)engine=blackhole;
    
    # memory:表结构是存储在硬盘上的,但是表数据全部存储在内存中
    mysql>: create table t14(id int)engine=memory;
    

    五、创建表的完整语法

    create table 表名(
    字段名1 类型[(宽度) 约束条件],
    字段名2 类型[(宽度) 约束条件],
    字段名3 类型[(宽度) 约束条件]
    )engine=innodb charset=utf8;
    
    # []可选参数
    
    create table db1.t1(name char(3) not null);
    # 数据插入时,name不能为空(null), 且最长只能存放三个字符
    # 总结: 宽度和约束条件为可选参数, 用来限制存放数据的规则
    

    六、数据库的模式(**)

    # mysql 5.7 以后默认都是安全模式
    
    # mysql 5.6 版本
    sql_model=no_engine_substitution  # 非安全性,默认
    sql_model=strict_trans_tables  # 安全性
    
    # 查看当前数据库模式:
    show variables like "%sql_mode%"; # %匹配0~n个任意字符 => 模糊查询
    
    # 临时设置为安全模式,服务重启后会被重置
    mysql>: set global sql_mode="strict_trans_tables";  # 在root用户登录状态下
    # 在设置后,quit断开数据库连接后(服务器不重启)就会进入安全模式
    
    # 安全模式下,非安全模式下sql执行的警告语句,都会抛异常
    eg>: create table t1(name char(2));
    eg>: insert into t1 values ("ab") # 正常
    eg>: insert into t1 values ("owen") # 错误 Data too long for column 'name' at row 1
    
  • 相关阅读:
    C++指针
    Linux Ubuntu常用终端命令
    java-JDBC-Oracle数据库连接
    HDU 1890 区间反转
    Hdu-3487 Splay树,删除,添加,Lazy延迟标记操作
    UVa 10088
    UVa10025-The ? 1 ? 2 ? ... ? n = k problem
    UVa10023手动开大数平方算法
    UVa 10007
    点的双联通+二分图的判定(poj2942)
  • 原文地址:https://www.cnblogs.com/XuChengNotes/p/11588523.html
Copyright © 2011-2022 走看看