mysql/mariadb学习记录——创建删除数据库、表的基本命令
查看已有的数据库:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| test |
+--------------------+
rows in set (0.05 sec)
新建数据库语句:
mysql> create database wzu;
Query OK, row affected (0.05 sec) mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| test |
| wzu |
+--------------------+
rows in set (0.05 sec)
要对某个数据库进行操作时首先要选中这个数据库,使用use <dbname>:
mysql> use wzu
Database changed
创建表格:
命令:create table <表名> ( <属性名 属性类型 [修饰]> );
create table student(sno char(9) primary key,sname char(20) unique,ssex char(2),sage smallint, sdept char(20));
create table course(cno char(4) primary key,cname char(40) not null,cpno char(4),ccredit smallint,foreign key(cpno) references course(cno));
create table sc(sno char(9),cno char(4),grade smallint,primary key(sno,cno),foreign key(sno) references student(sno),foreign key(cno) references course(cno));
删除表格:
命令:drop table <表名>;
mysql> drop table emp;
Query OK, rows affected (0.41 sec)
查看数据库中有哪些表格:
mysql> show tables;
+---------------+
| Tables_in_wzu |
+---------------+
| course |
| sc |
| student |
+---------------+
更改外键约束:
set foreign_key_checks=; //忽略外键检查
set foreign_key_checks=; //重启外键检查
更改表中某属性的数据类型:
命令:alter table <表名> modify <需要更改的属性> <想要更改的类型>;
如:student 表中的sno字段改成varchar(11)
mysql> alter table student modify sno varchar();
Query OK, rows affected (0.15 sec)
Records: Duplicates: Warnings:
可以用desc <表名> 来查看表格结构:
mysql> desc student;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| sno | varchar() | NO | PRI | | |
| sname | varchar() | YES | UNI | NULL | |
| ssex | varchar() | YES | | NULL | |
| sage | smallint() | YES | | NULL | |
| sdept | varchar() | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
表格插入数据:
命令:insert into <表名> values( 填,入,相,应,的,值 );
insert into student values('','测试','男','','CS');
删除一行数据:
命令:delete from <表名> where [条件];
mysql> delete from emp where empno='';
修改一行数据:
命令:update <表名> set [属性名]=[值] [where] [条件]
mysql> update course set cpno=null where cpno='NULL';
表格中的简单数据查询:
select * from [表名]
如:select * from student;
* 表示查询表格中所有的列,也可以用列名加','隔开来选择自己需要的数据
mysql> select * from student;
+-------------+--------+------+------+-------+
| sno | sname | ssex | sage | sdept |
+-------------+--------+------+------+-------+
| | 测试 | 男 | | CS |
| | 周帅 | 男 | | CS |
+-------------+--------+------+------+-------+ mysql> select sno,sname from student;
+-------------+--------+
| sno | sname |
+-------------+--------+
| | 测试 |
| | 周帅 |
+-------------+--------+
给已创建的表格增加一栏属性:
alter table <表名> add <属性名> <属性域>;
如:
mysql> alter table dept add type varchar();
Query OK, rows affected (0.62 sec)
Records: Duplicates: Warnings: mysql> desc dept;
+--------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+--------------+------+-----+---------+-------+
| deptno | decimal(,) | NO | PRI | NULL | |
| dname | varchar() | NO | | NULL | |
| loc | varchar() | YES | | NULL | |
| type | varchar() | YES | | NULL | |
+--------+--------------+------+-----+---------+-------+
在已创建的表格中删除一栏属性:
alter table <表名> drop <属性名>;
如:
mysql> alter table dept drop type;
Query OK, rows affected (0.57 sec)
Records: Duplicates: Warnings: mysql> desc dept;
+--------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+--------------+------+-----+---------+-------+
| deptno | decimal(,) | NO | PRI | NULL | |
| dname | varchar() | NO | | NULL | |
| loc | varchar() | YES | | NULL | |
+--------+--------------+------+-----+---------+-------+
当发现一个操作有warning时 可以通过show warnings;来查看警告信息:
mysql> show warnings;
+---------+------+-----------------------------------------------------------------------------------+
| Level | Code | Message |
+---------+------+-----------------------------------------------------------------------------------+
| Warning | 1366 | Incorrect string value: '\xE6\x9D\x8E\xE5\x8B\x87' for column 'sname' at row 1 |
| Warning | 1366 | Incorrect string value: '\xE7\x94\xB7' for column 'ssex' at row 1 |
| Warning | 1366 | Incorrect string value: '\xE6\x95\xB0\xE6\x8D\xAE...' for column 'cname' at row 1 |
+---------+------+-----------------------------------------------------------------------------------+
此处的问题主要是因为插入的编码格式不兼容(插入的数据编码为utf8 表格的编码为latinl)
解决方法见mysql/mariadb学习过程中出现的问题与解决
mysql查看当前选择的数据库:
mysql> select database();
+------------+
| database() |
+------------+
| groupdb |
+------------+
//或者:
mysql> show tables;
+-------------------+
| Tables_in_groupdb |//此处为当前数据库
+-------------------+
| course |
| dept |
| emp |
| jwc |
| salgrade |
| sc |
| student |
| temp |
+-------------------+
//或者:
mysql> status;
--------------
mysql Ver 14.14 Distrib 5.7.14, for Win64 (x86_64)
Connection id: 2721
Current database: groupdb //此处为当前数据库
Current user: group@122.228.131.86
SSL: Not in use
Using delimiter: ;
Server version: 5.5.56-MariaDB MariaDB Server
Protocol version: 10
Connection: AAA.AAA.AAA.AAA via TCP/IP
Server characterset: utf8
Db characterset: utf8
Client characterset: utf8
Conn. characterset: utf8
TCP port: 3306
Uptime: 2 days 5 hours 25 min 51 sec
Threads: 2 Questions: 549 Slow queries: 0 Opens: 26 Flush tables: 2 Open tables: 44 Queries per second avg: 0.002
2018-04-30
判断一个值是否为NULL:
使用 is 关键字而不能用 = 来判断
mysql> select * from course where cpno is null;
+-----+--------------+------+---------+
| cno | cname | cpno | ccredit |
+-----+--------------+------+---------+
| | 高等数学 | NULL | |
| | 数据处理 | NULL | |
+-----+--------------+------+---------+
rows in set (0.05 sec) mysql> select * from course where cpno is not null;
+-----+--------------+------+---------+
| cno | cname | cpno | ccredit |
+-----+--------------+------+---------+
| | 数据库 | | |
| | 信息系统 | | |
| | 操作系统 | | |
| | 数据结构 | | |
| | C语言 | | |
+-----+--------------+------+---------+
mysql/mariadb学习记录——创建删除数据库、表的基本命令的更多相关文章
- mysql/mariadb学习记录——查询
连接查询:同时设计两个及以上的表的查询 连接条件或连接谓词:用来连接两个表的条件一般格式: [<表名1>]<列名1> <比较运算符> [<表名2>]&l ...
- mysql/mariadb学习记录——查询2
Alias——使用一个列名别名AS 关键字: mysql> select sno as studentId,sname as studentName from student; +------- ...
- mysql/mariadb学习记录——limit
在mysql/mariadb 中可以用limit来限制查询的条数.例子如下: 1.limit后加一个参数 limit n: //选中查询所有结果中的前两条记录并返回 mysql> ; +---- ...
- mysql/mariadb学习记录——连接查询(JOIN)
//本文使用的数据表格//persons表中id_p为主键//orders表中id_o为主键,id_p为外键参考persons表中的id_p mysql> select * from perso ...
- mysql/mariadb学习记录——查询3(AVG、SUM、COUNT)函数
AVG() 求平均数函数: //求emp表中的sal属性的平均值 mysql> select avg(sal) as salAverage from emp; +-------------+ | ...
- --oracle删除数据库表(无主键)中重复的记录
--oracle删除数据库表(无主键)中重复的记录 1, CREATE TABLE newtable as SELECT distinct * FROM T_SYSTEM_MENU_PRIV; 2, ...
- Django学习路5_更新和删除数据库表中元素
查找所有的元素 Student.objects.all() 查找单个元素 Student.objects.get(主键=值) 主键 pk = xxx 更新数据库数据后进行保存 stu.save() 删 ...
- Java创建Oracle数据库表
我们通常只用java执行DML(即:insert, update, delete, select)操作,很少用来执行DDL(create, drop, alert)操作.今天试了下如何用java来创建 ...
- Mysql命令drop database:删除数据库
drop命令用于删除数据库. drop命令格式:drop database <数据库名>; 例如,删除名为 xhkdb的数据库:mysql> drop database xhkdb; ...
随机推荐
- windows Ctrl + Alt + 方向键 取消屏幕反转
1.在桌面右击 2.再次右击桌面 3.单击选项和支持 4.点击禁用和应用
- top,job,user,file,alias
1.系统进程 2.系统资源管理 3.作业管理 4.用户管理 5.文件权限 6.别名定义 一.系统进程 1.进程的定义 进程是操作系统的概念,每当我们执行一个程序时,对于操作系统来讲就创建了 ...
- leetCode题解之Contains Duplicate
1.题目描述 2.题目分析 直接使用hashTable 计数,超过1 则返回true,最后返回 false即可. 3.代码 bool containsDuplicate(vector<int&g ...
- 我是如何将linux用在开发环境中的
1.我为什么要写这篇文章 一直想深入学习一下linux的使用,于是将家里的笔记本装了linux系统,但是要将自己的系统打造一个适合开发的环境确实是一件费心费力的事,而且会经常出现一些莫名其妙的问题,以 ...
- Vue2学习笔记:组件(Component)
组件 组件(Component)是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.在较高层面上,组件是自定义元素, Vue.js 的编译器为它添加特殊功能.在有些情况 ...
- [SQL Server]利用索引改善sql语句
很多人不知道SQL语句在SQL SERVER中是如何执行的,他们担心自己所写的SQL语句会被SQL SERVER误解.比如: 1.select * from table1 where name=''z ...
- mysql(5.7.17)字符集设置(character_set/collation)
0 查看字符集(character_set/collation) use information_schema;desc tables; --一定记住tables表,information_sc ...
- flask的g对象
故名思议我们可以理解这个g对象是一个全局的对象,这个对象存储的是我们这一次请求的所有的信息,只是存储这一次的请求 g:global 1. g对象是专门用来保存用户的数据的. 2. g对象在一次请求中 ...
- Flask配置文件和 路由系统
debug = True开启debug模式 当你的代码在界面增减之后不用刷新界面自动更新 app.logger.error("这是error模式") app.logger.info ...
- CATransform3D的m34使用
CATransform3D的m34使用 效果图 源码 // // ViewController.m // StarWars // // Created by YouXianMing on 15/11/ ...