zoukankan      html  css  js  c++  java
  • mysql 语法的简单学习

    将文本数据导入到数据库中:

     load data local infile ‘文件名’into table 表名;

    数据的导出:

    查看数据库导出位置:show variables like '%secure%';

    导出语句:

    select * from 数据库.数据表名 into outfile  ‘文件名’;

    select * from t_aaa' into OUTFILE '/var/lib/mysql-files/1111.csv' FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY ' '

    数据库的备份

    1.导出整个数据库

    mysqldump -uroot -p 数据库名 > 导出文件名

    2.导出一个表

    用法:mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名 

    mysqldump -uroot -p student student>d:/learn/db_student.student.backup 

    3.导出一个数据结构

    用法:mysqldump -uroot -p -d --add-drop-table 数据库名>导出文件名 

    mysqldump -uroot -p -d --add-drop-table test>d:/learn/db_test.structure.backup

    **注意: 

    -d 表示没有数据 

    --add-drop-table 表示在每一个

    create 语句之前添加一个 drop table 语句 

    打开 c:/learn/db_test.structure.backup文件,和先前的两个文件比较,你会发现该文件里没有我们插入的数据.

    重命名数据库表

    alter table 旧名 rename 新名

    39.高效使用索引的好处和优势:

     

    下面讨论的是用了索引会给我们带来什么?

    1.) 获得域where从句中匹配的行:select * from customer where surname>'c'; 

    2.) 查找max()和min()值时,mysql只需在排序的索引中查找第一个和最后一个值。

    3.) 返回的部分是索引的一部分,mysql就不需要去查询全表的数据而只需看索引:select idfrom customer; 

    4.) 对域使用order by的地方:select * from customer order by surname; 

    5.) 还可以加速表的连接:select first_name,surname,commission from sales,sales_rep where sales.sales_rep=sales_rep.employee_number and code=8; 

    6.) 在通配符的情况下:select * from sales_rep where surname like 'ser%';     

         这种情况就不能起作用:select * from sales_rep where surname like '%ser%';

     

    41.如何对已有的数据表的字段,新增索引:

        alter table customer add index(surname,initial,first_name); 

     

     

    42.最左边规则

    区块,条件,循环

     

    .

    创建存储过程

     

    1.基本语法: 

    create procedure sp_name() 

    begin 

    ......... 

    end 

    2.参数传递

     

     

    添加定时任务:

    可参考:https://blog.csdn.net/zlp5201/article/details/38309095

    1、要想保证能够执行event事件,就必须保证定时器是开启状态,默认为关闭状态

    set GLOBAL event_scheduler = 1;

    或 

    set GLOBAL event_scheduler = ON; 

    要查看当前是否已开启事件调度器,可执行如下SQL:

    SHOW VARIABLES LIKE 'event_scheduler'

    2、如果原来存在该名字的任务计划则先删除  

    drop event if exist upload_to_sdmp;

    3、创建定时任务

    • CREATE EVENT update_month_card_open   
    • ON  schedule every 10*60 second  
    • ON COMPLETION PRESERVE ENABLE DO   
    •     #这里只是修改包月卡的会员的不在这里修改  
    •     'your SQL'

    4、开启定时器 event_name 任务的名字  

    alter event update_month_card_open on completion preserve enable;

    5、关闭事件:  

    ALTER EVENT upload_to_sdmp DISABLE;

     

     

     

     

     

  • 相关阅读:
    理解python多个参数*args
    物联网MQTT 协议测试
    python 自动化测试人工智能
    Django 初识
    算法排序
    python教程笔记GUI wxpython
    python入门教程学习笔记#3 基础部分
    python入门教程学习笔记#1 安装准备
    2012-2013 Northwestern European Regional Contest (NWERC 2012)
    2017 Benelux Algorithm Programming Contest (BAPC 17)
  • 原文地址:https://www.cnblogs.com/wangzhaoshuang/p/7755908.html
Copyright © 2011-2022 走看看