SQL高级教程学习

  • MySQL的字符匹配和其他数据库不同,一下语句查找(第一个字符不是h,第三个字符是m)不能用“!”

    select * from country
    where countryname rlike '^[^h].[m]';

    ^是开始的语法;[[^abc]表示非abc字符;. 号代表一个字符;[a-f]表示a到f任意字符

  • IN 操作符,在集合种匹配,以下语句查找(“peoplecount”是可以为括号选项)
    select * from country
    where peoplecount in(1,3,5,7,10,13);
  • BETWEEN - AND -,(MySQL)在闭区间查找
  • inner join:内链接,连接两个表,按照组合的方式输出(on关键子则表示条件 从组合种筛选出符合条件的返回)
  • select country.countryname,country.location,island.belong
    from country
    inner join island
    on country.location=island.countrylocation;

    3种join   inner/left/right   +   join   分别表示两个表的交集/左表/右表 ( MySQL不支持full out join)
    这就是说,即使另外一个表没有匹配项,也要把这个表(左右所述的表)的行输出,不匹配的列则显示null

  • union (all) 关键子,用于合并多个select查询的结果,all关键字允许重复的出现结果;
    注意:union内部的select结果必须具有相同的 列数、列的类型和列顺序

  • SQL约束
    • not null:非空,表示该列的值不能为空,否则无法插入数据;下表种 “myname” 列不能为 “null”

      create table tests
      (
      id int primary key auto_increment,
      myname char(255) not null,
      age int
      );
    • unique:唯一,表示该项必须是唯一的,null可以重复;下表种 “学号” 列必须是唯一的
      create table tests
      (
      id int primary key auto_increment,
      myname char(255) not null,
      xuehao int,
      age int,
      unique(xuehao)
      );

      撤销约束:下面的SQL,将撤销tests表种xuehao列的约束

      alter table tests
      drop index xuehao;
    • primary key:主键约束:表种必须只有一个主键,但是主键可以是多个列的组合;下面的SQL语句规定 id 和 xuehao 的组合为主键
    • 第二句SQL用于删除主键约束,注意,MySQL删除主键之前必须先删除自增约束(使用modify改变类型或者change改名同时改掉类型)
      create table tests
      (
      id int auto_increment,
      myname char(255) not null,
      xuehao int,
      constraint prke primary key (id,xuehao)
      ); alter table tests
      drop primary key;
    • foreign key :外键,与另外数据表的主键关联;第二SQL语句规定了amount和tests表中的id关联;关联之后列的数据必须存在于被关联的表中

      create table tests(
      id int primary key auto_increment,
      myname char(50) not null,
      score int
      ); create table tonji(
      id int primary key auto_increment,
      amount int,
      foreign key(amount) references tests(id)
      );

      如果尝试插入被关联表中不存在的主键:

      Error Code: 1452. Cannot add or update a child row: a foreign key constraint fails (`test`.`tonji`, CONSTRAINT `tonji_ibfk_1` FOREIGN KEY (`amount`) REFERENCES `tests` (`id`))

    • check:MySQL中check不能起到强制的作用,对有限的量可以采用枚举的方式(enum);下句SQL规定score只能选枚举出来的这几个选项否则无法插入数
      create table stu(
      id int primary key auto_increment,
      stuname char(50),
      score enum('A','B','C','D')
      );

      下句SQL试图插入意外的字符

      insert into stu
      values(null, 'tbhrv', 'X');

      报错:Error Code: 1265. Data truncated for column 'score' at row 1

    • default:设置默认值;下面这句SQL规定了分数的默认值为‘D’
      create table stu(
      id int primary key auto_increment,
      stuname char(50),
      score enum('A','B','C','D') default 'D'
      );
    • 索引:索引用来增加搜索的速度,但是自身也需要消耗时间,所以用在经常查询的表中;下句SQL为score列增加(唯一)索引
      create index stuindex on stu(score);

SQL上门2的更多相关文章

  1. SQL上门

    学习这个 介绍:SQL 是用于访问和处理数据库的标准的计算机语言.结构化化查询语言! SQL可以分为两大部分:数据操作语言(DML)和数据定义语言(DDL) 数据操作语言:select.update. ...

  2. 面试官:不会sql优化?出门右转顺便带上门,谢谢

    导读 作为一个后端程序员,数据库这个东西是绕不开的,特别是写sql的能力,如果您参加过多次面试,那么一定会从面试复盘中发现面试官总是会考察到sql优化这个东西. 我在之前的多次面试中最常遇到的一个问题 ...

  3. [翻译]通过使用正确的search arguments来提高SQL Server数据库的性能

    原文地址:http://www.sqlpassion.at/archive/2014/04/08/improving-query-performance-by-using-correct-search ...

  4. SQL Server 2005的XML数据修改语言(XML DML)

    转:http://www.microsoft.com/china/msdn/library/data/sqlserver/XMLDML.mspx?mfr=true 作为对XQuery语言的扩展,XML ...

  5. sql server常有的问题-实时错误'91' 对象变量或with块变量未设置

    这样的问题,对于我们这样的初学者来说,无疑是一个接触sql server后第一个艰难的问题,“实时错误'91' 对象变量或with块变量未设置”这句话到底透露出什么信息?直至写此博文,我依然看不出什么 ...

  6. 转:攻击JavaWeb应用[4]-SQL注入[2]

    转:http://static.hx99.net/static/drops/tips-288.html 攻击JavaWeb应用[4]-SQL注入[2] 园长 · 2013/07/18 17:23 注: ...

  7. 【监控笔记】【1.3】监控事件系列——SQL Trace(黑盒跟踪 BlackBox Trace)

    [1]它跟踪了哪些事件? (1.1)存储过程执行(SP:Strating) (1.2)T-SQL执行(SQL:BatchString) (1.3)错误和警告(Exception,Attention) ...

  8. sql 模块sqllit

    1.创建数据库表 面对 SQLite 数据库,我们之前熟悉的 SQL 指令都可以用: >>> create_table = "create table books (tit ...

  9. DDOS、CC、sql注入,跨站攻击防御方法

    web安全常见攻击解读--DDos.cc.sql注入.xss.CSRF 一,DDos https://www.cnblogs.com/sochishun/p/7081739.html#4111858 ...

随机推荐

  1. LeetCode 541. Reverse String II (反转字符串 II)

    Given a string and an integer k, you need to reverse the first k characters for every 2k characters ...

  2. 一个MySQL-JDBC驱动bug引起的血案……

    问题背景 公司是做电商系统的,整个系统搭建在华为云上.系统设计的时候,考虑到后续的用户和订单数量比较大,需要使用一些大数据库的组件.关系型数据库这块,考虑到后续数据量的快速增长,不是直接写入MySQL ...

  3. 选择排序(1)——简单选择排序(selection sort)

    选择排序是一种很常见的排序算法,它需要对数组 中的元素进行多次遍历.每经过一次循环,选择最小的元素并把它放在靠近数组前端的位置. 代码实现: public static void selectionS ...

  4. 转 linux/unix学习经典书籍

    都是一些链接. 1. Linux网络编程经典书籍推荐 http://blog.csdn.net/zhangpeng_linux/article/details/7001970 2. C语言经典著作导读 ...

  5. JSP-Runoob:JSP 自定义标签

    ylbtech-JSP-Runoob:JSP 自定义标签 1.返回顶部 1. JSP 自定义标签 自定义标签是用户定义的JSP语言元素.当JSP页面包含一个自定义标签时将被转化为servlet,标签转 ...

  6. [Swift通天遁地]八、媒体与动画-(1)实现音频的播放和停止

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  7. Java基础学习经验分享

    很多人学习Java,尤其是自学的人,在学习的过程中会遇到各种各样的问题以及难点,有时候卡在一个点上可能需要很长时间,因为你在自学的过程中不知道如何去掌握和灵活运用以及该注意的点.下面我整理了新手学习可 ...

  8. ACM_无聊者序列(斐波那契数列大数取余(同余)+规律)

    Problem Description: 瓜瓜在玩着由红色和蓝色的大理石做成的玻璃珠,他将n个玻璃珠从左到右排成一个序列叫做无聊者序列.一个非空的红色和蓝色玻璃珠组成的序列是一个无聊者序列.这个序列的 ...

  9. 记一次Oracle冷备恢复的过程

    一.故障来临 某日中午,市电意外中断,机房UPS电源由于负载过重而未接管供电,所有服务器全部重启...... 待所有服务器重启后,正在逐一检查设备和业务运行情况时,意外发生了.一台年代久远的HP PC ...

  10. Web程序安全机制

    ASP.NET提供了一个多层的安全模型,这个模型能够非常容易的保护Web应用程序. 安全策略没有必要非常复杂,但是需要应用安全策略的地方却是非常广泛的.程序员需要保证自己的应用程序不能被骗取,而把私有 ...