>  기사  >  데이터 베이스  >  MySQL--데이터 개발의 고전과 솔루션

MySQL--데이터 개발의 고전과 솔루션

php是最好的语言
php是最好的语言원래의
2018-08-08 12:02:491369검색

데이터 개발 - Classic

  • 1. 성 획순으로 정렬:

Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as //从少到多
  • 2. 데이터베이스 암호화:

select encrypt('原始密码')select pwdencrypt('原始密码')select pwdcompare('原始密码','加密后密码') = 1--相同;否则不相同 encrypt('原始密码')select pwdencrypt('原始密码')select pwdcompare('原始密码','加密后密码') = 1--相同;否则不相同
  • 3.

    아아아아
    4. 하드 디스크 파티션 확인:
  • declare @list varchar(1000),@sql nvarchar(1000) 
    select @list=@list+','+b.name from sysobjects a,syscolumns b where a.id=b.id and a.name='表A'set @sql='select '+right(@list,len(@list)-1)+' from 表A' exec (@sql)
    5. 테이블 A와 B가 동일한지 비교:
  • EXEC master..xp_fixeddrives
    6. 모든 프로파일러 프로세스 종료:
  • if (select checksum_agg(binary_checksum(*)) from A)
         =
        (select checksum_agg(binary_checksum(*)) from B)
    print '相等'elseprint '不相等'
    7 .레코드 검색:
  • DECLARE hcforeach CURSOR GLOBAL FOR SELECT 'kill '+RTRIM(spid) FROM master.dbo.sysprocessesWHERE program_name IN('SQL profiler',N'SQL 事件探查器')
    EXEC sp_msforeach_worker '?'
사례 예 1: 테이블에 10,000개 이상의 레코드가 있습니다. 테이블의 첫 번째 필드인 RecID는 31번째부터 40번째까지 자동으로 증가하는 필드입니다. 테이블의.
기록이 없는 A에서 상위 10개 기록 선택(상위 30개 기록 선택

A) 분석: 이렇게 작성하면, Recid가 테이블에 논리적 인덱스를 가지고 있으면 몇 가지 문제가 발생합니다.
select top 10 recid from A where...는 인덱스에서 검색되는 반면, 후속 A의 상위 30개 레코드는 데이터 테이블에서 검색되므로 인덱스의 순서로 인해 데이터 테이블과 일치하지 않을 수 있습니다. 쿼리에 불일치가 있어 쿼리가 원래 의도한 데이터와 다릅니다. select top 10 recid from A where recid not  in(select top 30 recid
 from A) 分析:如果这样写会产生某些问题,如果recid在表中存在逻辑索引。
select top 10 recid from A where……

Solution

开头到N条记录Select Top N * From 表
-------------------------------N到M条记录(要有主索引ID)Select Top M-N * From 表 Where ID in (Select Top M ID From 表) Order by ID   Desc
----------------------------------N到结尾记录
Select Top N * From 表 Order by ID Desc

  • 9: 현재 데이터베이스의 모든 사용자 테이블 가져오기

  • 1,用order by select top 30 recid from A order by ricid 如果该字段不是自增长,就会出现问题2,在那个子查询中也加条件:select top 30 recid from A where recid>-1例2:查询表中的最后以条记录,并不知道这个表共有多少数据,以及表结构。set @s = 'select top 1 * from T   where pid not in (select top ' + str(@count-1) + ' pid  from  T)'print @s      exec  sp_executesql  @s
  • 10: 특정 테이블의 모든 필드 가져오기

  • select Name from sysobjects where xtype='u' and status>=0
  • 11: 보기 및 특정 테이블 관련 뷰, 저장 프로시저, 함수

  • select name from syscolumns where id=object_id('表名')select name from syscolumns where id in (select id from sysobjects where type = 'u' and name = '表名')
    两种方式的效果相同
  • 12: 현재 데이터베이스의 모든 저장 프로시저 보기

  • select a.* from sysobjects a, syscomments b where a.id = b.id and b.text like '%表名%'
  • 13: 사용자가 생성한 모든 데이터베이스를 쿼리

  • select name as 存储过程名称 from sysobjects where xtype='P'
  • 14: 쿼리 테이블의 특정 필드 및 데이터 유형

  • select * from master..sysdatabases D where sid not in(select sid from master..syslogins where name='sa')
    或者select dbid, name AS DB_NAME from master..sysdatabases where sid <> 0x01
  • 15: 서로 다른 서버 데이터베이스 간의 데이터 작업

  • select column_name,data_type from information_schema.columnswhere table_name = &#39;表名&#39;
    --创建链接服务器exec sp_addlinkedserver   &#39;ITSV &#39;, &#39; &#39;, &#39;SQLOLEDB &#39;, &#39;远程服务器名或ip地址 &#39;exec sp_addlinkedsrvlogin  &#39;ITSV &#39;, &#39;false &#39;,null, &#39;用户名 &#39;, &#39;密码 &#39;
    --查询示例select * from ITSV.数据库名.dbo.表名
  • –원격/LAN 데이터 연결(openrowset/openquery/opendatasource)

  • --导入示例select * into 表 from ITSV.数据库名.dbo.表名
    --以后不再使用时删除链接服务器exec sp_dropserver  &#39;ITSV &#39;, &#39;droplogins &#39;
  • – 로컬 테이블을 원격 테이블로 가져오기

  • --1、openrowset--查询示例select * from openrowset( &#39;SQLOLEDB &#39;, &#39;sql服务器名 &#39;; &#39;用户名 &#39;; &#39;密码 &#39;,数据库名.dbo.表名)--生成本地表select * into 表 from openrowset( &#39;SQLOLEDB &#39;, &#39;sql服务器名 &#39;; &#39;用户名 &#39;; &#39;密码 &#39;,数据库名.dbo.表名)
  • – 로컬 테이블 업데이트

  • insert openrowset( &#39;SQLOLEDB &#39;, &#39;sql服务器名 &#39;; &#39;用户名 &#39;; &#39;密码 &#39;,数据库名.dbo.表名)select *from 本地表
  • – openquery를 사용하려면 연결을 만들어야 합니다

  • update bset b.列A=a.列A from openrowset( &#39;SQLOLEDB &#39;, &#39;sql服务器名 &#39;; &#39;用户名 &#39;; &#39;密码 &#39;,数据库名.dbo.表名)as a inner join 本地表 bon a.column1=b.column1
    --首先创建一个连接创建链接服务器exec sp_addlinkedserver   &#39;ITSV &#39;, &#39; &#39;, &#39;SQLOLEDB &#39;, &#39;远程服务器名或ip地址 &#39;
    --查询select *FROM openquery(ITSV,  &#39;SELECT *  FROM 数据库.dbo.表名 &#39;)
    --把本地表导入远程表insert openquery(ITSV,  &#39;SELECT *  FROM 数据库.dbo.表名 &#39;)select * from 本地表
  • – 3. /openrowset

  • --更新本地表update bset b.列B=a.列BFROM openquery(ITSV,  &#39;SELECT * FROM 数据库.dbo.表名 &#39;) as a 
    inner join 本地表 b on a.列A=b.列A
    r
    SELECT   *FROM   opendatasource( &#39;SQLOLEDB &#39;,  &#39;Data Source=ip/ServerName;User ID=登陆名;Password=密码 &#39; ).test.dbo.roy_ta
    --把本地表导入远程表insert opendatasource( &#39;SQLOLEDB &#39;,  &#39;Data Source=ip/ServerName;User ID=登陆名;Password=密码 &#39;).数据库.dbo.表名select * from 本地表
SQL Server基本函数
1.字符串函数 长度与分析用
1,datalength(Char_expr) 返回字符串包含字符数,但不包含后面的空格
2,substring(expression,start,length) 取子串,字符串的下标是从“1”,start为起始位置,length为字符串长度,实际应用中以len(expression)取得其长度
3,right(char_expr,int_expr) 返回字符串右边第int_expr个字符,还用left于之相反
4,isnull( check_expression , replacement_value )如果check_expression為空,則返回replacement_value的值,不為空,就返回check_expression字符操作类
5,Sp_addtype自定義數據類型
例如:EXEC sp_addtype birthday, datetime, 'NULL'
6,set nocount {on|off}
使返回的结果中不包含有关受 Transact-SQL 语句影响的行数的信息。如果存储过程中包含的一些语句并不返回许多实际的数据,则该设置由于大量减少了网络流量,因此可显著提高性能。SET NOCOUNT 设置是在执行或运行时设置,而不是在分析时设置。SET NOCOUNT 为 ON 时,不返回计数(表示受 Transact-SQL 语句影响的行数)。
관련 권장 사항:

MYSQL 클래식 명령문 종합 모음 - 개발

MySQL 데이터베이스 수동 설치 방법 및 중국어 솔루션

위 내용은 MySQL--데이터 개발의 고전과 솔루션의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.