当前位置: 首页 > news >正文

跟我一起学“仓颉Web”基础编程-多表查询和事务

目录

一、多表查询

二、事务

三、小结


一、多表查询

创建数据库

create database web_study; use web_study;

创建数据表

CREATE TABLE `student` ( `id` int NOT NULL AUTO_INCREMENT, `name` varchar(20) NOT NULL, `age` int DEFAULT NULL, `sex` int DEFAULT NULL, `grade` int DEFAULT NULL, PRIMARY KEY (`id`) ); CREATE TABLE `grade` ( `id` int NOT NULL AUTO_INCREMENT, `grade` varchar(20) NOT NULL, PRIMARY KEY (`id`) );

给数据表添加数据

INSERT INTO `student` VALUES (1,'白小黑',18,1,1), (2,'刘小辉',19,1,1), (3,'胡小静',20,0,2), (4,'漆小孟',19,0,2), (5,'林小茂',21,1,2); INSERT INTO `grade` VALUES (1,'大一'), (2,'大二'), (3,'大三'), (4,'大四');

核心代码

package WebStudy import std.database.sql.* import mariadb.cdbc.* main(): Unit { moreTable() } // 多表查询 public func moreTable(): Unit { // 创建驱动 let driver = DriverManager.getDriver('mariadb').getOrThrow() // 数据库的链接 let url = 'mariadb://127.0.0.1:3306' // 数据库用户 let username = ('username', 'root') // 数据库密码 let password = ('password', 'YGBG372S1') // 需要连接数据库 let database = ('database', 'web_study') // 启动驱动获取数据资源 let dataSource = driver.open(url, [username, password, database]) // 创建连接 let connection = dataSource.connect() // 查询大二的同学(内连接) println("查询大二的同学(内连接)") let sql1 = """ select s.id, s.name, s.age, s.sex, g.grade fromstudent s joingrade g on s.grade = g.id where g.grade=? """ let statement1 = connection.prepareStatement(sql1) statement1.set<String>(1, '大二') let resultSet1 = statement1.query() println('序号\t 姓名\t 年龄\t 性别\t 年级\t') while (resultSet1.next()) { let id = resultSet1.get<Int64>(1) let name = resultSet1.get<String>(2) let age = match (resultSet1.getOrNull<Int64>(3)) { case Some(v) => v case None => 0 } let sex = if(resultSet1.getOrNull<Int64>(4) == 1){'男'}else{'女'} let grade = resultSet1.get<String>(5) println('${id}\t ${name}\t ${age}\t ${sex}\t ${grade}') } // 查询大二的同学(子查询) println("\n查询大二的同学(子查询)") let sql2 = """ select s.id, s.name, s.age, s.sex, g.grade from student s, (select id, grade from grade where grade=?) g where s.grade = g.id; """ let statement2 = connection.prepareStatement(sql2) statement2.set<String>(1, '大二') let resultSet2 = statement1.query() println('序号\t 姓名\t 年龄\t 性别\t 年级\t') while (resultSet2.next()) { let id = resultSet2.get<Int64>(1) let name = resultSet2.get<String>(2) let age = match (resultSet2.getOrNull<Int64>(3)) { case Some(v) => v case None => 0 } let sex = if(resultSet2.getOrNull<Int64>(4) == 1){'男'}else{'女'} let grade = resultSet2.get<String>(5) println('${id}\t ${name}\t ${age}\t ${sex}\t ${grade}') } // 资源释放 有顺序 resultSet1.close() resultSet2.close() statement1.close() statement2.close() connection.close() dataSource.close() }

运行结果

二、事务

事务:把多个数据库操作(增 / 删 / 改)打包成一个整体,要么全部成功,要么全部失败

事务的特性:原子性、一致性、隔离性、持久性

原子性:多个操作看成一步,成功就全部成功,失败就全部撤回。

一致性:操作前后数据都是合法、正确的,不会出现中间状态、脏数据。

隔离性:多人同时操作数据库,互不干扰,你改你的,我改我的,不会互相影响。

持久性:一旦提交成功,永久保存!断电、重启都不会丢。

为什么要用事务?

同时操作多张表,或者连续执行多个增删改,必须保证数据不出错、不混乱

举个栗子,当前年级表里只有大一到大四,可以突然有一天,来了一个新同学,肖婕婕(女,25岁),她是研二的大学姐,为了可以灵活且高效的添加肖婕婕的信息,即同时操作学生表和年级表,这个时候,为了保证添加的信息的原子性、一致性、持久性,就必须用到事务。

核心代码

package WebStudy import std.database.sql.* import mariadb.cdbc.* main(): Unit { transaction() } // 事务 public func transaction(): Unit { // 创建驱动 let driver = DriverManager.getDriver('mariadb').getOrThrow() // 数据库的链接 let url = 'mariadb://127.0.0.1:3306' // 数据库用户 let username = ('username', 'root') // 数据库密码 let password = ('password', 'YGBG372S1') // 需要连接数据库 let database = ('database', 'web_study') // 启动驱动获取数据资源 let dataSource = driver.open(url, [username, password, database]) // 创建连接 let connection = dataSource.connect() // 事务 var transaction: Transaction // 创建事务 transaction = connection.createTransaction() // 开启事务 transaction.begin() // 新增年级 let sql1 = 'insert into grade (id, grade) values (?, ?)' let statement1 = connection.prepareStatement(sql1) statement1.set<Int64>(1, 5) statement1.set<String>(2, '研二') // 新增学生 let sql2 = 'insert into student (name, age, sex, grade) values (?, ?, ?, ?)' let statement2 = connection.prepareStatement(sql2) statement2.set<String>(1, '肖婕婕') statement2.set<Int64>(2, 25) statement2.set<Int64>(3, 0) statement2.set<Int64>(4, 5) try { let row1 = statement1.update() println('新增年级成功! row: ${row1.rowCount}') let row2 = statement2.update() println('新增学生成功! row: ${row2.rowCount}') // 提交事务 transaction.commit() } catch (e: SqlException) { // 事务回滚 transaction.rollback() println('新增失败, ${e.message}') } finally { statement1.close() statement2.close() } // 资源释放 有顺序 connection.close() dataSource.close() }

运行结果

数据库结果

三、小结

本章为大家详细的介绍了多表查询和事务的内容,下一章为大家介绍分页查询的内容。最后,创作不易,如果大家觉得我的文章对学习仓颉Web基础编程有帮助的话,就动动小手,点个免费的赞吧!收到的赞越多,我的创作动力也会越大哦,谢谢大家🌹🌹🌹!!!

http://www.rkmt.cn/news/1451557.html

相关文章:

  • EnvironmentalBERT-base核心功能揭秘:专为ESG领域打造的文本分析工具
  • 如何用Umi-OCR免费离线OCR工具快速搞定图片文字识别和双层PDF转换
  • 如何5分钟掌握SPT-AKI Profile Editor:逃离塔科夫离线版终极存档修改工具完全指南
  • 高效阅读源码:从策略到实战的开发者进阶指南
  • 从微软资助NSF项目看企业数据平台构建与效能优化实战
  • 基于环境智能与传感器融合的独居老人居家安全系统构建实践
  • TorchScript里trace和script到底怎么选?一个带if-else的实际例子讲清楚
  • 2026年知名的弹簧/扭转弹簧/耐高温弹簧稳定供货厂家推荐 - 品牌宣传支持者
  • Get Shit Done:终极AI开发工具,彻底解决Claude上下文衰退难题
  • 深入libuvc与libusb:手把手解析USB摄像头数据流的双缓冲机制与同步传输
  • 从数据到决策:构建基于价值最大化的智能决策系统
  • 量化交易中的特征重要性分析:GitHub_Trending/ma/machine-learning-for-trading SHAP值应用
  • 2026年支持跨境多功能旅行收纳包/七件套旅行收纳包/宁波旅行收纳包/旅行收纳包精选推荐公司 - 品牌宣传支持者
  • STM32F103VET6通过FSMC驱动2.8寸ILI9341彩屏的双库工程(标准库+HAL)
  • Mesh vs. Torus实战选型:在芯片互连与数据中心网络中如何避坑?
  • Three.js 实战:用 Water 库 5 分钟搞定一个会流动的湖泊(附免费法线贴图资源)
  • 智能胎心监护仪开发全解析:从BLE连接到移动端信号处理
  • 技术赋能生物多样性保护与文化遗产传承:从数据采集到社区参与的全栈实践
  • 原恒星双星光度测量新方法:OCS分子谱线观测技术
  • 革命性中文大语言模型Yuan2.0-2B:入门指南与快速上手教程
  • 5分钟快速上手res-downloader:跨平台网络资源下载终极指南
  • ArcGIS Pro城市建设用地适宜性评价实操工程包(含多源因子图层与完整索引)
  • UniApp小程序跳转后,参数怎么收?手把手教你处理onLaunch和onShow中的extraData
  • CANN EasyAsc DSL a2 Cube-Vec-Cube-Vec模式
  • TradingAgents-CN智能交易框架实战指南:5步快速搭建多智能体量化分析平台
  • 手把手教你用Wireshark抓包,搞定CANoe‘No TCP/IP Stack’模式下的数据监控
  • YOLOv5中文标签实战:用自定义数据集训练一个‘中文版‘安全帽检测模型(附完整代码)
  • 数字权益卡:企业营销新利器
  • 技术行动与学术传承:从数据密集型研究到区域创新生态构建
  • Linux下用libuvc驱动USB摄像头:从权限问题到实时视频流的保姆级避坑指南