https://www.ciang.top/ https://www.ciang.top/
首页
  • 首页
  • python
  • 工具经验
  • 教程
  • c++
  • mysql
  • 登录
搜索历史 清空
写文章

登录

账号密码登录
扫码登录
扫码登录
请使用手机扫码登录
注册登录即表示同意用户协议和隐私政策
编程
java c/c++ mysql python excel html/css/js 工具经验
思路/心得
传奇私服-V8M2引擎学习笔记
教程
翻译
游戏
推荐 最新
Python之Turtle模块
benojan 2023-4-5

Python之Turtle模块

常用命令 窗体和画布 # 窗体大小 turtle.setup(宽, 高, x坐标=屏幕居中, y坐标=屏幕居中) # 画布大小 turtle.screensize(宽, 高, 色) turtle.screensize() # 默认:400 × 300 画笔 turtle.pensize(粗细) # 笔粗 turtle.width(粗细) # 笔粗 turtle.pencolor(色) # 笔色: white, yellow, magenta, cyan, blue, black turtle.pencolor(R,G,B) turtle.pencolor( (R,G,B) ) turtle.colormode(色型) # 色型: 1.0, 255 turtle.fillcolor(色) # 填色 turtle.color(笔色, 填色) 画笔动作 turtle.pendown() # 落笔 turtle.down() # 落笔 turtle.pd() # 落笔 turtle.penup() # 挈笔 turtle.up() # 挈笔 turtle.pu() # 挈笔 turtle.goto(x坐标, y坐标) # 移动 turtle.forward(距离) # 前进 turtle.fd(距离) # 前进 turtle.backward(距离) # 后退 turtle.bk(距离) # 后退 turtle.left(角度) # 左转 turtle.right(角度) # 右转 turtle.seth(角度) # 设置朝向 turtle.setheading(角度) # 设置朝向 turtle.begin_fill() # 开始上色 turtle.end_fill() # 结束上色 turtle.circle(半径, 角度=360) # 画弧线,半径>100,圆心在左侧,半径<100,圆心在右侧 全局 stamp() # 复制当前图形 turtle.write(文字, 字体=("字体名", 字号, "字形")) turtle.showturtle() # 显示海龟 turtle.hideturtle() # 隐藏海龟 turtle.isvisible() # 检查海龟是否可见 turtle.clear() # 清除(只清除绘图) turtle.reset() # 重置(恢复一切到初始) turtle.undo() # 撤销动作 turtle.exitonclick() # 画完不关窗,点窗退出 turtle.done() # 中断绘制,关窗后继续绘制 颜色表 英文名 RGB整数表示色型 RGB小数表示色型 中文名 white 255, 255, 255 1, 1, 1 白 yellow 255, 255, 0 1, 1, 0 黄 magenta 255, 0, 255 1, 0, 1 梅红 cyan 0, 255, 255 0, 1, 1 青 blue 0, 0, 255 0, 0, 1 蓝 black 0, 0, 0 0, 0, 0 乌 seashell 255, 245, 238 1, 0.96, 0.93 海贝 gold 255, 215, 0 1, 0.84, 0 金 pink 255, 192, 203 1, 0.75, 0.80 粉 brown 165, 42, 42 0.65, 0.16, 0.16 棕/褐 purple 160, 32, 240 0.63, 0.13, 0.94 紫 tomato 255, 99, 71 1, 0.39, 0.28 番茄色

622 27 0
pythonturtle
Python之Turtle模块
boost的字符串操作
benojan 2023-2-9

boost的字符串操作

头文件 #include <boost/algorithm/string.hpp> 功能 字符串切割 boost::algorithm::split() using namespace boost::algorithm; int main() { std::string s = "Boost C++ Libraries"; std::vector<std::string> v; split(v, s, is_space()); std::cout << v.size() << std::endl; } // 内置的方式 using algorithm::is_classified; using algorithm::is_space; // 空白 using algorithm::is_alnum; // 数字+字母 using algorithm::is_alpha; // 字母 using algorithm::is_cntrl; using algorithm::is_digit; // 数字 using algorithm::is_graph; using algorithm::is_lower; // 小写字母 using algorithm::is_upper; // 大写字母 using algorithm::is_print; using algorithm::is_punct; using algorithm::is_xdigit; using algorithm::is_any_of; // 字符串中的任意字符 using algorithm::is_from_range; 去除首尾字符-默认为空白字符 boost::algorithm::trim_left_copy(str) boost::algorithm::trim_right_copy(str) boost::algorithm::trim_copy(str) // 指定字符 boost::algorithm::trim_left_copy_if(str, boost::algorithm::is_any_of("+-") boost::algorithm::trim_right_copy_if(str, boost::algorithm::is_any_of("+-"))) boost::algorithm::trim_copy_if(str, boost::algorithm::is_any_of(" \t\n")) 大小写转换 boost::algorithm::to_upper(str) boost::algorithm::to_lower(str) // copy函数返回一个大小写变换之后的副本 boost::algorithm::to_upper_copy(str) boost::algorithm::to_upper_copy(str) 移除指定字符串 // 移除第一个出现的指定字符串 erase_first_copy(str, "strOrChar") // 移除第n个出现的指定字符串 erase_nth_copy(str, "strOrChar", 0) // 移除最后出现的指定字符串 erase_last_copy(str, "strOrChar") // 移除所有出现的指定字符串 erase_all_copy(str, "strOrChar") // 移除头部的指定字符串 erase_head_copy(str, 5) // 移除尾部的指定字符串 erase_tail_copy(str, 5) 查找子串 boost::algorithm::find_first(str, "substr") boost::algorithm::find_last() boost::algorithm::find_nth() boost::algorithm::find_head() boost::algorithm::find_tail() 字符串拼接 boost::algorithm::join() using namespace boost::algorithm; int main() { std::vector<std::string> v{"Boost", "C++", "Libraries"}; std::cout << join(v, " ") << std::endl; } 字符串替换 boost::algorithm::replace_first_copy(s, "B", "D") boost::algorithm::replace_nth_copy(s, "i", 0, "D") boost::algorithm::replace_last_copy(s, "i", "D") boost::algorithm::replace_all_copy(s, "i", "D") boost::algorithm::replace_head_copy(s, 5, "DoAAA") boost::algorithm::replace_tail_copy(s, 8, "BecCCC")

863 27 0
c++boost字符串操作
c++程序的编码与字符集的转换
benojan 2023-2-8

c++程序的编码与字符集的转换

一、程序相关的编码 程序源文件编码 程序源文件编码是指保存程序源文件内容所使用的编码方案,该编码方案可在保存文件的时候自定义。 通常在简体中文windows环境下,各种编辑器(包括visual studio)新建文件缺省编码都是GB18030。 所以不特别指定的话,在windows环境下,c++源文件的编码通常为GB18030(GB18030兼容GBK); 在linux环境下,默认的为UTF-8编码。 c++程序内码 源程序编译后,c++中的字符串常量变成一串字节存放在可执行文件中,内码指的是在可执行文件中,字符串以什么编码进行存放。 这里的字符串常量指的是窄字符(char)而不是宽字符(wchar_t)。 宽字符通常都是以Unicode(VC使用UTF-16BE,gcc使用UTF-32BE)存放。 通常简体中文版的VC使用内码为GB18030,而gcc使用内码缺省为UTF-8,但可以通过-fexec-charset参数进行修改。 (可以通过在程序中打印字符串中每个字节的16进制形式来判断程序使用的内码)。 运行环境编码 运行环境编码指的是,执行程序时,操作系统或终端所使用的编码。程序中输出的字符最终要转换为运行环境编码才能显示,否则就会出现乱码。 常用的简体中文版的windows环境编码是GB18030,linux下最常用的环境编码是UTF-8。 三种编码之间的关系 程序源文件【源文件编码】 → (编译器编译) → 目标文件【程序内码】 → (运行后输出信息) → 输出【运行环境编码】 二、已知的问题 windows下,wchar_t的c++程序内码,VC默认使用UTF-16BE,所以wchar_t可能不支持生僻字。可以使用utf-8格式的char字符。 linux下,wchar_t的c++程序内码,默认使用UTF-32BE,所以生僻字应该没有这样的问题。 c++新标准里新增的char32_t,在windows下并未完全实现可用。标准输入输出流无法使用。 三、指定编译编码 功能 g++编译器 vs编译器 指定c++程序内码 -fexec-charset=GBK #pragma execution_character_set("utf-8") 指定源文件编码 -finput-charset=UTF-8 指定c++程序宽字符(wchar_t)内码 -fwide-exec-charset=UTF-16 指定运行环境utf-8编码 system("chcp 65001"); 四、C++中的字符类型 字符类型 字符文本 字符串类型 字符串文本 编码 范围 char 'a' string "abc" GBK或UTF-8 Windows 默认 GBKLinux 默认 UTF-8 wchar_t L'a' wstring L"abc" UTF-16BE或UTF-32BE Windows 默认 UTF-16BELinux 默认 UTF-32BE char8_t u8'a' u8string u8"abc" UTF-8 UTF-8 char16_t u'a' u16string u"abc" UTF-16 BMP平面字符(即代码点 U+0000 到 U+FFFF 范围内的字符) char32_t U'a' u32string U"abc" UTF-32 UTF-32 (char8_t 是 C++20 中的新增功能,需要 /std:c++20 或 /std:c++latest 编译器选项) 五、字符集转换 Windows平台 MFC程序中,如果从文件读入Utf-8字符集的字符在CString中,可以使用MultiByteToWideChar函数,转成Unicode字符集。 反之,Unicode字符集的CString,可以使用WideCharToMultiByte函数,转成GBK字符集或utf-8字符集的char[]或string。 void Utf8ToUnicode(CString& str) { // str是用CStdioFile类的ReadString()读取的Utf-8格式的文件,存入CString中 if (str.GetLength() == 0) { return; } PSTR szBuf = new CHAR[str.GetLength() + 1]; // 注意“+1”,char[]字符数组要求结束符,而CString中没有'\0' memset(szBuf, '\0', str.GetLength() + 1); // 将 WCHAR 转换成 CHAR for (int i = 0; i < str.GetLength(); ++i) { szBuf[i] = (CHAR)str.GetAt(i); // 逐字节读取CString中的数据,存入char[]中 } // 根据保存着utf8的char[],计算需要的宽字符字节数 INT nLen = MultiByteToWideChar(CP_UTF8, 0, szBuf, -1, NULL, 0); LPWSTR ptch = new WCHAR[nLen]; // utf8 => unicode MultiByteToWideChar(CP_UTF8, 0, szBuf, -1, ptch, nLen); // 将转换后的unicode交给str str = ptch; // 回收空间 if (NULL != ptch) delete[] ptch; ptch = NULL; if (NULL != szBuf) delete[] szBuf; szBuf = NULL; } LPSTR UnicodeToUtf8(CString& str, INT& nCount) { // CP_ACP 是 GBK,CP_UTF 是 Utf-8 nCount = WideCharToMultiByte(CP_UTF8, 0, str, -1, NULL, 0, NULL, NULL); // 获得需要的宽字符字节数 LPSTR pChar = new CHAR[nCount]; WideCharToMultiByte(CP_UTF8, 0, str, -1, pChar, nCount, NULL, NULL); // utf8 => unicode return pChar; } wstring是Unicode字符集,可以使用WideCharToMultiByte转换成gbk字符集的string或utf-8字符集的string。 #include <iostream> #include <windows.h> int main() { std::wstring pwszUnicode = L"你好𣍐"; int iSize; char* pszMultiByte; // CP_ACP 是 GBK,CP_UTF 是 Utf-8 iSize = WideCharToMultiByte(CP_UTF8, 0, pwszUnicode.c_str(), -1, NULL, 0, NULL, NULL); pszMultiByte = new char[iSize + 1]; WideCharToMultiByte(CP_UTF8, 0, pwszUnicode.c_str(), -1, pszMultiByte, iSize, NULL, NULL); std::string pszUtf8(pszMultiByte); system("chcp 65001"); std::cout << pszUtf8 << std::endl; delete[] pszMultiByte; pszMultiByte = NULL; return 0; } Linux平台 Linux平台下可以使用 iconv() 函数 // https://www.cnblogs.com/huojing/articles/16291647.html 太复杂,略... 通用方式 使用 wstring_convert 转换(注意:c++17已弃用<codecvt>) #include <iostream> #include <locale> #include <codecvt> // vs编译器需要这一行 #pragma execution_character_set("utf-8") std::string u32string_to_string(const std::u32string& str) { // 虽然在linux平台下此处使用codecvt_utf8_utf16和codecvt_utf8都能正常转换,但是还是不建议用codecvt_utf8_utf16 std::wstring_convert<std::codecvt_utf8<char32_t>, char32_t> converter; return converter.to_bytes(str); } std::u32string string_to_u32string(const std::string& str) { std::wstring_convert<std::codecvt_utf8<char32_t>, char32_t> converter; return converter.from_bytes(str); } std::string u16string_to_string(const std::u16string& str) { std::wstring_convert<std::codecvt_utf8_utf16<char16_t>, char16_t> converter; return converter.to_bytes(str); } std::string wstring_to_string(const std::wstring& str) { // 虽然在linux平台下此处使用codecvt_utf8_utf16和codecvt_utf8都能正常转换,但是还是不建议用codecvt_utf8_utf16 std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> converter; return converter.to_bytes(str); } std::wstring string_to_wstring(const std::string& str) { std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> converter; return converter.from_bytes(str); } int main() { // windows平台需要这一行 system("chcp 65001"); std::u32string u32str = U"中國人𣍐"; std::cout << u32string_to_string(u32str) << std::endl; std::string str = "中國人𣍐"; std::cout << u32string_to_string(string_to_u32string(str)) << std::endl; std::u16string u16str = u"中國人𣍐"; std::cout << u16string_to_string(u16str) << std::endl; std::wstring wstr = L"中國人𣍐"; std::cout << wstring_to_string(wstr) << std::endl; std::string str2 = "中國人𣍐"; std::cout << wstring_to_string(string_to_wstring(str2)) << std::endl; } 注意: codecvt_utf8_utf16 在 UTF-8 和 UTF-16 之间转换。 codecvt_utf8 只转换为 UCS-2/4。 关于两者之间的区别,chatGPT的回答是: std::codecvt_utf8和std::codecvt_utf8_utf16都是C++ STL库中用于文本编码转换的类,但它们之间有一些细微的区别。 std::codecvt_utf8是用于将UTF-8编码的字符串转换为本地宽字符集编码的类。它提供了从UTF-8到本地宽字符集编码和从本地宽字符集编码到UTF-8的转换方法。因此,当你想要使用UTF-8编码来存储或传输字符串时,可以使用std::codecvt_utf8来将其转换为本地编码。 std::codecvt_utf8_utf16是用于在UTF-8和UTF-16编码之间进行转换的类。它提供了从UTF-8到UTF-16和从UTF-16到UTF-8的转换方法。因此,当你需要在UTF-8和UTF-16编码之间进行转换时,可以使用std::codecvt_utf8_utf16。 虽然它们都可以用于对UTF-8编码进行转换,但它们之间的主要区别在于它们所涵盖的编码范围不同。std::codecvt_utf8_utf16可以处理所有Unicode字符,包括增补平面字符(Supplementary Planes);而std::codecvt_utf8只能处理基本多文种平面(BMP)中的字符,无法处理增补平面字符。 使用boost的conv来进行字符集转换 #include <boost/locale/encoding.hpp> std::string UTF8toGBK(const std::string& str) { return boost::locale::conv::between(str, "GBK", "UTF-8"); } std::string GBKtoUTF8(const std::string& str) { return boost::locale::conv::between(str, "UTF-8", "GBK"); } std::wstring GBKtoUNICODE(const std::string& str) { return boost::locale::conv::to_utf<wchar_t>(str, "GBK"); } std::string UNICODEtoGBK(std::wstring wstr) { return boost::locale::conv::from_utf(wstr, "GBK"); } std::string UNICODEtoUTF8(const std::wstring& wstr) { return boost::locale::conv::from_utf(wstr, "UTF-8"); } std::wstring UTF8toUNICODE(const std::string& str) { return boost::locale::conv::utf_to_utf<wchar_t>(str); } 结合 c++20 的新类型: u8string、u16string、u32string char8_t、char16_t、char32_t 头文件 #include <string> // UTF8与UTF16互相转换 u8string conv_utf16_to_utf8(u16string s); u16string conv_utf8_to_utf16(u8string s); // UTF16与UTF32互相转换 u32string conv_utf16_to_utf32(u16string s); u16string conv_utf32_to_utf16(u32string s); // UTF8与UTF32互相转换 u8string conv_utf8_to_utf32(u32string s); u32string conv_utf32_to_utf8(u8string s); // 同类型不同类型名强制转换 // 如果明确知道string内容为UTF8字符集,使用该函数将其强制转换为u8string u8string cast_u8string(string s); string cast_string(u8string s); // 如果明确知道wstring内容为UTF16字符集,使用该函数将其强制转换为wstring u16string cast_u16string(wstring s); wstring cast_wstring(u16string s); 函数定义 #include <string> #include <boost/locale.hpp> u8string conv_utf16_to_utf8(u16string s) { return boost::locale::conv::utf_to_utf<char8_t>(s.c_str()); } u16string conv_utf8_to_utf16(u8string s) { return boost::locale::conv::utf_to_utf<char16_t>(s.c_str()); } u32string conv_utf16_to_utf32(u16string s) { return boost::locale::conv::utf_to_utf<char32_t>(s.c_str()); } u16string conv_utf32_to_utf16(u32string s) { return boost::locale::conv::utf_to_utf<char16_t>(s.c_str()); } u8string conv_utf8_to_utf32(u32string s) { return boost::locale::conv::utf_to_utf<char8_t>(s.c_str()); } u32string conv_utf32_to_utf8(u8string s) { return boost::locale::conv::utf_to_utf<char32_t>(s.c_str()); } u8string cast_u8string(string s) { return u8string((char8_t*)s.data(), s.size()); } string cast_string(u8string s) { return string((char*)s.data(), s.size()); } u16string cast_u16string(wstring s) { return u16string((char16_t*)s.data(), s.size()); } wstring cast_wstring(u16string s) { return wstring((wchar_t*)s.data(), s.size()); } u32string 输出到 utf-8 文件中 std::u32string str{ U"中國娃娃𣍐快活" }; std::locale loc(std::locale(), new std::codecvt_utf8<char32_t>); std::basic_ofstream<char32_t> ofs("test.txt"); ofs.imbue(loc); std::cout << "Writing to file (UTF-8)... "; ofs << str; std::cout << "done!\n"; 六、相关链接 https://blog.csdn.net/whl0071/article/details/125677678 [c++程序编码]⭐ https://blog.csdn.net/qq981091829/article/details/114121785 [UTF16及GB18030编码介绍] http://blog.csdn.net/haiross/article/details/45074355 [C++中的locale设置(即系统区域设置)] http://blog.csdn.net/wallaceli1981/article/details/6116738 [C++ 标准库的 locale 类用法] https://gcc.gnu.org/onlinedocs/libstdc++/manual/localization.html [libstd c++ localization章节]

1408 27 0
c++boost编码转换字符集UTF-8UnicodeGBK
c++程序的编码与字符集的转换
宝塔面板使用手册
benojan 2022-11-3

宝塔面板使用手册

命令行操作 bt 宝塔面板SSL重置 rm -f /www/server/panel/data/ssl.pl && /etc/init.d/bt restart

389 27 0
宝塔面板
mysql的进阶用法
benojan 2022-11-2

mysql的进阶用法

视图 类似临时表取别名,可反复使用。不推荐使用 -- 创建 create view v1 as select * from student where sid > 10; -- 使用 select * from v1; # 使用v1视图 -- 修改 alter view v1 as SQL; -- 删除 drop view v1; 触发器(不推荐使用) delimiter \\ create trigger t1 before/after insert/delete on table1 for each row begin SQL; -- insert 可使用 NEW 变量; delete 可使用 OLD 变量 end \\ delimiter ; 函数 ---- 内置函数 select curdate(); -- 当前日期 current_timestamp(); -- 当前日期 length('asdf'); -- 字符串长度 concat('alex', '123'); -- 拼接 date_format('2020-02-02', "%Y-%m") -- 时间格式化 ---- 自定义函数 delimiter \\ create function f1( i1 int, i2 int) returns int begin -- 可以写 存储过程 语句 declare num int default 0; set num = i1 + i2; return(num); end \\ delimiter ; select f1(); 存储过程 (更重要,DBA与程序员之间的分工活) 保存在MySQL上的一个别名,它是一堆SQL语句,用于替代程序员写SQL语句 delimiter \\ create procedure p1( in n1 int, -- in, out, inout out n2 int) begin set n2 = 123123; select * from user where id > n1; end \\ delimiter ; set @v1 = 0; call p1(1, @v1); -- @v1只用于取值,无法传入值,如果为inout,则皆可 select @v1; 事务(性能不高) delimiter \\ create procedure p2( out return_code tinyint) begin -- 定义异常 declare exit handler for sqlexception begin set return_code = 1; # 异常状态 rollback; # 回滚操作 end; -- 原子性事务操作 start transaction; delete from tb1; insert into tb2(name) values('seven'); commit; set return_code = 0; # 正常状态 end \\ delimiter ; 游标(略) 动态执行SQL(防SQL注入) delimiter \\ create procedure p2( -- in tpl varchar(255), in arg int) begin set @arg = arg; -- 创建session变量 prepare prod_name from 'select * from user where id = ?'; execute prod_name using @arg; -- 只能是session变量 deallocate prepare prod_name; end \\ delimiter ; 索引(Index) 创建额外文件,某种格式存储。 普通索引: 加速查找 主键索引: 加速查找 + 不能重复 + 不能为空 唯一索引: 加速查找 + 不能重复 联合索引: (多列) 联合主键索引 联合唯一索引 联合普通索引 create index id_name on user(name); drop index id_name on user; ORM操作 (SQLAlchemy)

594 27 0
mysql
mysql的进阶用法
mysql的备份与还原
benojan 2022-11-2 java

mysql的备份与还原

备份 >mysqldump -u root db1 > db1.sql -p # 无-d参数,备份结构与数据 >mysqldump -u root -d db1 > db1.sql -p # 有-d参数,只备份结构 导入 create database db2; # 先建立数据库 >mysqldump -u用户 db2 < db1.sql -p

486 27 0
mysql
mysql的备份与还原
mysql的增删改查
benojan 2022-11-2 传奇私服-V8M2引擎学习笔记

mysql的增删改查

增 Insert insert into t1(id, name) value(1, '张三'); insert into t1(name, age) value('张三', 17), ('李四', 18); insert into t1(name, age) select name, age from t2; 删 Delete delete from t1; delete from t1 where id = 2; delete from t1 where id < 6 and name = '张三'; 改 Update update t1 set age = 18 where age = 17; update t1 set name = '张四', age = 19 where id = 1; 查 Select select * from t1; select id, name from t1; select id, name as cname from t1; select id, name, 11 from t1; -- 11为额外的列 select id, name, 11, (select num from t2) as number from t1; -- 子查询语句,必须单值 select id, name, 11, (select num from t1 as b where b.student_id = a.student_id) as number from t1 as a group by a.student_id; -- 子查询语句可以使用外层表 select case when min(num) < 10 then 0 else min(num) end from t1; select if(min(num)<10, 0, min(num)) from t1; -- 同上 select distinct name from t1; -- 去重,但效率不高,可用group by去重 使用函数查询 if(,,) isnull() 条件查询 where select * from t1 where id != 1; select * from t1 where id > 10 or name = '张三'; select * from t1 where id not in(1,5,12); select * from t1 where id between 5 and 12; -- 包含 5, 12 select * from t1 where id in (select nid from t2); like select * from t1 where name like 'a%'; select * from t1 where name like 'a_'; limit select * from t1 limit 5; -- 前5行 select * from t1 limit 5 offset 2 -- 从第3行开始的5行 select * from t1 limit 2, 5; -- 从第3行开始的5行 order by select * from t1 order by id asc; select * from t1 order by id desc; select * from t1 order by id asc, name desc; group by select count(id), part_id from t1 group by part_id; select max(id), part_id from t1 group by part_id; select min(id), part_id from t1 group by part_id; 聚合函数 count、max、min、sum、avg 聚合函数二次筛选,必须使用 having select count(id), part_id from t1 group by part_id having count(id) > 1; 连表查询 左右连表 left join, right join, inner join where连表 select * from a1, b1 where a1.part_id = b1.id; left join连表 a1是左表, b1是右表,left join为左表数据全部显示 select * from a1 left join b1 on a1.part_id = b1.id; right join连表 a1是左表,b1是右表,right join为右表数据全部显示 select * from a1 right join b1 on a1.part_id = b1.id; inner join连表 a1是左表, b1是右表, inner join,把出现null的行隐藏 select * from a1 inner join b1 on a1.part_id = b1.id; 上下连表 union union连表,去重 select id, name from tb1 union select num, sname from tb2; union all连表,不去重 select id, name from tb1 union all select num, sname from tb2; 临时表查询 select * from (select * from score where num > 60) as B;

523 27 0
mysql
mysql的增删改查
mysql的数据类型
benojan 2022-11-2 html/css/js

mysql的数据类型

数字类型 整数 类型 范围 tinyint -128 ~ 127 tinyint unsigned 0 ~ 255 smallint -32768 ~ 32767 smallint unsigned 0 ~ 65535 int -2147483648 ~ 2147483647 int unsigned 0 ~ 4294967295 bigint -9223372036854775808 ~ 9223372036854775807 bigint unsigned 18446744073709551615 小数 类型 说明 float 单精度 double 双精度 decimal (总位数, 小数位数):十进制小数(字符串法存) 字符串类型 (定长往前放,变长往后放) 类型 长度、特点 char(10) 255,速度快 (定长) varchar(10) 255,节省空间,速度慢 (变长) text 65535 mediumtext 16777215 longtext 4294967295 时间类型 类型 格式 datetime YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59) date YYYY-MM-DD(1000-01-01/9999-12-31) time HH:MM:SS('-838:59:59'/'838:59:59') year YYYY(1901-2155) timestamp YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037年某时) 枚举、集合类型 类型 用例 说明 enum sex ENUM('male', 'female') 单选 set col SET('a', 'b', 'c', 'd') 多选,如 'a, b'、'c, b'

506 27 0
mysql
mysql的数据类型
mysql的索引与外键
benojan 2022-11-2 工具经验

mysql的索引与外键

主键索引 约束:不能重复且不能为空; 加速查找 id int unsigned auto_increment primary key, primary key (id,name), # 多列主键 唯一索引 约束:不能重复,可以为空; 加速查找 unique 约束名 (id, name), 外键 约束:值必须是另一张表的主键 constraint fk_user_depar foreign key(department_id) references department(id), 外键的变种: 一对一 blog表中,fk(user_id) + unique(user_id) 如:一个博客属于一个用户,一个用户只能有一个博客 一对多 student表中,fk(class_id) 如:一个学生属于一个班级,一个班级可以有多个学生 多对多 fk(aid) + fk(bid) + unique(aid,bid) 如:关系表、组合配对

491 27 0
mysql
mysql的索引与外键
mysql的数据表操作
benojan 2022-11-2 excel

mysql的数据表操作

创建表 show tables; -- 显示表 create table t1(id int, name char(10)); -- 创建表 create table t1(id int, name char(10)) default charset=utf8; -- 创建指定字符编码的表 创建详细的表 create table t1( 列名 类型 null, -- 允许空 列名 类型 not null, -- 不许空 列名 类型 not null default 1, -- 默认值 列名 类型 auto_increment primary key, -- 自增,主键(约束:不能重复且不能为空;加速查找) id int, name char(10) -- 末行不加"," ) engine=innodb default charset=utf8; -- 指定 innodb引擎 引擎的区别: 引擎 功能 innodb 支持事务,原子性操作 myisam 不支持事务 参考 mysql使用索引与外键 mysql的数据类型 清空表 delete from t1; -- 自增id不归零 truncate table t1; -- 自增id归零 删除表 drop table t1; 查看表的描述description desc t1; 查看表的SQL创建语句 show create table t1; 修改自增变量值 alter table t1 set AUTO_INCREMENT=2;

498 27 0
mysql的数据表操作
  1. 首页
  2. 3
  3. 4
  4. 5
  5. 尾页

搜索

搜索历史 清空

最新评论

标签

  • 重写
  • 继承
  • 虚函数
  • springboot
  • java
  • drf
  • 私服
  • 脚本
  • Windows窗口程序
  • cmake
  • dll
  • Modeless
  • Accelerators
  • WTL
  • ListCtrl
  • MFC
  • regex
  • 正则表达式
  • 虚拟环境
  • venv
  • radio
  • html
  • vim
  • nodejs
  • Linux
  • 宝塔面板
  • bt
  • chatGPT
  • AI
  • turtle
  • python
  • 我的世界
  • api
  • bukkit
  • 字符串操作
  • docker
  • 本地架设
  • 游戏
  • 编程
  • CodeCombat
  • 教程
  • 插件开发
  • Minecraft
  • GBK
  • Unicode
  • UTF-8
  • 字符集
  • 转换
  • 编码
  • boost

链接

  • 標準吳語字典
  • 台州方言維基
  • 溫嶺吳語微辭典
关于 友链 rss
Powered by benojan

备案号: